PaperAccount - 本地模拟交易模块
功能简介
PaperAccount是用于本地模拟交易的功能模块,用户可以通过其UI界面基于实盘行情进行本地化的仿真模拟交易。
加载启动
VN Station加载
启动登录VN Station后,点击【VN Trader Pro】按钮,在配置对话框中的【上层应用】栏勾选【PaperAccount】。
脚本加载
在启动脚本中添加如下代码:
# 写在顶部
from vnpy.app.paper_account import PaperAccountApp
# 写在创建main_engine对象后
main_engine.add_app(PaperAccountApp)
启动模块
打开VN Trader后,本地模拟交易模块会自动启动,并接管主引擎层所有合约的交易委托和撤单请求,不会再通过底层交易接口发往外部服务器。
用户可以通过【查询合约】来查询确认合约的交易接口状态,点击菜单栏的【帮助】->【合约查询】,或者点击左侧按钮栏的图标:
在弹出的对话框中直接点击右上角的【查询】按钮,可以看到所有合约的【交易接口】列均显示为PAPER(已由本地模拟交易模块接管),如下图所示:
业务支持
当前版本的本地模拟交易模块的支持的业务功能如下:
支持的委托类型(不支持的类型会被拒单):
限价单;
市价单;
停止单;
委托撮合规则采用到价成交模式,以买入委托为例:
限价单:当盘口卖1价ask_price_1小于等于委托价格,则成交;
停止单:当盘口卖1价ask_price_1大于等于委托价格,则成交;
委托成交时不考虑盘口挂单量,一次性全部成交;
委托成交后,先推送委托状态更新OrderData,再推送成交信息TradeData,和实盘交易中的顺序一致;
委托成交后,模块会自动记录相应的持仓信息PositionData:
根据合约本身的持仓模式(多空仓 vs 净仓位)信息,维护对应的持仓信息;
开仓成交时,采用加权平均计算更新持仓成本价;
平仓成交时,持仓成本价不变;
多空仓模式下,挂出平仓委托后会冻结相应的持仓数量,可用数量不足时会拒单;
持仓的盈亏会基于持仓成本价和最新成交价定时计算(默认频率1秒);
数据的持久化保存:
成交数据和委托数据不保存,关闭VN Trader后即消失;
持仓数据会在有变化时立即写入硬盘文件,重启VN Trader登录交易接口后即可看到(要收到相应的合约信息)。
订阅行情
在对某一合约进行下单和撤单操作前,用户必须先订阅该合约的行情(订阅方法详见基本使用篇的订阅行情部分)。
订阅成功后,委托、成交、持仓三个监控组件中显示的信息,其接口列均为PAPER(本地模拟数据),如下图所示:
功能配置
在菜单栏中点击【功能】-> 【模拟交易】,或者点击左侧按钮栏的图标:
即可进入本地模拟交易模块的UI界面,如下图所示:
用户可以通过UI界面对以下功能进行配置:
市价委托和停止委托的成交滑点
- 用于影响市价单和停止单成交时,成交价格相对于盘口价格的滑点跳数;
模拟交易持仓盈亏的计算频率
- 多少秒执行一次持仓盈亏计算更新,如果持仓较多时发现程序卡顿,建议尝试调低频率;
下单后立即使用当前盘口撮合
- 默认情况下,用户发出的委托需要等到下一个TICK盘口推送才会撮合(模拟实盘情景),对于TICK推送频率较低的不活跃合约可以勾选该选项,委托后会立即基于当前的最新TICK盘口撮合;
清空所有持仓
- 一键清空本地所有持仓数据。
本地模拟交易模块同样可以和其他策略应用模块(如CtaStrategy模块、SpreadTrading模块等)一起使用,从而实现完全本地化的量化策略仿真交易测试。