gym-anytrading

GitHub
2.4k 485 非常简单 1 次阅读 3天前MIT开发框架
AI 解读 由 AI 自动生成,仅供参考

gym-anytrading 是一个专为强化学习交易算法设计的开源工具包,基于广受欢迎的 OpenAI Gym 框架构建。它旨在解决金融交易领域缺乏统一、灵活且易于上手的仿真环境这一痛点,帮助开发者和研究人员更高效地训练和测试自动交易策略。

该工具主要面向外汇(FOREX)和股票两大市场,提供了三个核心环境:通用的抽象环境 TradingEnv,以及分别针对外汇和股市的 ForexEnv 与 StocksEnv。其独特的技术亮点在于对复杂交易逻辑的极致简化:摒弃了传统算法中繁琐的“持有”、“入场”、“出场”等多重动作定义,仅保留最核心的“买入”与“卖出”两个动作;同时将持仓状态简化为“做多”与“做空”。这种设计大幅降低了智能体的学习难度,避免了因动作空间过大导致的训练效率低下问题,让模型能更专注于捕捉市场规律。

gym-anytrading 非常适合从事量化交易研究的科研人员、希望尝试强化学习在金融领域应用的开发者,以及需要快速验证交易想法的算法工程师。通过简单的 pip 安装即可上手,它为探索自动化交易策略提供了一个坚实且灵活的起点,让用户能将精力集中在策略优化而非环境搭建上。

使用场景

某量化团队正在尝试利用强化学习开发一个自动化的外汇(FOREX)交易策略,希望模型能根据历史 K 线数据自主决定买卖时机。

没有 gym-anytrading 时

  • 环境搭建耗时极长:开发者需从零编写符合 OpenAI Gym 标准的交易环境代码,包括状态空间定义、奖励函数计算及步进逻辑,往往耗费数周时间。
  • 动作空间设计冗余:初期容易陷入误区,定义“买入、卖出、持有、入场、离场”等复杂动作,导致智能体难以收敛,甚至因“持有”动作被过度规避而学不到有效策略。
  • 头寸管理逻辑混乱:在处理做多(Long)与做空(Short)的切换时,缺乏标准化的位置状态定义,容易引发逻辑漏洞或回测结果失真。
  • 复用性与扩展性差:若后续想从外汇市场切换到股票市场测试,必须重新修改大量底层代码,无法快速验证策略在不同市场的泛化能力。

使用 gym-anytrading 后

  • 即插即用的高效开发:直接调用 ForexEnvStocksEnv 接口,几分钟内即可构建出标准化的训练环境,将精力集中于算法优化而非基建。
  • 动作空间精简高效:遵循工具推荐的最佳实践,仅保留 BuySell 两个核心动作,大幅降低学习难度,显著缩短模型收敛时间。
  • 头寸状态清晰明确:内置标准化的 LongShort 位置逻辑,自动处理复杂的持仓盈亏计算,确保回测数据的准确性与一致性。
  • 灵活的市场切换:凭借统一的抽象基类 TradingEnv,只需更换数据源即可在外汇与股票环境间无缝切换,快速对比策略表现。

gym-anytrading 通过标准化和简化交易环境的复杂性,让开发者能从繁琐的基建工作中解放出来,专注于强化学习策略的核心迭代与验证。

运行环境要求

GPU

未说明

内存

未说明

依赖
notes该工具是基于 OpenAI Gym (现兼容 gymnasium) 的强化学习交易环境库,主要用于外汇和股票市场的算法开发与测试。安装可通过 pip 或源码进行。核心依赖包括用于数据处理的 pandas、数值计算的 numpy 以及用于可视化的 matplotlib。README 中未明确指定具体的操作系统、GPU、内存或 Python 版本要求,通常此类库在标准的 Python 数据科学环境中即可运行。用户需自行准备交易数据(DataFrame 格式),也可使用库内自带的示例数据集。
python未说明
gymnasium
pandas
numpy
matplotlib
gym-anytrading hero image

快速开始

gym-anytrading

AnyTrading 是一个基于 OpenAI Gym 的环境集合,专为强化学习驱动的交易算法设计。

交易算法主要应用于两个市场:外汇市场股票市场。AnyTrading 的目标是提供一些 Gym 环境,以改进和简化在这一领域开发与测试基于强化学习的算法的过程。为此,我们实现了三个 Gym 环境:TradingEnvForexEnvStocksEnv

TradingEnv 是一个抽象环境,旨在支持各类交易场景。ForexEnv 和 StocksEnv 则分别继承并扩展了 TradingEnv。在后续章节中,我们将对这些环境进行更详细的说明,但在那之前,先讨论一下它们的一些特性。

注意: 对于专家用户,建议查看 gym-mtsim 项目。

安装

通过 PIP

pip install gym-anytrading

从仓库安装

git clone https://github.com/AminHP/gym-anytrading
cd gym-anytrading
pip install -e .

## 或者

pip install --upgrade --no-deps --force-reinstall https://github.com/AminHP/gym-anytrading/archive/master.zip

环境特性

首先,你不能简单地指望一个强化学习智能体在如此复杂的交易市场中为你完成所有操作,然后自己就坐享其成! 为了使智能体能够更快、更高效地学习,必须尽可能地简化问题。在所有交易算法中,首要任务就是定义 动作仓位。在接下来的两个小节中,我将详细解释这些动作和仓位,并说明如何对其进行简化。

交易动作

如果你在网上搜索交易算法,会发现它们通常使用多种动作,例如 买入卖出持有入场出场 等。

正如本节开头所述,典型的强化学习智能体只能解决该领域中的一部分问题。如果你从事交易工作,就会明白,决定是否持有、入场或出场(在外汇市场中针对货币对,在股票市场中针对个股)是一个依赖于诸多参数的统计决策,比如你的资金预算、交易的货币对或股票、你在多个市场的资金分配策略等。让强化学习智能体考虑所有这些因素是一项极其繁重的任务,可能需要数年时间才能开发出这样的智能体!在这种情况下,你很可能不会直接使用这个环境,而是会基于它扩展出自己的环境。

经过数月的研究,我最终得出结论:这些复杂多样的动作并不会带来实际的积极效果,反而会使学习过程变得更加冗长。事实上,像 持有 这样的动作几乎不会被训练有素的智能体采用,因为它会尽量避免错过任何潜在的收益。因此,没有必要设置如此多的动作,仅使用 Sell=0Buy=1 两种动作就足以有效地训练智能体。

交易仓位

如果你不熟悉交易仓位的概念,可以参考 这里。这是一个非常重要的概念,你应该尽快掌握。

简单来说:做多 仓位是指在价格较低时买入股票,并在其价格上涨时获利;而 做空 仓位则是指在价格较高时卖出股票,再用所得资金以更低的价格买入股票,从而赚取差价。

同样地,在一些交易算法中,可能会出现多种仓位,如 做空做多平仓 等。正如前面所讨论的,我只使用 Short=0Long=1 两种仓位。

交易环境

正如前面提到的,现在是介绍这三个环境的时候了。在创建这个项目之前,我花了大量时间寻找一个简单且灵活的 Gym 环境,适用于任何交易市场,但始终未能找到合适的方案。现有的许多环境要么代码过于复杂,要么包含大量难以理解的参数,让人难以快速了解其运作机制。因此,我决定专注于简洁性、灵活性和全面性来实现这个项目。

在接下来的三个小节中,我将逐一介绍我们的交易环境;而在下一节中,我们将展示并简要说明一些 IPython 示例。

TradingEnv

TradingEnv 是一个抽象类,继承自 gym.Env。该类旨在为各类交易市场提供一个通用环境。下面我将介绍其公开属性和方法。当然,你也可以直接查看完整的 源代码

  • 属性:

df:即 DataFrame 的缩写。这是一个 pandas 的 DataFrame,包含了你的数据集,并在类的构造函数中传入。

prices:随时间变化的真实价格,用于计算收益并渲染环境。

signal_features:随时间提取的特征,用于生成 Gym 观测值。

window_size:作为 Gym 观测值返回的当前及过去若干个时间步的数量,也在构造函数中传入。

action_space:Gym 的动作空间属性,包含离散值 0=卖出1=买入

observation_space:Gym 的观测空间属性,每个观测都是对 signal_features 中从索引 current_tick - window_size + 1current_tick 的窗口。因此,环境的 _start_tick 将等于 window_size。此外,初始值为 _last_trade_tickwindow_size - 1

shape:单个观测的形状。

history:存储所有步骤的信息。

  • 方法:

seed:标准的 Gym 种子方法。

reset:标准的 Gym 重置方法。

step:标准的 Gym 步进方法。

render:标准的 Gym 渲染方法,用于显示当前时间步的环境信息。

render_all:渲染整个环境。

close:标准的 Gym 关闭方法。

  • 抽象方法:

_process_data:在构造函数中调用,返回 pricessignal_features 的元组。不同的交易市场需要提取不同的特征,因此该方法使我们的 TradingEnv 成为一个通用环境,可以根据具体市场(如外汇、股票等)返回相应的特征。

_calculate_reward:强化学习智能体的奖励函数。

_update_profit:计算并更新智能体迄今为止获得的总收益。收益表示以 1.0 单位货币开始,最终获得的货币单位数量(利润 = 最终金额 / 初始金额)。

max_possible_profit:在不考虑交易费用的情况下,强化学习智能体可能获得的最大收益。

ForexEnv

这是一个具体的类,继承自 TradingEnv 并实现了其抽象方法。此外,它还具有一些专属于 FOREX 市场的属性。更多信息请参阅 源代码

  • 属性:

frame_bound: 一个元组,用于指定 df 的起始和结束位置。该参数在类的构造函数中传入。

unit_side: 指定您开始交易的一方。取值为字符串 left(默认值)和 right。如您所知,在 FOREX 市场中,货币对存在两个方向。例如,在 EUR/USD 货币对中,当您选择 left 方向时,您的计价货币是 EUR,您将以 1 欧元开始交易。该参数在类的构造函数中传入。

trade_fee: 一种默认的固定手续费,每次交易时都会从实际价格中扣除。

StocksEnv

与 ForexEnv 类似,但适用于 股票 市场。更多信息请参阅 源代码

  • 属性:

frame_bound: 一个元组,用于指定 df 的起始和结束位置。该参数在类的构造函数中传入。

trade_fee_bid_percent: 买单的默认固定手续费百分比。例如,当 trade_fee_bid_percent=0.01 时,每次卖出股票您将损失 1% 的资金。

trade_fee_ask_percent: 卖单的默认固定手续费百分比。例如,当 trade_fee_ask_percent=0.005 时,每次买入股票您将损失 0.5% 的资金。

此外,您还可以通过扩展 TradingEnv,甚至 ForexEnv 或 StocksEnv,创建自己的自定义环境,并根据需要制定奖励、利润、手续费等计算策略。

示例

创建环境

import gymnasium as gym
import gym_anytrading

env = gym.make('forex-v0')
# env = gym.make('stocks-v0')
  • 这将创建默认环境。您可以更改数据集、frame_bound 等任何参数。

使用自定义参数创建环境

我提供了两个默认数据集,分别用于 FOREX股票,但您也可以使用自己的数据集。

from gym_anytrading.datasets import FOREX_EURUSD_1H_ASK, STOCKS_GOOGL

custom_env = gym.make(
    'forex-v0',
    df=FOREX_EURUSD_1H_ASK,
    window_size=10,
    frame_bound=(10, 300),
    unit_side='right'
)

# custom_env = gym.make(
#     'stocks-v0',
#     df=STOCKS_GOOGL,
#     window_size=10,
#     frame_bound=(10, 300)
# )
  • 需要注意的是,frame_bound 的第一个元素应大于或等于 window_size

打印一些信息

print("env 信息:")
print("> shape:", env.unwrapped.shape)
print("> df.shape:", env.unwrapped.df.shape)
print("> prices.shape:", env.unwrapped.prices.shape)
print("> signal_features.shape:", env.unwrapped.signal_features.shape)
print("> 最大可能利润:", env.unwrapped.max_possible_profit())

print()
print("custom_env 信息:")
print("> shape:", custom_env.unwrapped.shape)
print("> df.shape:", custom_env.unwrapped.df.shape)
print("> prices.shape:", custom_env.unwrapped.prices.shape)
print("> signal_features.shape:", custom_env.unwrapped.signal_features.shape)
print("> 最大可能利润:", custom_env.unwrapped.max_possible_profit())
env 信息:
> shape: (24, 2)
> df.shape: (6225, 5)
> prices.shape: (6225,)
> signal_features.shape: (6225, 2)
> 最大可能利润: 4.054407219413578

custom_env 信息:
> shape: (10, 2)
> df.shape: (6225, 5)
> prices.shape: (300,)
> signal_features.shape: (300, 2)
> 最大可能利润: 1.1228998536878634
  • 此处的 max_possible_profit 表示,如果市场没有交易费用,以 1.0 作为初始资金,您最多可以获得 4.054414887146572(或 1.1229001800089833)单位的收益。换句话说,您的资金几乎翻了四倍。

绘制环境

env.reset()
env.render()

png

  • redgreen 颜色分别表示 空头多头 头寸。
  • 如您所见,环境的初始 头寸 始终是 空头

完整示例

import numpy as np
import matplotlib.pyplot as plt

import gymnasium as gym
import gym_anytrading
from gym_anytrading.envs import TradingEnv, ForexEnv, StocksEnv, Actions, Positions 
from gym_anytrading.datasets import FOREX_EURUSD_1H_ASK, STOCKS_GOOGL


env = gym.make('forex-v0', frame_bound=(50, 100), window_size=10)
# env = gym.make('stocks-v0', frame_bound=(50, 100), window_size=10)

observation = env.reset(seed=2023)
while True:
    action = env.action_space.sample()
    observation, reward, terminated, truncated, info = env.step(action)
    done = terminated or truncated

    # env.render()
    if done:
        print("info:", info)
        break

plt.cla()
env.unwrapped.render_all()
plt.show()
info: {'total_reward': 27.89616584777832, 'total_profit': 0.989812615901, 'position': <Positions.Long: 1>}

png

  • 您可以使用 render_all 方法避免每一步都进行渲染,从而节省时间。
  • 如您看到的,图表中的前 10 个点(window_size=10)并没有显示头寸。这是因为它们不参与奖励、利润等的计算,仅用于展示最初的观测数据。因此,环境的 _start_tick 和初始 _last_trade_tick 分别是 109

更多示例

这里提供了一些示例,展示了如何将 gym-anytrading 与其他知名库(如 Stable-Baselines3QuantStats)结合使用,并说明如何在其他强化学习或交易库中利用我们的交易环境。

扩展和操作 TradingEnv

如果您希望在环境之外处理数据并提取特征,可以通过两种简单的方法实现:

方法 1(推荐):

def my_process_data(env):
    start = env.frame_bound[0] - env.window_size
    end = env.frame_bound[1]
    prices = env.df.loc[:, 'Low'].to_numpy()[start:end]
    signal_features = env.df.loc[:, ['Close', 'Open', 'High', 'Low']].to_numpy()[start:end]
    return prices, signal_features


class MyForexEnv(ForexEnv):
    _process_data = my_process_data


env = MyForexEnv(df=FOREX_EURUSD_1H_ASK, window_size=12, frame_bound=(12, len(FOREX_EURUSD_1H_ASK)))

方法 2:

def my_process_data(df, window_size, frame_bound):
    start = frame_bound[0] - window_size
    end = frame_bound[1]
    prices = df.loc[:, 'Low'].to_numpy()[start:end]
    signal_features = df.loc[:, ['Close', 'Open', 'High', 'Low']].to_numpy()[start:end]
    return prices, signal_features


class MyStocksEnv(StocksEnv):
    
    def __init__(self, prices, signal_features, **kwargs):
        self._prices = prices
        self._signal_features = signal_features
        super().__init__(**kwargs)

    def _process_data(self):
        return self._prices, self._signal_features

    
prices, signal_features = my_process_data(df=STOCKS_GOOGL, window_size=30, frame_bound=(30, len(STOCKS_GOOGL)))
env = MyStocksEnv(prices, signal_features, df=STOCKS_GOOGL, window_size=30, frame_bound=(30, len(STOCKS_GOOGL)))

相关项目

  • DI-engine 项目中,开发了一个更为复杂的 anytrading 版本,包含五种动作、三种仓位以及更优的奖励函数。该工具属于中等难度级别(介于 anytradingmtsim 之间),适合中级用户使用。更多相关信息和文档请参见 这里

版本历史

v2.0.02023/08/27
v1.3.22022/09/11
v1.3.12022/06/25
v1.3.02022/05/21
v1.2.02020/07/31
v1.1.02020/05/26
v1.0.02019/09/22

常见问题

相似工具推荐

openclaw

OpenClaw 是一款专为个人打造的本地化 AI 助手,旨在让你在自己的设备上拥有完全可控的智能伙伴。它打破了传统 AI 助手局限于特定网页或应用的束缚,能够直接接入你日常使用的各类通讯渠道,包括微信、WhatsApp、Telegram、Discord、iMessage 等数十种平台。无论你在哪个聊天软件中发送消息,OpenClaw 都能即时响应,甚至支持在 macOS、iOS 和 Android 设备上进行语音交互,并提供实时的画布渲染功能供你操控。 这款工具主要解决了用户对数据隐私、响应速度以及“始终在线”体验的需求。通过将 AI 部署在本地,用户无需依赖云端服务即可享受快速、私密的智能辅助,真正实现了“你的数据,你做主”。其独特的技术亮点在于强大的网关架构,将控制平面与核心助手分离,确保跨平台通信的流畅性与扩展性。 OpenClaw 非常适合希望构建个性化工作流的技术爱好者、开发者,以及注重隐私保护且不愿被单一生态绑定的普通用户。只要具备基础的终端操作能力(支持 macOS、Linux 及 Windows WSL2),即可通过简单的命令行引导完成部署。如果你渴望拥有一个懂你

349.3k|★★★☆☆|5天前
Agent开发框架图像

stable-diffusion-webui

stable-diffusion-webui 是一个基于 Gradio 构建的网页版操作界面,旨在让用户能够轻松地在本地运行和使用强大的 Stable Diffusion 图像生成模型。它解决了原始模型依赖命令行、操作门槛高且功能分散的痛点,将复杂的 AI 绘图流程整合进一个直观易用的图形化平台。 无论是希望快速上手的普通创作者、需要精细控制画面细节的设计师,还是想要深入探索模型潜力的开发者与研究人员,都能从中获益。其核心亮点在于极高的功能丰富度:不仅支持文生图、图生图、局部重绘(Inpainting)和外绘(Outpainting)等基础模式,还独创了注意力机制调整、提示词矩阵、负向提示词以及“高清修复”等高级功能。此外,它内置了 GFPGAN 和 CodeFormer 等人脸修复工具,支持多种神经网络放大算法,并允许用户通过插件系统无限扩展能力。即使是显存有限的设备,stable-diffusion-webui 也提供了相应的优化选项,让高质量的 AI 艺术创作变得触手可及。

162.1k|★★★☆☆|5天前
开发框架图像Agent

everything-claude-code

everything-claude-code 是一套专为 AI 编程助手(如 Claude Code、Codex、Cursor 等)打造的高性能优化系统。它不仅仅是一组配置文件,而是一个经过长期实战打磨的完整框架,旨在解决 AI 代理在实际开发中面临的效率低下、记忆丢失、安全隐患及缺乏持续学习能力等核心痛点。 通过引入技能模块化、直觉增强、记忆持久化机制以及内置的安全扫描功能,everything-claude-code 能显著提升 AI 在复杂任务中的表现,帮助开发者构建更稳定、更智能的生产级 AI 代理。其独特的“研究优先”开发理念和针对 Token 消耗的优化策略,使得模型响应更快、成本更低,同时有效防御潜在的攻击向量。 这套工具特别适合软件开发者、AI 研究人员以及希望深度定制 AI 工作流的技术团队使用。无论您是在构建大型代码库,还是需要 AI 协助进行安全审计与自动化测试,everything-claude-code 都能提供强大的底层支持。作为一个曾荣获 Anthropic 黑客大奖的开源项目,它融合了多语言支持与丰富的实战钩子(hooks),让 AI 真正成长为懂上

150k|★★☆☆☆|今天
开发框架Agent语言模型

ComfyUI

ComfyUI 是一款功能强大且高度模块化的视觉 AI 引擎,专为设计和执行复杂的 Stable Diffusion 图像生成流程而打造。它摒弃了传统的代码编写模式,采用直观的节点式流程图界面,让用户通过连接不同的功能模块即可构建个性化的生成管线。 这一设计巧妙解决了高级 AI 绘图工作流配置复杂、灵活性不足的痛点。用户无需具备编程背景,也能自由组合模型、调整参数并实时预览效果,轻松实现从基础文生图到多步骤高清修复等各类复杂任务。ComfyUI 拥有极佳的兼容性,不仅支持 Windows、macOS 和 Linux 全平台,还广泛适配 NVIDIA、AMD、Intel 及苹果 Silicon 等多种硬件架构,并率先支持 SDXL、Flux、SD3 等前沿模型。 无论是希望深入探索算法潜力的研究人员和开发者,还是追求极致创作自由度的设计师与资深 AI 绘画爱好者,ComfyUI 都能提供强大的支持。其独特的模块化架构允许社区不断扩展新功能,使其成为当前最灵活、生态最丰富的开源扩散模型工具之一,帮助用户将创意高效转化为现实。

108.3k|★★☆☆☆|今天
开发框架图像Agent

gemini-cli

gemini-cli 是一款由谷歌推出的开源 AI 命令行工具,它将强大的 Gemini 大模型能力直接集成到用户的终端环境中。对于习惯在命令行工作的开发者而言,它提供了一条从输入提示词到获取模型响应的最短路径,无需切换窗口即可享受智能辅助。 这款工具主要解决了开发过程中频繁上下文切换的痛点,让用户能在熟悉的终端界面内直接完成代码理解、生成、调试以及自动化运维任务。无论是查询大型代码库、根据草图生成应用,还是执行复杂的 Git 操作,gemini-cli 都能通过自然语言指令高效处理。 它特别适合广大软件工程师、DevOps 人员及技术研究人员使用。其核心亮点包括支持高达 100 万 token 的超长上下文窗口,具备出色的逻辑推理能力;内置 Google 搜索、文件操作及 Shell 命令执行等实用工具;更独特的是,它支持 MCP(模型上下文协议),允许用户灵活扩展自定义集成,连接如图像生成等外部能力。此外,个人谷歌账号即可享受免费的额度支持,且项目基于 Apache 2.0 协议完全开源,是提升终端工作效率的理想助手。

100.8k|★★☆☆☆|昨天
插件Agent图像

markitdown

MarkItDown 是一款由微软 AutoGen 团队打造的轻量级 Python 工具,专为将各类文件高效转换为 Markdown 格式而设计。它支持 PDF、Word、Excel、PPT、图片(含 OCR)、音频(含语音转录)、HTML 乃至 YouTube 链接等多种格式的解析,能够精准提取文档中的标题、列表、表格和链接等关键结构信息。 在人工智能应用日益普及的今天,大语言模型(LLM)虽擅长处理文本,却难以直接读取复杂的二进制办公文档。MarkItDown 恰好解决了这一痛点,它将非结构化或半结构化的文件转化为模型“原生理解”且 Token 效率极高的 Markdown 格式,成为连接本地文件与 AI 分析 pipeline 的理想桥梁。此外,它还提供了 MCP(模型上下文协议)服务器,可无缝集成到 Claude Desktop 等 LLM 应用中。 这款工具特别适合开发者、数据科学家及 AI 研究人员使用,尤其是那些需要构建文档检索增强生成(RAG)系统、进行批量文本分析或希望让 AI 助手直接“阅读”本地文件的用户。虽然生成的内容也具备一定可读性,但其核心优势在于为机器

93.4k|★★☆☆☆|4天前
插件开发框架