/rqalpha-mod-ctp

RQAlpha 对接 ctp 的扩展 Mod。通过启用该 Mod 来实现期货策略的实盘交易

Primary LanguagePythonApache License 2.0Apache-2.0

RQAlpha-mod-ctp

RQAlpha 对接 CTP 的扩展 Mod。通过启用该 Mod 来实现期货策略的实盘交易。目前本模块仍处在正式发布前的测试阶段,您可以下载参与测试并开 Issue 提交 bug,也欢迎您提交代码,参与开发。

该 Mod 底层引用了 PyCTP, 一些函数的封装和写法参考了 VN.PY

量化社区

Ricequant 旨在为量化爱好者提供可靠、易用的工具。与此同时我们也搭建了一个量化社区供大家探讨与交流回测框架、策略。欢迎大家前来分享自己对于量化交易的理解。

环境要求

该 Mod 支持 python 2.7, 3.4, 3.5,暂时仅支持 Linux,后续会加入 windows 支持。

安装

rqalpha mod install ctp

或者将源代码克隆,并在安装目录执行

rqalpha mod install -e .

配置项

您需要在配置项中填入您的 CTP 账号密码等信息,您可以在 simnow 官网 申请实盘模拟账号。 配置项的使用与 RQAlpha 其他 mod 无异

{   
    # CTP 登录信息
    "login": {
        'user_id': None,
        'password': None,
        'broker_id': "9999",
    },
    # 事件相关设置
    "event": {
        # 是否使用默认的 CTP 实时数据源
        "enabled": True,
        # 是否在非交易时间段内触发行情事件
        "all_day": False,
        "address": "tcp://180.168.212.228:41213",
    },
    # 交易相关设置
    "trade": {
        # 是否使用默认的 CTP 交易接口
        "enabled": True,
        "address": "tcp://180.168.146.187:10000",
    },
}

FAQ

FAQ

  • 为什么策略在初始化期间停滞了几十秒甚至数分钟?

程序在启动前,需要从 CTP 获取 Instrument 和 Commission 等数据,由于 CTP 控流等原因,向 CTP 发送大量请求会占用很长时间。您可以将 log_level 设置成 verbose 来查看详细的回调函数执行情况。未来可能会考虑开放设置是否全量更新 commission 信息以换取更快的启动速度。

  • 为什么我在RQAlpha中查询到的账户、持仓信息与我通过快期等终端查询到的不一致?

本 mod 会尽力将您的账户信息恢复至 RQAlpha 中,但由于计算逻辑的不同,可能会导致各个终端显示的数字有差异,另外您通过其他终端下单交易也有可能导致数据同步的不及时。不过这也有可能是程序bug,如果您发现不一致情况严重,欢迎通过Issue的方式向作者提出。

  • 我想要仅仅使用 CTP 的交易/实时行情接口,并配合其他 mod 使用 RQAlpha。

您可以在配置项中将 event 和 trade 部分的 enabled 项设置为 False 来禁用这一部分。

History

  • 0.1.3

    • 对接了 pyctp,实现了 python2 和 python3 下的 RQAlpha 期货实盘。
  • 0.1.4

    • 更改了配置项的格式。
    • 拆分了事件和交易部分,用户可以通过配置项将其中一部分禁用。