- Fix Issue 87
- Fix Issue 89
- Fix 无法通过
env.config.mod
获取全部 mod 的配置信息 - 增加
context.config
来获取配置信息 - 提供
from rqalpha import export_as_api
接口,方便扩展自定义 API
- Fix Issue 81
- 解决 mod_config.yml 文件解析出错以后,所有的命令报错的问题
- 默认在 Python 2.x 下 sys.setdefaultencoding("utf-8")
- 优化 UNIVERSE_CHANGED 事件,现在只有在universe真正变化时才触发
- Fix Issue 78
- is_st_stock | is_suspended 支持 count 参数
- 解决大量 Python 2.x 下中文乱码问题
- 解决在 Python 2.x 下安装 RQAlpha 提示 requirements-py2.txt Not Found 的问题
- 解决 Benchmark 无法显示的问题
- 解决 rqalpha mod list 显示不正确的问题
- 现在可以通过配置 base.extra_vars 向策略中预定义变量了。用法如下:
from rqalpha import run
config = {
"base": {
"strategy_file": "strategy.py",
"start_date": "2016-06-01",
"end_date": "2016-07-01",
"stock_starting_cash":100000,
"benchmark": '000300.XSHG'
},
"extra":{
"context_vars":{
"short":5,
"middle":10,
"long":21
}
}
}
result_dict = run(config)
# 以下是策略代码:
def handle_bar(context):
print(context.short) # 5
print(context.middle) # 10
print(context.long) # 21
- 修改配置的读取方式,不再从 ~/.rqalpha/config.yml 读取自定义配置信息,而是默认从当前路径读取 config.yml,如果没找到,则会读取系统默认配置信息
- 现在不再对自定义信息进行版本检查
rqalpha generate_config
现在会生成包含所有默认系统配置信息的 config.yml 文件。RUN_TYPE
增加LIVE_TRADING
- 修复
history_bars
获取日期错误产生的问题 - 修复执行
context.run_info
会报错的问题 - 修复持久化报错的问题
- 增加 Order Persist 相关内容
2.0.0 详细修改内容请访问:RQAlpha 2.0.0
Portfolio/Account/Position 相关
- 重新定义了
Portfolio
,Account
和Position
的角色和关系 - 删除大部分累计计算的属性,重新实现股票和期货的计算逻辑
- 现在只有在
Portfolio
层级进行净值/份额的计算,Account级别不再进行净值/份额/收益/相关的计算 - 账户的恢复和初始化现在只需要
total_cash
,positions
和backward_trade_set
即可完成 - 精简
Position
的初始化,可以从real_broker
直接进行恢复 Account
提供fast_forward
函数,账户现在可以从任意时刻通过orders
和trades
快速前进至最新状态- 如果存在 Benchmark, 则创建一个
benchmark_portfolio
, 其包含一个benchmark_account
- 策略在调用
context.portfolio.positions[some_security]
时候,如果 position 不存在,不再每次都创建临时仓位,而是会缓存,从而提高回测速度和性能 - 不再使用
clone
方法 - 不再使用
PortfolioProxy
和PositionProxy
Event 相关
- 规范 Event 的生成和相应逻辑, 使用 Event object 来替换原来的 Enum
- 抽离事件执行相关逻辑为
Executor
模块
Mod 相关
- 规范化 Mod 命名规则,需要以 rqalpha_mod_xxx 作为 Mod 依赖库命名
- 抽离
slippage
相关业务逻辑至simulation mod
- 抽离
commission
相关业务逻辑至simulation mod
- 抽离
tax
相关业务逻辑至simulation mod
- rqalpha mod list 命令现在可以格式化显示 Mod 当前的状态了
Environment 和 ExecutionContext 相关
- 现在
ExecutionContext
只负责上下文相关的内容,不再可以通过ExecutionContext
访问其他成员变量。 - 扩展了
Environment
的功能,RQAlpha 及 Mod 均可以直接通过Environment.get_instance()
来获取到环境中核心模块的引用 Environment
还提供了很多常用的方法,具体请直接参考代码
配置及参数相关
- 重构了配置相关的内容,~/.rqalpha/config.yml 现在类似于 Sublime/Atom 的用户配置文件,用于覆盖默认配置信息,因此只需要增加自定义配置项即可,不需要全部的配置内容都存在
- 将Mod自己的默认配置从配置文件中删除,放在Mod中自行管理和维护
- 独立存在 ~/.rqalpha/.mod_conifg.yml, 提供 rqalpha mod install/uninstall/enable/disable/list 命令,RQAlpha 会通过该配置文件来对Mod进行管理。
- 抽离
rqalpha run
的参数,将其中属于 Mod 的参数全部删除,取代之为Mod提供了参数注入机制,所以现在 Mod 可以自行决定是否要注入参数或者命令来扩展 RQAlpha 的功能 - 提供了
rqalpha-cmd
命令,Mod 推荐在该命令下注入自己的命令来实现功能扩展 - 不再使用 --strategy-type, 改为使用 --security 选项
- --output-file | --report | --plot | --plot-save`参数 转移至 `sys_analyser Mod 中
- plot | report 命令,转移至 sys_analyser Mod 中
- --signal | --slippage | --commission-multiplier | --matching-type | --rid 转移至 sys_simulation Mod 中
Risk 计算
- 修复 tracking error 计算错误
- 修改 sharpe , sortino , information ratio , alpha 计算逻辑。参考 晨星 的方法, 先计算单日级别指标, 再进行年化。与原本直接基于年化值计算相比, 在分析时间较短的情况下, 新的指标计算结果会系统性低于原指标结果。
- 引入单日无风险利率作为中间变量计算上述指标。单日无风险利率为通过 中国债券信息网 获取得到对应期限的年化国债到期收益率除以244得到
- 修改指标说明若干
其他
- 修改了
Order
和Trade
的字段和函数,使其更通用 - 为
RqAttrDict
类增加update
方法,现在支持动态更新了 arg_checker
增加is_greater_or_equal_than
和is_less_or_equal_than
函数- 删除
DEFAULT_FUTURE_INFO
变量,现在可以直接通过data_proxy
获取相关数据 - 通过 better_exceptions 提供更好的错误堆栈提示体验
- 对字符串的处理进行了优化,现在可以正确在 Python2.x/3.x 下显示中文了
- 修复
update_bundle
直接在代码中调用会报错的问题 - 增加对于下单量为0的订单过滤,不再会创建订单,也不再会输出警报日志
- 增加
is_suspended
和is_st_stock
API 的支持
- Hotfix
UnboundLocalError: local variable 'signature' referenced before assignment
- 增加股票裸做空的配置参数
--short-stock
POSITION_EFFECT
增加CLOSE_TODAY
ExecutionContext
增加get_current_close_price
get_future_commission_info
get_future_margin
get_future_info
函数- 增加
RQInvalidArgument
来处理用户策略代码异常的问题 - 现在可以正确提示期货主力连续合约和指数连续合约在回测和模拟中的报错信息了
- 现在以
handle_tick(context, tick)
的方式支持tick级别的API支持(未来可能会修改) - 现在回测时的
before_trading
函数输出的时间提前到开盘前半小时
- 优化 setup.py 脚本,只有在 python 2 环境下才安装兼容性依赖库
- 增加
rqalpha install/uninstall/list/enable/disable
命令 - 增加
EVENT.POST_SYSTEM_RESTORED
事件 - 增加 净值和份额的支持,现在的收益和Analyser的计算都是基于净值了。
- 在 AnalyserMod 输出的 Trade 中增加
side
和position_effect
- 修复
total_orders
计算错误 - 修复
inpsect.signature
在 python 2.x 报错的问题。
- 更新本地化翻译,修改系统提示,支持多语言
- 增加
--locale
默认为cn
(中文), 支持cn | en
(中文 | 英文) - 修复
main.run
返回值中stock_position
为None
的问题 - 修复 Windows Python 2.7 下中文显示乱码的问题
- 增加
config.yml
的版本号检查及相关流程 - 增加
plot
关于中文字体的校验,如果系统没有中文字体,则显示英文字段 - 修正
Benchmark
在不设置时某些情况下会导致运行失败的错误 - 修正
inspect.unwrap
在 Python 2.7 下不支持的兼容性问题 - 修正
numpy
在某些平台下没有 float128 引起的报错问题
- 增加
--disable-user-system-log
参数,可以独立关闭回测过程中因策略而产生的系统日志 --log-level
现在可以正确区分不同类型的日志,同时增加none
类型,用来关闭全部日志信息。- 在不指定配置文件的情况下,默认会调用
~/.rqalpha/config.yml
文件 - 支持
rqalpha generate_config
命令来获取默认配置文件 - 指定策略类型不再使用
--kind
参数,替换为--strategy-type
和配置文件呼应 - 重构
events.py
,现在可以更好的支持基于事件的模块编写了 - 将风险指标计算独立成
analyser
Mod - 将事前风控相关内容独立成
risk_manager
Mod - 将 回测 和 实盘模拟 相关功能独立成
simulation
Mod
- 增加几个 technical analysis 的 examples 和自动化测试
- 修复一些在 Python 2 下运行的 bug
- 增加
-mc
/--mod-config
参数来传递参数到 mod 中 - 增加了 simple_stock_realtime_trade, progressive_output_csv,funcat_api 几个 DEMO mod 供开发者参考开发自己的 mod
update_bundle
移到main.py
中,方便直接从代码中调用update_bundle
- 增加了一些自动化的测试用例
- support auto test with Travis [python 2.7 3.4 3.5 3.6]
rqalpha.run
现在支持直接传入source_code
了- 支持
rqalpha.update_bundle
函数
- 增加
from rqalpha import run
接口,现在可以很方便的直接在程序中调用RQAlpha 回测了。
- 本地化模块更具有扩展性
- 修改
rqalpha update_bundle
的目录结构,现在是在指定目录下生成一个 bundle 文件,而不再会直接删除当前文件夹内容了。
- 解决
rqalpha examples -d .
无样例策略生成的问题
- 解决 Windows 10 下 matplotlib 中文字体显示乱码的问题
- 解决 Windows 下 set_locale error 的问题
- 增加 Python 2 的支持
- 支持多周期回测扩展(虽然只有日线数据,但是结构上是支持不同周期的回测和实盘的)
- 支持期货策略
- 支持混合策略(股票和期货混合)
- 支持多种参数配置方式
- 抽离接口层,数据源、事件源、撮合引擎、下单模块全部可以替换或扩展。
- 完善事件定义,采取 pub/sub 模式,可以非常简答的在 RQAlpha 中添加 hook。
- 增加 Mod 机制,极大的增加了 RQAlpha 的扩展性,使其可以轻松完成程序化交易过程中所产生的的特定需求。
- 完善了回测结果显示
- 修正了 Risk 计算和 Benchmark 计算
- 增加会回测进度显示开关
- 完善了回测结果显示
- 在
handle_bar
前用当前的数据更新 portfolio 和 position,因为 ricequant.com 是这样做的。
- 修复了分红计算
- 用户可以通过 context 设置 slippage/commission/benchmark
- 增加了 scheduler
- 修复 history 在 before_trading 调用
- 增加 api 的 phase 检查
- 修改支持 python2
- 修正了 Risk 计算,使用合理的年化收益计算方法
- 格式化代码符合 pep8
- 更新 requirements.txt
- 增加了数据下载
- 修正了 Risk 计算
- 增加了 instrument
- 增加了 position 的
market_value
和value_percent
- 增加了日线回测
- 去掉了涨跌停检查
- 增加了分红处理
- 运行参数如下:
# 生成sample策略
rqalpha generate_examples -d ./
# 运行回测
rqalpha run -f examples/simple_macd.py -s 2013-01-01 -e 2015-01-04 -o /tmp/a.pkl
- 搭建基本的框架,增加基本的 unittest