• QQ空间
  • 回复
  • 收藏

【宽客策略源码】跨品种套利(期货)

geek168 数据策略 2019-8-11 15:54 100435人围观


本策略根据计算滚动的.过去的30个1min的bar的均值正负2个标准差得到布林线,并在最新价差上穿上轨来做空价差,下穿下轨来做多价差,并在回归至上下轨水平内的时候平仓

回测数据为:SHFE.rb1801和SHFE.hc1801的1min数据
回测时间为:2017-09-01 08:00:00到2017-10-01 16:00:00


  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. def init(context):
  6.     # 进行套利的品种
  7.     context.goods = ['SHFE.rb1801', 'SHFE.hc1801']
  8.     # 订阅行情
  9.     subscribe(symbols=context.goods, frequency='60s', count=31, wait_group=True)
  10. def on_bar(context, bars):
  11.     # 获取两个品种的时间序列
  12.     data_rb = context.data(symbol=context.goods[0], frequency='60s', count=31, fields='close')
  13.     close_rb = data_rb.values
  14.     data_hc = context.data(symbol=context.goods[1], frequency='60s', count=31, fields='close')
  15.     close_hc = data_hc.values
  16.     # 计算价差
  17.     spread = close_rb[:-1] - close_hc[:-1]
  18.     # 计算布林带的上下轨
  19.     up = np.mean(spread) + 2 * np.std(spread)
  20.     down = np.mean(spread) - 2 * np.std(spread)
  21.     # 计算最新价差
  22.     spread_now = close_rb[-1] - close_hc[-1]
  23.     # 无交易时若价差上(下)穿布林带上(下)轨则做空(多)价差
  24.     position_rb_long = context.account().position(symbol=context.goods[0], side=PositionSide_Long)
  25.     position_rb_short = context.account().position(symbol=context.goods[0], side=PositionSide_Short)
  26.     if not position_rb_long and not position_rb_short:
  27.         if spread_now > up:
  28.             order_target_volume(symbol=context.goods[0], volume=1, order_type=OrderType_Market,
  29.                                 position_side=PositionSide_Short)
  30.             print(context.goods[0], '以市价单开空仓一手')
  31.             order_target_volume(symbol=context.goods[1], volume=1, order_type=OrderType_Market,
  32.                                 position_side=PositionSide_Long)
  33.             print(context.goods[1], '以市价单开多仓一手')
  34.         if spread_now < down:
  35.             order_target_volume(symbol=context.goods[0], volume=1, order_type=OrderType_Market,
  36.                                 position_side=PositionSide_Long)
  37.             print(context.goods[0], '以市价单开多仓一手')
  38.             order_target_volume(symbol=context.goods[1], volume=1, order_type=OrderType_Market,
  39.                                 position_side=PositionSide_Short)
  40.             print(context.goods[1], '以市价单开空仓一手')
  41.     # 价差回归时平仓
  42.     elif position_rb_short:
  43.         if spread_now <= up:
  44.             order_close_all()
  45.             print('价格回归,平所有仓位')
  46.             # 跌破下轨反向开仓
  47.         if spread_now < down:
  48.             order_target_volume(symbol=context.goods[0], volume=1, order_type=OrderType_Market,
  49.                                 position_side=PositionSide_Long)
  50.             print(context.goods[0], '以市价单开多仓一手')
  51.             order_target_volume(symbol=context.goods[1], volume=1, order_type=OrderType_Market,
  52.                                 position_side=PositionSide_Short)
  53.             print(context.goods[1], '以市价单开空仓一手')
  54.     elif position_rb_long:
  55.         if spread_now >= down:
  56.             order_close_all()
  57.             print('价格回归,平所有仓位')
  58.             # 涨破上轨反向开仓
  59.         if spread_now > up:
  60.             order_target_volume(symbol=context.goods[0], volume=1, order_type=OrderType_Market,
  61.                                 position_side=PositionSide_Short)
  62.             print(context.goods[0], '以市价单开空仓一手')
  63.             order_target_volume(symbol=context.goods[1], volume=1, order_type=OrderType_Market,
  64.                                 position_side=PositionSide_Long)
  65.             print(context.goods[1], '以市价单开多仓一手')
  66. if __name__ == '__main__':
  67.     '''
  68.     strategy_id策略ID,由系统生成
  69.     filename文件名,请与本文件名保持一致
  70.     mode实时模式:MODE_LIVE回测模式:MODE_BACKTEST
  71.     token绑定计算机的ID,可在系统设置-密钥管理中生成
  72.     backtest_start_time回测开始时间
  73.     backtest_end_time回测结束时间
  74.     backtest_adjust股票复权方式不复权:ADJUST_NONE前复权:ADJUST_PREV后复权:ADJUST_POST
  75.     backtest_initial_cash回测初始资金
  76.     backtest_commission_ratio回测佣金比例
  77.     backtest_slippage_ratio回测滑点比例
  78.     '''
  79.     run(strategy_id='strategy_id',
  80.         filename='main.py',
  81.         mode=MODE_BACKTEST,
  82.         token='token_id',
  83.         backtest_start_time='2017-09-01 08:00:00',
  84.         backtest_end_time='2017-10-01 16:00:00',
  85.         backtest_adjust=ADJUST_PREV,
  86.         backtest_initial_cash=500000,
  87.         backtest_commission_ratio=0.0001,
  88.         backtest_slippage_ratio=0.0001)
复制代码
跨品种套利.png




路过

雷人

握手

鲜花

鸡蛋
原作者: abctrader
关注微信