: | : | :期货量化学习 | :期货量化 |
返回列表 发帖

[模板与范例参考] 跨品种套利(期货)Python策略源码模板【东方财富Python量化】

[模板与范例参考] 跨品种套利(期货)Python策略源码模板【东方财富Python量化】

  1. # coding=utf-8
  2. from __future__ import print_function, absolute_import, unicode_literals
  3. from gm.api import *
  4. import numpy as np

  5. '''
  6. 本策略首先滚动计算过去30个1min收盘价的均值,然后用均值加减2个标准差得到布林线.
  7. 若无仓位,在最新价差上穿上轨时做空价差;下穿下轨时做多价差
  8. 若有仓位则在最新价差回归至上下轨水平内时平仓
  9. 回测数据为:DCE.j1901和DCE.jm1901的1min数据
  10. 回测时间为:2018-02-01 08:00:00到2018-12-31 08:00:00
  11. '''

  12. def init(context):
  13.     # 选择的两个合约
  14.     context.symbol = ['DCE.j1901', 'DCE.jm1901']
  15.     # 订阅历史数据
  16.     subscribe(symbols=context.symbol, frequency='1d', count=11, wait_group=True)


  17. def on_bar(context, bars):
  18.     # 数据提取
  19.     j_close = context.data(symbol=context.symbol[0],frequency='1d',fields='close',count=31).values
  20.     jm_close = context.data(symbol=context.symbol[1],frequency='1d',fields='close',count=31).values

  21.     # 提取最新价差
  22.     new_price = j_close[-1] - jm_close[-1]

  23.     # 计算历史价差,上下限,止损点
  24.     spread_history = j_close[:-2] - jm_close[:-2]
  25.     context.spread_history_mean = np.mean(spread_history)
  26.     context.spread_history_std = np.std(spread_history)
  27.     context.up = context.spread_history_mean + 0.75 * context.spread_history_std
  28.     context.down = context.spread_history_mean - 0.75 * context.spread_history_std
  29.     context.up_stoppoint = context.spread_history_mean + 2 * context.spread_history_std
  30.     context.down_stoppoint = context.spread_history_mean - 2 * context.spread_history_std

  31.     # 查持仓
  32.     position_jm_long = context.account().position(symbol=context.symbol[0], side=1)
  33.     position_jm_short = context.account().position(symbol=context.symbol[0], side=2)

  34.     # 设计买卖信号
  35.     # 设计开仓信号
  36.     if not position_jm_short and not position_jm_long:
  37.         if new_price > context.up:
  38.             print('做空价差组合')
  39.             order_volume(symbol=context.symbol[0],side=OrderSide_Sell,volume=1,order_type=OrderType_Market, position_effect=1)
  40.             order_volume(symbol=context.symbol[1], side=OrderSide_Buy, volume=1, order_type=OrderType_Market, position_effect=PositionEffect_Open)

  41.         if new_price < context.down:
  42.             print('做多价差组合')
  43.             order_volume(symbol=context.symbol[0], side=OrderSide_Buy, volume=1, order_type=OrderType_Market, position_effect=PositionEffect_Open)
  44.             order_volume(symbol=context.symbol[1], side=OrderSide_Sell, volume=1, order_type=OrderType_Market, position_effect=PositionEffect_Open)

  45.     # 设计平仓信号
  46.     # 持jm多仓时
  47.     if position_jm_long:
  48.         if new_price >= context.spread_history_mean:
  49.             # 价差回归到均值水平时,平仓
  50.             print('价差回归到均衡水平,平仓')
  51.             order_volume(symbol=context.symbol[0], side=OrderSide_Sell, volume=1, order_type=OrderType_Market, position_effect=PositionEffect_Close)
  52.             order_volume(symbol=context.symbol[1], side=OrderSide_Buy, volume=1, order_type=OrderType_Market, position_effect=PositionEffect_Close)

  53.         if new_price < context.down_stoppoint:
  54.             # 价差达到止损位,平仓止损
  55.             print('价差超过止损点,平仓止损')
  56.             order_volume(symbol=context.symbol[0], side=OrderSide_Sell, volume=1, order_type=OrderType_Market, position_effect=PositionEffect_Close)
  57.             order_volume(symbol=context.symbol[1], side=OrderSide_Buy, volume=1, order_type=OrderType_Market, position_effect=PositionEffect_Close)

  58.     # 持jm空仓时
  59.     if position_jm_short:
  60.         if new_price <= context.spread_history_mean:
  61.             # 价差回归到均值水平时,平仓
  62.             print('价差回归到均衡水平,平仓')
  63.             order_volume(symbol=context.symbol[0], side=OrderSide_Buy, volume=1, order_type=OrderType_Market, position_effect=PositionEffect_Close)
  64.             order_volume(symbol=context.symbol[1], side=OrderSide_Sell, volume=1, order_type=OrderType_Market, position_effect=PositionEffect_Close)

  65.         if new_price > context.up_stoppoint:
  66.             # 价差达到止损位,平仓止损
  67.             print('价差超过止损点,平仓止损')
  68.             order_volume(symbol=context.symbol[0], side=OrderSide_Buy, volume=1, order_type=OrderType_Market, position_effect=PositionEffect_Close)
  69.             order_volume(symbol=context.symbol[1], side=OrderSide_Sell, volume=1, order_type=OrderType_Market, position_effect=PositionEffect_Close)

  70. if __name__ == '__main__':
  71.     '''
  72.     strategy_id策略ID,由系统生成
  73.     filename文件名,请与本文件名保持一致
  74.     mode实时模式:MODE_LIVE回测模式:MODE_BACKTEST
  75.     token绑定计算机的ID,可在系统设置-密钥管理中生成
  76.     backtest_start_time回测开始时间
  77.     backtest_end_time回测结束时间
  78.     backtest_adjust股票复权方式不复权:ADJUST_NONE前复权:ADJUST_PREV后复权:ADJUST_POST
  79.     backtest_initial_cash回测初始资金
  80.     backtest_commission_ratio回测佣金比例
  81.     backtest_slippage_ratio回测滑点比例
  82.     '''
  83.     run(strategy_id='strategy_id',
  84.         filename='main.py',
  85.         mode=MODE_BACKTEST,
  86.         token='{{token}}',
  87.         backtest_start_time='2018-02-01 08:00:00',
  88.         backtest_end_time='2018-12-31 16:00:00',
  89.         backtest_adjust=ADJUST_PREV,
  90.         backtest_initial_cash=2000000,
  91.         backtest_commission_ratio=0.0001,
  92.         backtest_slippage_ratio=0.0001)
复制代码

论坛官方微信、群(期货热点、量化探讨、开户与绑定实盘)
 
期货论坛 - 版权/免责声明   1.本站发布源码(包括函数、指标、策略等)均属开放源码,用意在于让使用者学习程序化语法撰写,使用者可以任意修改语法內容并调整参数。仅限用于个人学习使用,请勿转载、滥用,严禁私自连接实盘账户交易
  2.本站发布资讯(包括文章、视频、历史记录、教材、评论、资讯、交易方案等)均系转载自网络主流媒体,内容仅为作者当日个人观点,本网转载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。本网不对该类信息或数据做任何保证。不对您构成任何投资建议,不能依靠信息而取代自身独立判断,不对因使用本篇文章所诉信息或观点等导致的损失承担任何责任。
  3.本站发布资源(包括书籍、杂志、文档、软件等)均从互联网搜索而来,仅供个人免费交流学习,不可用作商业用途,本站不对显示的内容承担任何责任。请在下载后24小时内删除。如果喜欢,请购买正版,谢谢合作!
  4.龙听期货论坛原创文章属本网版权作品,转载须注明来源“龙听期货论坛”,违者本网将保留追究其相关法律责任的权力。本论坛除发布原创文章外,亦致力于优秀财经文章的交流分享,部分文章推送时若未能及时与原作者取得联系并涉及版权问题时,请及时联系删除。联系方式:http://www.qhlt.cn/thread-262-1-1.html
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

返回列表