Skip to main content

A package that implements a news sentiment based strategy for trading using Tiknoff Invest API

Project description

Tinvest Robot Perevalov

Version Downloads

Tinvest Robot Perevalov - это Python Библиотека, реализующая функциональность торгового робота на основе Tinkoff Invest API для Python с торговой стратегией, основанной на анализе тональности новостей.

Описание торговой стратегии

Торговая стратегия основана на анализе тональности новостей. При получении новой новости производится анализ её тональности, в результате которого получаем один из трёх классов: positive, negative, или neutral. После чего, проверяется наличие упоминания той или иной компании в заголовке новости. Если компания упомянута, то в случае новости с классом positive посылается сигнал на покупку акций в заданном количестве. Если новость с классом negative, то посылается сигнал на продажу акций в заданном количестве.

Ниже на рисунке представлена концептуальная схема стратегии на определённом примере.

Схема стратегии

Как видно, ключевым звеном является модуль анализа тональности, в качестве которого используется предобученная нейронная языковая модель (neural language model).

Тестирование торговой стратегии (Backtesting)

Тестирование стратегии проводилось на наборе данных новостей "Historical financial news archive", который содержит в себе новостные данные по 800 компаниям из США за 12 лет (2008-2020).

В ходе тестирования был выбран диапазон с 2012 по 2020 годы включительно по 100 наиболее упоминаемым компаниям из набора данных. Поскольку некоторые компании оказались недоступны через сервис Тинькофф Инвестиции, в итоге в процедуру тестирования было включено 90 компаний.

В рамках наблюдаемого года (например 2013) бралось соответствующее подмножество новостей упорядоченных по дате по возрастанию. После чего по каждой из компаний проверялось упоминание в той или иной новости и далее использовался алгоритм стратегии описанной выше со следующими условиями:

  • Комиссия за операции не учитывалась;
  • Покупка в шорт (в минус) недоступна;
  • Покупка и продажа производится по одному лоту за раз;
  • Финансовый результат считался по определённой бумаге за конкретный год;
  • Данные по цене (свечи) брались из API Тинькофф Инвестиции;
  • Если на конец года на балансе имелось ненулевой число акций, то финальный баланс на год рассчитывался по цене закрытия бумаг в последний торговый день года.

Ниже представленые некоторые графики по результатам тестирования.

Доход по годам

На графике мы видим, что доходность была положительной почти на всех годах, за исключением 2018. Также, очевидно что доходность не зависит от количества операций по бумагам (это было так же подтверждено анализом коррелляции).

Доход по тикерам

На графике не уместились все тикеры, однако в топ-3 самых доходных компаний входят: TSLA (64.72%), NFLX (28.62%), AAPL (18.68%) в среднем за год. Также, очевидно, что большинство бумаг оказались с положительной доходностью.

Тестирование можно воспроизвести с помощью данного ноутбука скачав перед этим датасет. Экспериментальные данные тестирования доступны тут.

Как запустить решение (How to run)

Для запуска решения необходимо установить Docker и Docker Compose на вашей машине. После чего, необходимо перейти в директорию examples и запустить там следующие команды:

docker-compose build
docker-compose up

После чего, запустится 3 контейнера:

  • fetch -- контейнер для получения новостей из интернета (запускается сразу или через интервал, указанный в примере);
  • trade -- контейнер для совершения торговых операций, мониторит полученные новости через определённый интервал, указанный тут.
  • sqlite-web -- позволяет следить за полученными новостями и исполненными операциями в базе данных через веб-интерфейс (по умолчанию порт 8080).

Внимание, перед тем как запускать решение, необходимо создать .env файл с вашими конфигурационными параметрами. Пример конфигурационного файла:

TINVEST_ACCOUNT_ID=200000000
TINVEST_DB_NAME=../data/tinvest-perevalov.sqlite
SENTIMENT_MODEL=cardiffnlp/twitter-roberta-base-sentiment
TINVEST_TOKEN=t.YoUr.tInVeSt.token
IS_SANDBOX=True
TINVEST_TICKERS=CSCO,AAPL

Описание параметров:

  • TINVEST_ACCOUNT_ID: Идентификатор счета в тинькофф инвестициях (или в песочнице)
  • TINVEST_DB_NAME: Имя базы данных где будуn храниться новости и данные об операциях (если меняете относительный путь, то необходимо изменить volume в docker-compose.yml)
  • SENTIMENT_MODEL: Имя модели для обработки новостей (в данный момент поддерживается только эта модель)
  • TINVEST_TOKEN: Токен для доступа к тинькофф инвестициям
  • IS_SANDBOX: Признак того, работаем ли мы в песочнице
  • TINVEST_TICKERS: Список тикеров для торговли через запятую

Ограничения и планы на будущее

Основными ограничениями решения можно считать:

  • Торговля только на СПб Бирже (из-за использования англоязычной модели анализа новостей);
  • Торговля по одному лоту на бумагу;
  • Стратегия "захардкожена" внутри библиотеки.

Однако, в будущем планируются следующие улучшения:

  • Поддержка нескольких бирж для торговли;
  • Поддержка нескольких моделей анализа новостей;
  • Кастомизация стратегии;
  • Коннекторы для использования разных БД.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tinvest-robot-perevalov-0.1.3.tar.gz (14.1 kB view details)

Uploaded Source

Built Distribution

tinvest_robot_perevalov-0.1.3-py3-none-any.whl (11.8 kB view details)

Uploaded Python 3

File details

Details for the file tinvest-robot-perevalov-0.1.3.tar.gz.

File metadata

File hashes

Hashes for tinvest-robot-perevalov-0.1.3.tar.gz
Algorithm Hash digest
SHA256 4104c9d01a8c4c18bdcc754e06bcbd6644c2c82f865e32551c6e119f0f9fe28f
MD5 b580ba357d0539f059d7101d81bf4f03
BLAKE2b-256 1c77473d73c59a0a7a87245da25c9b41c2a3c20fb28b65235d872294e6e74665

See more details on using hashes here.

File details

Details for the file tinvest_robot_perevalov-0.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for tinvest_robot_perevalov-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 6480a159076dda868130597ca8ae410b219e9d71dda39c3abd0cd33325195caf
MD5 3dc434e7eff79b06c3f24007c3f3f8bd
BLAKE2b-256 67d7144ac50d4a3d56bfdc1f72e077ebfa3dd350f28f47ab1886f0b51bde2bf9

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page