Skip to content

Insaned79/gradientindex

Repository files navigation

  1. Требования: предполагается, что у вас установлен jupyter-notebook, python3.6 (или выше), pip 0.1 pip3 install -r requirements.txt
  2. Для получения данных, требуется зарегистрироваться на сайте financialmodelingprep.com (пакет Starter) и получить токен. Технически, возможно обойтись пакетом Free, "растянув" загрузку на несколько дней, чтобоы уложиться в лимиты, но этот вариант не описан в настоящей инструкции.
  3. Переименуйте файл config.py.sample в config.py. Отредактируйте его, вписав свой токен.
  4. Переименуйте шаблон базы данных invest.db.sample (например в invest.db)
  5. Любым редактором Sqlite (например DB Browser for SQLite) отредактируйте таблицу FRS, добавив историю ставок ФРС США. Это единственные данные, которые требуется вносить вручную, но они имеют очень большое значение для качества работы модели.
  6. Получение истории цен. В качестве источника данных используется yahoo finance.В jupyter-notebook откройте файл GetData.ipynb. Отредактируйте переменные first_year (первый год - обычно 2000), last_year (последний год - обычно текущий), base (имя базы данных из п.3). Также можно отредактировать зачение переменных SP_SYMBOLS и OLD_SP - по-умолчанию они содержат список акций, которые были исключены из индекса S&P 500 (для получения истории) и акций, которые сейчас включены в индекс. Вы можете определить для себя другие критерии для выбора акций. Выполните все ячейки. Получение цен занимает несколько часов.
  7. Получение истории выплаты дивидендов. В качестве источника данных используется yahoo finance.В jupyter-notebook откройте файл GetDividents.ipynb. Внесите изменения аналогично п.5. Выполните все ячейки.
  8. Получение истории финансовых показателей. В качестве источника данных используется financialmodelingprep. В jupyter-notebook откройте файл GetFinancial.ipynb. Внесите изменения аналогично п.5. Выполните все ячейки.
  9. Получение сектора и индустрии. В качестве источника данных используется yahoo finance.В jupyter-notebook откройте файл GetSectorsAndIdustries.ipynb. Внесите изменения аналогично п.5. Выполните все ячейки.
  10. Получение истории цен фьючерсов на comodities (товары широкого потребления).В качестве источника данных используется yahoo finance. В jupyter-notebook откройте файл GetComodity.ipynb. Внесите изменения аналогично п.5. Выполните все ячейки.
  11. Создание учебного набора данных (training dataset). В jupyter-notebook откройте файл GetComodity.ipynb. Важные замечания: 1. Последний год в обучающей выборке, должен быть на 1 меньше чем последний год в базе, а первый год в выборке должен быть на 1 больше чем первый год в базе. 2. В связи с тем, что финансовые показатели за прошедший год, публикуются в первые 3 месяца текущего года, граница принятия решения должна быть смещена как минимум на 1 апреля. Т.е. 2020 год в нашем случае начинается 1.04.2020 и заканчивается 31.03.2021. Пример: для прогнозирования данных в 2021-м году, необходимо готовить обучающую выборку не раньше 1 апреля, при этом использовать диапазон 2001-2019 годы. Значения для годов в обучающей выборке задаются в переменных first_year и last_year. Месяц и день границы принятия решения в переменных edge_month и edge_day. После выполнения всех ячеек, набор данных будет сохранен в файл y_train.csv
  12. Обучение модели. Выполните все ячейки в файле Train.ipynb. Модель будет сохранена в файл model.cbm
  13. Создание датасета для прогнозирования. Откройте файл CreatePredictDataset.ipynb. Измените значение переменной year на последний полный год. Т.е. в 2021 году, установите значение в 2020. Выполните все ячейки. Данные будут сохранены в файл y_test.csv
  14. Прогнозироание. Выполните все ячейки файла Predict.ipynb. Вы получите список из 7 наиболее перспективных акций года.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published