trading gym
Project description
AlphaProfit Trading Gym Env
Trading Gym Env - это "тренажер", где можно имитировать торговлю активами и обучать торговых роботов с помощью специальных методов RL. Он был разработан для быстрой и настраиваемой реализации алгоритмов RL для торговли.
Reinforcement Learning (RL) - это одна из областей машинного обучения, где агент учится принимать решения, выполняя действия в некоторой среде, чтобы максимизировать некоторый кумулятивный выигрыш.
Вот ключевые понятия и компоненты RL:
- Агент (agent) – сущность, которая принимает решения. В контексте игр это может быть игроком, а в торговле – торговым алгоритмом.
- Среда (env) – это всё, с чем агент взаимодействует. Агент делает действия в среде и получает обратную связь от неё.
- Состояние (state) – это описание текущей ситуации в среде. Например, в игре шахмат состоянием может быть расположение всех фигур на доске.
- Действие (action) – это то, что агент решает сделать в данный момент времени. В торговле это может быть решение купить, продать или удержать актив.
- Вознаграждение (reward) – это численное значение, которое агент получает после выполнения действия. Цель агента – максимизировать сумму вознаграждений за определенный период времени.
- Политика (policy) – это стратегия, которую агент использует для принятия решений. Это может быть простой алгоритм или сложная нейронная сеть, которая определяет, какое действие выполнить на основе текущего состояния.
RL отличается от других форм машинного обучения тем, что агенту не предоставляются "правильные" ответы. Вместо этого агенту предоставляется обратная связь в виде вознаграждения, основанная на его действиях, и он должен самостоятельно выяснить, какие действия приводят к максимальному вознаграждению.
Применение RL охватывает множество областей: от игр (например, обучение компьютера играть в шахматы или Go) до робототехники, финансов и многого другого.
На данный момент доступны следующие агенты:
- BuyAndHoldAgent
- RandomAgent
- EqualWeightingAgent
- A2C
- PPO
- DDPG
- TD3
- SAC
Требования
- Python >=3.10, <3.12
- gym ^0.26.2
- stable-baselines3 ^2.1.0
- loguru ^0.7.0
- matplotlib ^3.7.2
- seaborn ^0.12.2
- ... (и другие зависимости, указанные в
pyproject.toml
)
Установка
Через Poetry
- Установите Poetry:
pip install poetry
- Установите зависимости проекта:
poetry install
Через Docker
Dockerfile предоставлен для удобства установки и использования проекта в контейнере. Чтобы использовать Docker:
- Соберите образ:
docker build -t trading_gym_env .
- Запустите контейнер:
docker run -it trading_gym_env
Использование
Пример использования:
...
from tradegym.tradegym import TradingEnv
from tradegym.agents import *
from tradegym.crossval import BackTest
import tradegym
print(tradegym.__version__)
...
agent = RandomAgent(_, e_test_gym, symbol='BTC-USDT-PERP')
bk = BackTest(e_test_gym, agent, verbose_step=1000)
bk.render()
bk.get_plot_profit_benchmark().show()
...
Подробные примеры и эксперименты можно найти в каталоге notebooks
.
Тестирование
Для тестирования используйте:
pytest -v
Jupyter Notebooks
В репозитории присутствуют Jupyter notebooks. Откройте их, чтобы узнать больше о работе проекта и различных экспериментах.
Изменения
Посмотрите CHANGELOG.md для истории изменений.
Project Structure
├── repository/
├── CHANGELOG.md
├── Dockerfile
├── pyproject.toml
├── README.md
├── requirements.txt
├── notebooks/
├── test_Agent_RandomAgent.ipynb
├── quantstats-report.html
├── data/
├── tests/
├── stock_data_sample.csv
├── test_crossval.py
├── test_trading_env.py
├── test_agents.py
├── tradegym/
├── crossval.py
├── tradegym.py
├── __init__.py
├── rewards.py
├── agents/
├── baseline.py
├── sb3.py
├── __init__.py
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for tradegym-25.2.3-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 14b2f3bc61b0093f7a4055b6a72e4cda275a8e68e08c0299b66ee865bf5894bb |
|
MD5 | 8f6f42f49f95848df4081e681de18f60 |
|
BLAKE2b-256 | de9c653769a714e26e482a0fe4f1e73b4c0353dde37181eb274596445ff94b97 |