高频量化合约对冲交易机器人开发部署代码详情

简介: 高频量化合约对冲交易机器人开发部署代码详情,线上运营案例

量化合约指的是目标或任务具体明确,可以清晰度量。根据不同情况,表现为数量多少,具体的统计数字,范围衡量,时间长度等等。所谓量化就是把经过抽样得到的瞬时值将其幅度离散,即用一组规定的电平,把瞬时抽样值用最接近的电平值来表示。经过抽样的图像,只是在空间上被离散成为像素(样本)的阵列。而每个样本灰度值还是一个由无穷多个取值的连续变化量,必须将其转化为有限个离散值,赋予不同码字才能真正成为数字图像。这种转化称为量化。
量化合约策略部署代码参考如下:

coding=utf-8

from future import print_function, absolute_import, unicode_literals
import numpy as np
import pandas as pd
from gm.api import *
'''
本策略标的为:SHFE.rb1901
价格中枢设定为:前一交易日的收盘价
从阻力位到压力位分别为:1.03 open、1.02 open、1.01 open、open、0.99 open、0.98 open、0.97 open
每变动一个网格,交易量变化100个单位
回测数据为:SHFE.rb1901的1min数据
回测时间为:2017-07-01 08:00:00到2017-10-01 16:00:00
'''
def init(context):

# 策略标的为SHFE.rb1901
context.symbol = 'SHFE.rb1901'
# 订阅SHFE.rb1901, bar频率为1min
subscribe(symbols = context.symbol, frequency='60s')
# 设置每变动一格,增减的数量
context.volume = 1
# 储存前一个网格所处区间,用来和最新网格所处区间作比较
context.last_grid = 0
# 以前一日的收盘价为中枢价格
context.center = history_n(symbol= context.symbol,frequency='1d',end_time=context.now,count = 1,fields = 'close')[0]['close']
# 记录上一次交易时网格范围的变化情况(例如从4区到5区,记为4,5)
context.grid_change_last = [0,0]

def on_bar(context, bars):

bar = bars[0]
# 获取多仓仓位
position_long = context.account().position(symbol=context.symbol, side=PositionSide_Long)
# 获取空仓仓位
position_short = context.account().position(symbol=context.symbol, side=PositionSide_Short)
# 设置网格和当前价格所处的网格区域
context.band = np.array([0.97, 0.98, 0.99, 1, 1.01, 1.02, 1.03]) * context.center
grid = pd.cut([bar.close], context.band, labels=[1, 2, 3, 4, 5, 6])[0]
# 如果价格超出网格设置范围,则提示调节网格宽度和数量
if np.isnan(grid):
    print('价格波动超过网格范围,可适当调节网格宽度和数量')
# 如果新的价格所处网格区间和前一个价格所处的网格区间不同,说明触碰到了网格线,需要进行交易
# 如果新网格大于前一天的网格,做空或平多
if context.last_grid < grid:
    # 记录新旧格子范围(按照大小排序)
    grid_change_new = [context.last_grid,grid]
    # 几种例外:
    # 当last_grid = 0 时是初始阶段,不构成信号
    # 如果此时grid = 3,说明当前价格仅在开盘价之下的3区域中,没有突破网格线
    # 如果此时grid = 4,说明当前价格仅在开盘价之上的4区域中,没有突破网格线
    if context.last_grid == 0:
        context.last_grid = grid
        return
    if context.last_grid != 0:
        # 如果前一次开仓是4-5,这一次是5-4,算是没有突破,不成交
        if grid_change_new != context.grid_change_last:
            # 更新前一次的数据
            context.last_grid = grid
            context.grid_change_last = grid_change_new
            # 如果有多仓,平多
            if position_long:
                order_volume(symbol=context.symbol, volume=context.volume, side=OrderSide_Sell, order_type=OrderType_Market,
                             position_effect=PositionEffect_Close)
                print('以市价单平多仓{}手'.format(context.volume))
            # 否则,做空
            if not position_long:
                order_volume(symbol=context.symbol, volume=context.volume, side=OrderSide_Sell, order_type=OrderType_Market,
                             position_effect=PositionEffect_Open)
                print('以市价单开空{}手'.format(context.volume))
# 如果新网格小于前一天的网格,做多或平空
if context.last_grid > grid:
    # 记录新旧格子范围(按照大小排序)
    grid_change_new = [grid,context.last_grid]
    # 几种例外:
    # 当last_grid = 0 时是初始阶段,不构成信号
    # 如果此时grid = 3,说明当前价格仅在开盘价之下的3区域中,没有突破网格线
    # 如果此时grid = 4,说明当前价格仅在开盘价之上的4区域中,没有突破网格线
    if context.last_grid == 0:
        context.last_grid = grid
        return
    if context.last_grid != 0:
        # 如果前一次开仓是4-5,这一次是5-4,算是没有突破,不成交
        if grid_change_new != context.grid_change_last:
            # 更新前一次的数据
            context.last_grid = grid
            context.grid_change_last = grid_change_new
            # 如果有空仓,平空
            if position_short:
                order_volume(symbol=context.symbol, volume=context.volume, side=OrderSide_Buy,
                             order_type=OrderType_Market,
                             position_effect=PositionEffect_Close)
                print('以市价单平空仓{}手'.format(context.volume))
            # 否则,做多
            if not position_short:
                order_volume(symbol=context.symbol, volume=context.volume, side=OrderSide_Buy,
                             order_type=OrderType_Market,
                             position_effect=PositionEffect_Open)
                print('以市价单开多{}手'.format(context.volume))
# 设计一个止损条件:当持仓量达到10手,全部平仓
if position_short == 10 or position_long == 10:
    order_close_all()
    print('触发止损,全部平仓')

if name == '__main__':

'''
strategy_id策略ID,由系统生成
filename文件名,请与本文件名保持一致
mode实时模式:MODE_LIVE回测模式:MODE_BACKTEST
token绑定计算机的ID,可在系统设置-密钥管理中生成
backtest_start_time回测开始时间
backtest_end_time回测结束时间
backtest_adjust股票复权方式不复权:ADJUST_NONE前复权:ADJUST_PREV后复权:ADJUST_POST
backtest_initial_cash回测初始资金
backtest_commission_ratio回测佣金比例
backtest_slippage_ratio回测滑点比例
'''
run(strategy_id='strategy_id',
    filename='main.py',
    mode=MODE_BACKTEST,
    token='token_id',
    backtest_start_time='2018-07-01 08:00:00',
    backtest_end_time='2018-10-01 16:00:00',
    backtest_adjust=ADJUST_PREV,
    backtest_initial_cash=100000,
    backtest_commission_ratio=0.0001,
    backtest_slippage_ratio=0.0001)

相关文章
|
2月前
|
机器学习/深度学习 人工智能 自然语言处理
TsingtaoAI具身智能机器人开发套件及实训方案
该产品套件创新性地融合了先进大模型技术、深度相机与多轴协作机械臂技术,构建了一个功能强大、灵活易用的人机协作解决方案。其核心在于将智能决策、精准感知与高效执行完美结合,为高校实训领域的发展注入新动力。
161 10
|
5月前
|
人工智能 开发框架 机器人
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
AstrBot 是一个开源的多平台聊天机器人及开发框架,支持多种大语言模型和消息平台,具备多轮对话、语音转文字等功能。
3777 15
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
|
6月前
|
人工智能 自动驾驶 安全
Cosmos:英伟达生成式世界基础模型平台,加速自动驾驶与机器人开发
Cosmos 是英伟达推出的生成式世界基础模型平台,旨在加速物理人工智能系统的发展,特别是在自动驾驶和机器人领域。
633 15
Cosmos:英伟达生成式世界基础模型平台,加速自动驾驶与机器人开发
|
7月前
|
传感器 人工智能 自然语言处理
RDT:清华开源全球最大的双臂机器人操作任务扩散基础模型、代码与训练集,基于模仿能力机器人能够自主完成复杂任务
RDT(Robotics Diffusion Transformer)是由清华大学AI研究院TSAIL团队推出的全球最大的双臂机器人操作任务扩散基础模型。RDT具备十亿参数量,能够在无需人类操控的情况下自主完成复杂任务,如调酒和遛狗。
463 22
RDT:清华开源全球最大的双臂机器人操作任务扩散基础模型、代码与训练集,基于模仿能力机器人能够自主完成复杂任务
|
7月前
|
编解码 网络协议 机器人
顶顶通电话机器人开发接口对接大语言模型之实时流TTS对接介绍
大语言模型通常流式返回文字,若一次性TTS会导致严重延迟。通过标点断句或流TTS可实现低延迟的文本到语音转换。本文介绍了电话机器人接口适配流TTS的原理及技术点,包括FreeSWITCH通过WebSocket流TTS放音,以及推流协议和旁路流对接的详细说明。
580 1
|
4月前
|
人工智能 自然语言处理 机器人
9.9K star!大模型原生即时通信机器人平台,这个开源项目让AI对话更智能!
"😎高稳定、🧩支持插件、🦄多模态 - 大模型原生即时通信机器人平台"
119 0
|
21天前
|
机器人
陌陌自动回复消息脚本,陌陌自动打招呼回复机器人插件,自动聊天智能版
这是一款为陌陌用户设计的自动回复软件,旨在解决用户无法及时回复消息的问题,提高成交率和有效粉丝数。软件通过自动化操作实现消息检测与回复功能
|
2月前
|
弹性计算 自然语言处理 Ubuntu
从0开始在阿里云上搭建基于通义千问的钉钉智能问答机器人
本文描述在阿里云上从0开始构建一个LLM智能问答钉钉机器人。LLM直接调用了阿里云百炼平台提供的调用服务。
从0开始在阿里云上搭建基于通义千问的钉钉智能问答机器人
|
3月前
|
人工智能 自然语言处理 安全
Deepseek 的 “灵魂”,宇树的 “躯体”,智能机器人还缺一个 “万万不能”
法思诺创新探讨智能机器人产业的发展,指出Deepseek的AI“灵魂”与宇树的机器人“躯体”虽技术先进,但缺乏关键的商业模式。文章分析了两者在硬件和软件领域的困境,并提出通过软硬一体化结合及明确商业模式,才能实现真正实用的智能机器人。未来,需聚焦高频刚需场景、优化付费体验、推动技术创新,让智能机器人走进千家万户。法思诺提供相关课程与咨询服务,助力行业突破。
|
3月前
|
传感器 机器学习/深度学习 人工智能
自己都站不稳,怎么护理人?智能机器人的自主平衡问题,用TRIZ和DeepSeek有解吗?
法思诺创新探讨机器人自主平衡难题,结合TRIZ创新理论与DeepSeek大模型,为仿人机器人动态平衡提供解决方案。文章分析了机器人平衡差的原因,包括复杂环境、传感器限制、算法难度和机械设计挑战等,并提出通过TRIZ原理(如矛盾识别、理想解)与DeepSeek的AI能力(如数据学习、强化学习)协同优化平衡性能。展望未来,2024-2028年将实现从实验室验证到家用场景落地,推动消费级人形机器人发展。
125 0

热门文章

最新文章