自己做量化交易软件(38)小白量化实战11--双向高频马丁交易策略

自己做量化交易软件(38)小白量化实战11–双向高频马丁交易策略
上一篇文章我们介绍了做多的马丁策略,见文章<自己做量化交易软件(37)小白量化实战10–操作方法与MetaTrader5高频策略的进化>.
这一篇介绍双向高频马丁交易策略,也就是说能够多空两个方向的开单策略.
小白量化双向马丁策略如下:
1、RSI上穿40开多方马丁策略。
2、RSI下穿60开空方马丁策略。
3、K线上穿布林上轨,或者 rsi>70,关闭做空马丁策略。
3、K线下穿布林下轨,或者 rsi<30,则止损关闭做多马丁策略。
4、设置每个订单的止盈和止损价。
5、采用策略盈利最大回撤机制关闭策略。
在高频策略中,1秒钟运行几十次,甚至上百次运算,遇到的两个重要问题,
一是信号稳定性,信号总是在金叉,不金叉之间摆动.
二是重复开单,信号满足条件,一致重复下单的问题.
这2个问题可以用技术手段来解决.
信号重复开单稳定性采用策略库中的mt5.ontime()函数来实现。
重复开单可以用开关变量加以控制。

小白量化双向马丁策略不保证能赚钱,仅仅给大家提供一个高频交易的思路。
我们使用MetaTrader5中BTCUSD品种进行测试交易。
下面给出这个策略的全部代码,其中有详细的注释。

'''
独狼荷蒲qq:2886002
通通小白python量化群:524949939
小白量化MT5群:556894446
tkinter,pyqt,gui,Python交流2:517029284
微信公众号:独狼股票分析
小白量化双向马丁策略:
1、RSI上穿40开多方马丁策略。
2、RSI下穿60开空方马丁策略。
3、K线上穿布林上轨,关闭做空马丁策略。
3、K线下穿布林下轨,关闭做多马丁策略。
4、设置每个订单的止盈和止损价。
5、采用策略盈利最大回撤关闭策略。
'''
#软件信息
p_sname='MT5自动交易程序'
p_aname='独狼'
p_edate='20210207'
p_ver=1.00

print('----------程序开始----------')
print('程序名称:',p_sname)
print('程序作者:',p_aname)
print('最后修改日期:',p_edate)
print('最新版本:',p_ver)


#引入相关库
import datetime
import numpy as np
import time
import pandas as pd
import threading

from HP_formula import *   #公式库
import MetaTrader5 as mt5
import HP_mt5a as hmt5  #hmt5增强库

#----------模块信息----------
print('----------模块信息----------')
print('numpy库版本:',np.version.version)
print('pandas库版本:',pd.__version__)
print('mt5库版本:',hmt5.__version__)
print('hmt5库版本:',hmt5.pver)


#----------定义全局变量----------
symbol="BTCUSD"
magic1=168
magic2=158
p_num=3  #开单数
p_step=50 #步长
lot=0.02 #开单量
##------------------------------

# BOLL 布林带指标
def BOLL(N=24, P=2):
    """
    BOLL 布林带
    """
    MID = MA(CLOSE, N)
    UPPER = MID + STD(CLOSE, N) * P
    LOWER = MID - STD(CLOSE, N) * P
    return UPPER, MID, LOWER

#RSI指标
def RSI(N1=5):
    LC = REF(CLOSE, 1)
    RSI1 = SMA(MAX(CLOSE - LC, 0), N1, 1) / SMA(ABS(CLOSE - LC), N1, 1) * 100.00
    return RSI1


#初始化小白mt5库
hmt5.init()


#登陆帐号
用户名=0
密码=''
服务器=''
hmt5.login(login=用户名, server=服务器,password=密码)

#输出mt5软件信息及连接相关信息
mt5info=hmt5.terminal_info()
mt5软件名称=mt5info.name
mt5软件语言=mt5info.language
mt5软件所属公司=mt5info.company
mt5软件路径=mt5info.path
print()
print('----------软件信息----------')
print('mt5软件名称:',mt5软件名称)
print('mt5软件语言:',mt5软件语言)
print('mt5软件所属公司:',mt5软件所属公司)
print('mt5软件路径:',mt5软件路径)

#获取用户登陆信息
accountinfo=mt5.account_info()
姓名=accountinfo.name
服务器=accountinfo.server
货币=accountinfo.currency
用户名=accountinfo.login
结余=accountinfo.balance
总净值=accountinfo.equity
总盈亏=accountinfo.profit

print()
print('----------用户信息----------')
print('姓名:',姓名)
print('服务器:',服务器)
print('用户名',用户名)
print('总盈亏',总盈亏)
print('总净值',总净值)
print('结余:',结余)

symbol="BTCUSD"
ask=hmt5.symbol_info_tick(symbol).ask
bid=hmt5.symbol_info_tick(symbol).bid
点差=ask-bid

print('ask : ',ask)
print('bid : ',bid)
print('点差:' , 点差)

#多单马丁策略Martingale Strategy
md=hmt5.Martingale_Strategy( symbol = symbol,volume=lot,price=p_step,magic=magic1,n=3,x1=200,x2=400,type2=0)

#空单马丁策略Martingale Strategy
md2=hmt5.Martingale_Strategy( symbol = symbol,volume=lot,price=p_step,magic=magic2,n=3,x1=200,x2=400,type2=1)

#开关变量,防止策略重复开单
开多单=False
开空单=False

i=0
while True:
    start = time.time()
#    if i>0:    #取消这段注释,循环只运行1次。
#        break
    print("第%d次工作"%i)

    #获取行情数据并计算
    rates= mt5.copy_rates_from_pos(symbol, mt5.TIMEFRAME_M1, 0, 300)
    data2=hmt5.tohpdata(rates)

    #小白量化数据格式化
    mydf=data2.reset_index(level=None, drop=True ,col_level=0, col_fill='')
    CLOSE= mydf['close']
    HIGH=mydf['high']
    LOW=mydf.low
    OPEN=mydf.open

    #计算布林轨道
    BOLL_u,BOLL_m,BOLL_d=BOLL()
    mydf['BOLL_u']=BOLL_u
    mydf['BOLL_m']=BOLL_m
    mydf['BOLL_d']=BOLL_d

    #计算RSI指标
    mydf['rsi']=RSI()
    mydf['z30']=30
    mydf['z40']=40
    mydf['z50']=50
    mydf['z60']=60
    mydf['z70']=60
    
    #买多信号
    mydf['buy']=CROSS(mydf['rsi'],mydf['z40']) #rsi上穿30,买信号
    
    #买空信号
    mydf['sell']=CROSS(mydf['z60'],mydf['rsi']) #rsi下穿70,卖信号

    #让子弹飞一会,信号持续时间检测
    t1=hmt5.ontime('buy',mydf['buy'].iloc[-1],30)   #获取信号维持时间
    t2=hmt5.ontime('sell',mydf['sell'].iloc[-1],30) #获取信号维持时间

    if 开多单==False and mydf['buy'].iloc[-1]>0 and t1>20:
        开多单=True
        md.begin()  #执行多单马丁策略
        time.sleep(5)    #暂停多少秒
        t1=hmt5.settime('buy',mydf['buy'].iloc[-1],30)   #获取信号维持时间
        
    if 开空单==False and mydf['sell'].iloc[-1]>0 and t2>20:
        开空单=True
        md2.begin()  #执行空单马丁策略
        time.sleep(5)    #暂停多少秒
        t2=hmt5.settime('sell',mydf['sell'].iloc[-1],30) #获取信号维持时间
      
    df=md.getcc()  #获取全部多单持仓
    df2=md2.getcc()  #获取全部空单持仓
    
    #多单处理
    if len(df)>0:
        profit=df.profit.sum()  #持仓的总盈利
        hc=hmt5.huiche(mark='盈利',x=profit,t=30)  #获取盈利在30秒内的最大回撤
        if hc>0.2 and profit>2: #如果总盈利大于2美元,且回撤20%,关闭策略。
            md.closeall()  #关闭多向马丁策略
            time.sleep(5)    #暂停多少秒
            开多单=False
        if profit<-20: #如果总盈利小于20美元,且回撤20%,关闭策略。
            md.closeall()  #关闭多向马丁策略
            time.sleep(5)    #暂停多少秒
            开多单=False
    
    #空单处理
    if len(df2)>0:
        profit2=df2.profit.sum()  #持仓的总盈利
        hc2=hmt5.huiche(mark='盈利2',x=profit2,t=30)  #获取盈利在30秒内的最大回撤
        if hc2>0.2 and profit2>2: #如果总盈利大于2美元,且回撤20%,关闭策略。
            md2.closeall()  #关闭空向马丁策略
            time.sleep(5)    #暂停多少秒
            开空单=False
        if profit2<-20: #如果总盈利小于20美元,且回撤20%,关闭策略。
            md2.closeall()  #关闭空向马丁策略
            time.sleep(5)    #暂停多少秒 
            开空单=False
      
    #策略止损判断
    多止损=0
    if ask<mydf['BOLL_d'].iloc[-1] or mydf['rsi'].iloc[-1]<30:
        多止损=1
        
    空止损=0
    if bid>mydf['BOLL_u'].iloc[-1] or mydf['rsi'].iloc[-1]>70:
        空止损=1
    
    #让子弹飞一会,信号持续时间检测
    t3=hmt5.ontime('多止损',多止损,30)   #获取信号维持时间
    t4=hmt5.ontime('空止损',空止损,30)  #获取信号维持时间

    if 多止损>0 and t3>20 and 开多单 : #关闭看多马丁策略
        md.closeall()  #关闭多向马丁策略
        time.sleep(5)    #暂停多少秒
        开多单=False

    if 空止损>0 and t4>20 and 开空单 : #关闭看空马丁策略
        md2.closeall()  #关闭空向马丁策略
        time.sleep(5)    #暂停多少秒
        开空单=False
        
    i=i+1    #循环次数加1
    end=time.time()   #获取循环结束时间
    print('时间:',round(start,2),round(end,2),round(end-start,4),'秒,每秒跑%d圈。'%int(1/(end-start+0.000000001)))
    

程序输出如下:

6019次工作
时间: 1612698144.67 1612698144.69 0.019,每秒跑52圈。
第6020次工作
时间: 1612698144.69 1612698144.71 0.019,每秒跑52圈。
第6021次工作
时间: 1612698144.71 1612698144.73 0.02,每秒跑50圈。
第6022次工作
时间: 1612698144.73 1612698144.75 0.02,每秒跑50圈。

程序交易部分信息:
在这里插入图片描述
mt5开单情况:
在这里插入图片描述
作者出版的书<零基础搭建量化投资系统――以Python为工具> 提供仿通达信自编指标的设计和实现。HP_formula模块在读者群文件中下载。

请持续关注我的博客,我的进步,就是你的进步!

猜你喜欢

转载自blog.csdn.net/hepu8/article/details/113746024
今日推荐