期魔方风控模型之委托失败补单程序

你知道吗?只需简单设置,期魔方风控模型就能自动处理风控委托失败的订单,进行补单操作。

那么,这种功能适用于哪些场景呢?让我们一起来探讨一下!

在实际交易中,我们有时会遇到在任意交易终端(如文华博弈、随身行等)下单后,委托被挂起未成交,或者由于流动性不足导致部分订单未能完全成交。此时,期魔方的自动补单功能就能发挥关键作用。系统会自动撤销未成交的订单,并重新提交补单,确保不会错失交易机会,避免漏单风险。

这一自动补单功能不仅可以应用于全局账户风控,也可以针对特定合约进行精确控制。用户还可以自定义补单方式,选择市价、现价或对价等不同类型的报单方式,以适应不同的市场需求和风险管理策略。

这是这款风控模型的Python源码,适用于期魔方软件

#——————————————#

#文件类型:量化策略

#帮助文档:https://qmfquant.com/static/doc/code/strategyEdit.html

#期魔方,为您提供专业的量化服务

#——————————————#

from pydantic import BaseModel, Field

import time

import datetime

class Params(BaseModel, validate_assignment=True):

    “””参数映射模型”””

    set_symbol_mode:dict   = Field(default={“options”:[“全局”,”指定”],\

                                           “value”:”全局”},title =”跟踪对象”)

    symbols:str            = Field(default=”ag2510,rb2510″,title =”指定的合约”)

    over_time_second:int   = Field(default=10,title = “超时N秒撤单”)

    #run_dis:int            = Field(default=10,title  = “触发间隔”)

    #run_times:int          = Field(default=3,title  = “执行次数”)

    set_price_mode:dict   = Field(default={“options”:[“市价”,”现价”,”对价”],\

                                           “value”:”市价”},title =”报单方式”)

position                   = {}

def on_init(context):

    print(“[on_init] => 初始化…”)    

    context.orders =  {}

    context.wait_open_orders  = []

    print(“[on_init] => 初始化完成.”)

def on_tick(context):

    try:

        #判断订单是否超时 超时发起撤单  并重新开单

        for order_sys_id,order in context.orders.items():

            if order.get(“OrderStatus”) == “3”:

                #未成交

                insert_date = order.get(“InsertDate”)

                insert_time = order.get(“InsertTime”)

                order_time = datetime.datetime.strptime(

                    f”{insert_date} {insert_time}”,”%Y%m%d %H:%M:%S”).timestamp()

                current_time = datetime.datetime.now().timestamp()

                #print(f”订单时间戳=>{order_time}  当前时间戳=>{current_time}”)

                if current_time – order_time > int(context.over_time_second):

                    #撤单

                    print(f”订单时间:{insert_date} {insert_time}  当前的时间 {datetime.datetime.now()}”)

                    print(f”执行超时撤单 [{order_sys_id}]”)

                    action_order(order)

    except Exception as e:

        print(f”撤单判断过程有错误  {e}”)

    try:

        #把需要重开的订单依次执行开启

        while len(context.wait_open_orders) >0:

            order = context.wait_open_orders.pop(0)

            #执行开仓

            result = open_order(context,order)

            if result <=0:

                print(“重开失败”)

                context.wait_open_orders.append(order)

                break

            else:

                print(“报单成功”)        

        …

    except Exception as e:

        print(f”重开过程报错=>{e}”)

    …

def cook_order_key(order):

    return f”{

        order.get(‘InstrumentID’)}_{order.get(‘Direction’)}_{order.get(‘CombOffsetFlag’)}_{order.get(‘VolumeTotalOriginal’)}”

def open_order(context,order):

    try:

        symbol = order.get(“InstrumentID”)

        exchangid = order.get(“ExchangeID”)

        direction = order.get(“Direction”)

        volume    = order.get(“VolumeTotalOriginal”)

        comboffsetflag = order.get(“CombOffsetFlag”)

        tick = get_tick(symbol)

        if not tick.get(“ActionDay”):

            #tick获取失败 返回等待下一次运行

            return -1

        upper_price = float(tick.get(“UpperLimitPrice”))

        lower_price = float(tick.get(“LowerLimitPrice”))

        if context.set_price_mode.get(“value”) == “对价”:

            upper_price = float(tick.get(“BidPrice1”))

            lower_price = float(tick.get(“AskPrice1”))

        if context.set_price_mode.get(“value”) == “现价”:

            upper_price = float(tick.get(“LastPrice”))

            lower_price = float(tick.get(“LastPrice”))

        price  =upper_price if direction==”0″ else lower_price

        order  = {

            “symbol”:symbol,

            “exchangeid”:exchangid,

            “limitprice”:price,

            “direction”:direction,

            “orderpricetype”:”2″,

            “comboffsetflag”:comboffsetflag,

            “volumn”:volume

            }

        print(f”报单信息 => {order}”)

        send_order(order)

    except Exception as e:

        print(f”开单出现错误=>请查看GridTrade.close_order[{e}]”)

        print(e)

        return 0

    return 1

def on_allorder(context,data):

    “””按要求记录全局报单”””

    order_sys_id  = data.get(“OrderSysID”)

    instrument_id = data.get(“InstrumentID”)

    if context.set_symbol_mode.get(“value”) == “指定”:

        if instrument_id not in context.symbols: return

    order_status  = data.get(“OrderStatus”)

    offset         = data.get(“CombOffsetFlag”)

    if  order_status in “3”:

        context.orders[order_sys_id] = data

        print(“收到未成交报单信息”)

    elif order_status == “0”:

        if order_sys_id in context.orders:

            context.orders.pop(order_sys_id)

    elif order_status == “5”:

        if order_sys_id in context.orders:

            context.orders.pop(order_sys_id)

            #首单撤单信息 则按信息重新开启订单

            context.wait_open_orders.append(data)

            #执行开仓

            …

def on_order(context,data):

    “””报单回调函数”””

    #print(f”用来收集本地成交的记录  {data = }”)

    order_sys_id  = data.get(“OrderSysID”)

    instrument_id = data.get(“InstrumentID”)

    if context.set_symbol_mode.get(“value”) == “指定”:

        if instrument_id not in context.symbols: return

    order_status  = data.get(“OrderStatus”)

如何导入和启动风控策略,详见期魔方帮助文档:策略编写文档

图片[2]|期魔方风控模型之委托失败补单程序|魔方商学院

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/889446.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ubuntu系统的docker安装(2)

查看系统版本 lsb_release -asudo systemctl status docker查看docker是否安装成功 docker pull拉取镜像不成功/docker run不成功 可能有多种原因&#xff1a;网络链接不稳定&#xff0c;没有重启docker&#xff0c;可以先将docker源设置为国内镜像源 sudo systemctl rest…

Source Insight的使用经验汇总

01-Add All"和“Add Tree”有何区别&#xff1f; 在 Source Insight 中&#xff0c;“Add All”和“Add Tree”是两种向项目&#xff08;Project&#xff09;中添加文件的操作选项&#xff0c;它们的区别在于处理文件和目录的方式不同&#xff1a; 1. Add All 范围&am…

MVC基础——市场管理系统(四)

文章目录 项目地址六、EF CORE6.1 配置ef core环境6.2 code first6.2.1 创建Database context1. 添加navigation property2. 添加MarketContext上下文七、Authentication7.1 添加Identity7.2 Run DB migration for Identity7.3 使用Identity7.3.1 设置认证中间件7.3.2 设置权限…

前端编辑器JSON HTML等,vue2-ace-editor,vue3-ace-editor

与框架无关 vue2-ace-editor有问题&#xff0c;ace拿不到&#xff08;brace&#xff09; 一些组件都是基于ace-builds或者brace包装的 不如直接用下面的&#xff0c;不如直接使用下面的 <template><div ref"editor" class"json-editor"><…

Oracle 与 达梦 数据库 对比

当尝试安装了达梦数据库后&#xff0c;发现达梦真的和Oracle数据库太像了&#xff0c;甚至很多语法都相同。 比如&#xff1a;Oracle登录数据库采用sqlplus&#xff0c;达梦采用disql。 比如查看数据视图&#xff1a;达梦和Oracle都有 v$instance、v$database、dba_users等&a…

【docker】12. Docker Volume(存储卷)

什么是存储卷? 存储卷就是将宿主机的本地文件系统中存在的某个目录直接与容器内部的文件系统上的某一目录建立绑定关系。这就意味着&#xff0c;当我们在容器中的这个目录下写入数据时&#xff0c;容器会将其内容直接写入到宿主机上与此容器建立了绑定关系的目录。 在宿主机上…

汽车总线协议分析-CAN总线

随着汽车工业的发展&#xff0c;汽车各系统的控制逐步向自动化和智能化转变&#xff0c;汽车电气系统变得日益复杂。许多车辆设计使用CAN、CAN-FD、LIN、FlexRay或SENT在电子控制单元(ECU)之间以及ECU与传感器&#xff0c;执行器和显示器之间进行通信。这些ECU之间的通信允许车…

前端性能优化(理念篇)

前端性能优化&#xff08;理念篇&#xff09; 前言 其实前端性能优化&#xff0c;按照我的理解&#xff0c;首先你公司的硬件条件跟其它资源跟的上&#xff0c;比如服务器资源&#xff0c;宽带怎么样&#xff0c;还有后端接口响应如何&#xff0c;这些资源都具备后&#xff0…

IIS部署程序https是访问出现403或ERR_HTTP2_PROTOCOL_ERROR

一、说明 在windows server 2016中的IIS程序池里部署一套系统&#xff0c;通过https访问站点&#xff0c;同时考虑到安全问题以及防攻击等行为&#xff0c;就用上了WAF云盾功能&#xff0c;能有效的抵挡部分攻击&#xff0c;加强网站的安全性和健壮性。 应用系统一直能够正常…

【深度学习】热力图绘制

热力图&#xff08;Heatmap&#xff09;是一种数据可视化方法&#xff0c;通过颜色来表示数据矩阵中的数值大小&#xff0c;以便更直观地展示数据的分布和模式。热力图在许多领域中都有应用&#xff0c;尤其在统计分析、机器学习、数据挖掘等领域&#xff0c;能够帮助我们快速识…

3.6 IP 数据报的发送与转发

欢迎大家订阅【计算机网络】学习专栏&#xff0c;开启你的计算机网络学习之旅&#xff01; 文章目录 前言1 主机发送 IP 数据报2 直接交付与间接交付3 路由器转发 IP 数据报4 习题分析 前言 在计算机网络中&#xff0c;数据传输的核心工作之一是通过 IP 协议将数据从源主机传递…

PH热榜 | 2024-12-13

1. AI Santa by Tavus 标语&#xff1a;随时随地&#xff0c;视频连线圣诞老人&#xff01; 介绍&#xff1a;准备好迎接AI圣诞老人了吗&#xff1f;塔武斯公司推出的这款神奇的节日体验&#xff0c;能让你实时用30多种语言与圣诞老人对话&#xff0c;看看自己今年是乖孩子还…

双击 Origin 文件后打开软件只有空白没有任何窗口、或者打开后加载失败解决办法

这其实是因为你的文件并没有在 Origin 中打开&#xff0c;可以在标题栏确认 如果这里显示为 UNTITLED&#xff0c;就说明文件还没有在 Origin 中打开。如果你遇到此类问题&#xff0c;我们建议尝试以下方法。 方法 1 设 Origin 为打开 .opj/opju 文件时的默认应用程序 右键单…

【电子通识】电流倒灌为什么需要注意?

电流倒灌是一个很常见的问题,以“IO电流倒灌”为关键词在百度上进行搜索,可以找到很多相关案例。 电流倒灌问题在5V电平的单片机时代几乎不会发生,主要是因为5V单片的IO耐压值高,单片机内部结构对IO保护设计很好。 到了3.3V单片机时代,这类问题有一定的偶发性,但…

奇怪的知识又增加了:ESP32下的Lisp编程=>ULisp--Lisp for microcontrollers

ESP32下有MicroPython&#xff0c;那么我就在想&#xff0c;有Lisp语言支持吗&#xff1f;答案是果然有&#xff01;有ULisp&#xff0c;专门为MCU设计的Lisp&#xff01; 网址&#xff1a;uLisp - Lisp for microcontrollers 介绍&#xff1a;用于微控制器的 Lisp 适用于 Ar…

【竞技宝】LOL:JDG官宣yagao离队

北京时间2024年12月13日,在英雄联盟S14全球总决赛结束之后,各大赛区都已经进入了休赛期,目前休赛期也快进入尾声,LPL大部分队伍都开始陆续官宣转会期的动向,其中JDG就在近期正式官宣中单选手yagao离队,而后者大概率将直接选择退役。 近日,JDG战队在官方微博上连续发布阵容变动消…

得物App奢侈品鉴别能力再获A级资质认证

11月20日&#xff0c;在中国出入境检验检疫协会举办的“2024高端消费品检验鉴定与市场可持续发展大会”上传出消息&#xff0c;得物App因“先鉴别、后发货”保障正品的突出表现以及较高的消费者认可度&#xff0c;被中国海关科学技术研究中心授予“奢侈品鉴别&#xff08;箱包类…

使用BMFont创建适用于Unity的艺术字

最近经常使用艺术字&#xff0c;虽然之前的工作经验我知道只需要修什么哪些就可以弄好艺术字的创建和间隔&#xff0c;所以打算做个总结&#xff0c;接下来分为以下几步&#xff08;其中会有补充&#xff0c;最后会有如何解决unity艺术字的字距问题&#xff09; 第1步 下载BMF…

websocket_asyncio

WebSocket 和 asyncio 指南 简介 本指南涵盖了使用 Python 中的 websockets 库进行 WebSocket 编程的基础知识&#xff0c;以及 asyncio 在异步非阻塞 I/O 中的作用。它提供了构建高效 WebSocket 服务端和客户端的知识&#xff0c;以及 asyncio 的特性和优势。 1. 什么是 WebS…

数据结构_树表的查找

平衡调整方法 四种类型的调整 LL型调整 RR型调整 LR型调整 RL型调整 // 以p为根的二叉排序树作右旋处理(LL void BST::rRotate(BiNode*& p) {BiNode* k p->lChild;p->lChild k->rChild;k->rChild p;p k; }// 以p为根的二叉排序树作左旋处理(RR void BST:…