DUAL TRUST+资金管理策略源码-经管之家官网!

人大经济论坛-经管之家 收藏本站
您当前的位置> 考研考博>>

考研

>>

DUAL TRUST+资金管理策略源码

DUAL TRUST+资金管理策略源码

发布:ghjktdf | 分类:考研

关于本站

人大经济论坛-经管之家:分享大学、考研、论文、会计、留学、数据、经济学、金融学、管理学、统计学、博弈论、统计年鉴、行业分析包括等相关资源。
经管之家是国内活跃的在线教育咨询平台!

经管之家新媒体交易平台

提供"微信号、微博、抖音、快手、头条、小红书、百家号、企鹅号、UC号、一点资讯"等虚拟账号交易,真正实现买卖双方的共赢。【请点击这里访问】

提供微信号、微博、抖音、快手、头条、小红书、百家号、企鹅号、UC号、一点资讯等虚拟账号交易,真正实现买卖双方的共赢。【请点击这里访问】

资金管理类策略或文章在其他网站上很少见到,把之前收集的一些策略分享一下策略名称:DUALTRUST+资金管理策略原理:在原DualThrust策略逻辑的基础上,加上资金管理策略:即当前头寸在盈利的情况下才考虑进场回测曲线 ...
坛友互助群


扫码加入各岗位、行业、专业交流群


资金管理类策略或文章在其他网站上很少见到,把之前收集的一些策略分享一下
策略名称:DUAL TRUST+资金管理
策略原理:
在原DualThrust策略逻辑的基础上,加上资金管理策略:即当前头寸在盈利的情况下才考虑进场
回测曲线:
策略代码:

functionStrategy1(freq)%


targetList=traderGetTargetList();

%获取目标资产信息

HandleList=traderGetHandleList();

%获取账户句柄

globalrecord;

fork=1:length(targetList);


%--------------------仓位、K线、当前bar的提取-----------------------------%

%获取当前仓位

[marketposition,~,~]=traderGetAccountPosition(HandleList(1),targetList(k).Market,targetList(k).Code);

%策略中每次取数据的长度

lags=200;

dlags=10;

barnum=traderGetCurrentBar(targetList(k).Market,targetList(k).Code);

%数据长度限制

if(barnum<lags)

continue;

end

%获取K线数据

[time,open,high,low,close,volume,~,~]=traderGetKData(targetList(k).Market,targetList(k).Code,'min',freq,0-lags,0,false,'FWard');

[Dtime,Dopen,Dhigh,Dlow,Dclose,Dvolume,~,~]=traderGetKData(targetList(k).Market,targetList(k).Code,'day',1,0-dlags,0,false,'FWard');

iflength(close)<lags||length(Dclose)<dlags

continue;

end;

%-------------------------交易逻辑-------------------------------%

stoplossratio=0.03;

stopearnratio=stoplossratio*1.1; %止盈触发比例

%未平仓的订单提取

remain_num=find(record.isopen==1);

remain.isopen=record.isopen(remain_num);

remain.isearn=record.isearn(remain_num);

remain.pivotprice=record.pivotprice(remain_num);

remain.entrybar=record.entrybar(remain_num);

remain.unit=record.unit(remain_num);

remain.direction=record.direction(remain_num);

%计算购买手数

[ValidCash,MarketCap,OrderFrozen,MarginFrozen,PositionProfit]=traderGetAccountInfo(HandleList(1));

[~,~,Multiple,~,~,~,~,~,~]=traderGetFutureInfo(targetList(k).Market,targetList(k).Code);

remain_share=10-length(remain_num);

con1=0;

ifremain_share~=0;

con1=1; %表示仍有可用资金购买

openunit=fix(ValidCash/remain_share/close(end)/Multiple);

end;

%判断当前是多头持仓还是空头持仓

posdir=0;

if~isempty(remain.direction)

ifremain.direction(end)>0

posdir=1;

elseifremain.direction(end)<0

posdir=-1;

end;

end;

%---------------------------------对未平仓的订单进行平仓或者调整止损线--------------------------------------------%

fori=1:length(remain_num)

index=remain_num(i);

ifremain.direction(i)==1

ifclose(end)<remain.pivotprice(i)-stoplossratio*remain.pivotprice(i)%触发止损线

orderID3=traderDirectSell(HandleList(1),targetList(k).Market,targetList(k).Code,remain.unit(i),0,'market','sell');

iforderID3==0

continue;

end;

record.isopen(index)=0;

elseifclose(end)>remain.pivotprice(i)+stopearnratio*remain.pivotprice(i)%触发止盈线

record.pivotprice(index)=close(end);

record.isearn(index)=2;

end;

elseifremain.direction(i)==-1

ifclose(end)>remain.pivotprice(i)+stoplossratio*remain.pivotprice(i)%触发止损线

orderID4=traderDirectBuy(HandleList(1),targetList(k).Market,targetList(k).Code,remain.unit(i),0,'market','buy');

iforderID4==0

continue;

end;

record.isopen(index)=0;

elseifclose(end)<remain.pivotprice(i)-stopearnratio*remain.pivotprice(i)%触发止盈线

record.pivotprice(index)=close(end);

record.isearn(index)=2;

end;

end;

end;

%-----------------------------入场条件--------------------------------------------%

con2=isempty(find(remain.isearn==1,1)); %所有头寸都是盈利的才考虑进新的头寸

N=3;

k1=0.5;

k2=0.5;

HH=max(Dhigh(end-N:end-1));

HC=max(Dclose(end-N:end-1));

LC=min(Dclose(end-N:end-1));

LL=min(Dlow(end-N:end-1));

range=max(HH-LC,HC-LL);

upline=Dopen(end)+k1*range;

dnline=Dopen(end)-k2*range;

bcon=close(end)>upline;

scon=close(end)<dnline;

buycon=con1&&con2&&bcon&&posdir>=0;

sellshortcon=con1&&con2&&scon&&posdir<=0;

%---------------------------入场操作--------------------------------%

ifbuycon

orderID1=traderDirectBuy(HandleList(1),targetList(k).Market,targetList(k).Code,openunit,0,'market','buy');

iforderID1==0

continue;

end;

record.pivotprice=[record.pivotprice,close(end)];

record.isearn=[record.isearn,1];

record.isopen=[record.isopen,1];

record.unit=[record.unit,openunit];

record.entrybar=[record.entrybar,barnum];

record.direction=[record.direction,1];

end;

ifsellshortcon

orderID2=traderDirectSell(HandleList(1),targetList(k).Market,targetList(k).Code,openunit,0,'market','sell');

iforderID2==0

continue;

end;

record.pivotprice=[record.pivotprice,close(end)];

record.isearn=[record.isearn,1];

record.isopen=[record.isopen,1];

record.unit=[record.unit,openunit];

record.entrybar=[record.entrybar,barnum];

record.direction=[record.direction,-1];

end;

end

end


策略来源:atrader社区-策略服务

目测有上百个策略可以免费下载~


扫码或添加微信号:坛友素质互助


「经管之家」APP:经管人学习、答疑、交友,就上经管之家!
免流量费下载资料----在经管之家app可以下载论坛上的所有资源,并且不额外收取下载高峰期的论坛币。
涵盖所有经管领域的优秀内容----覆盖经济、管理、金融投资、计量统计、数据分析、国贸、财会等专业的学习宝库,各类资料应有尽有。
来自五湖四海的经管达人----已经有上千万的经管人来到这里,你可以找到任何学科方向、有共同话题的朋友。
经管之家(原人大经济论坛),跨越高校的围墙,带你走进经管知识的新世界。
扫描下方二维码下载并注册APP
本文关键词:

本文论坛网址:https://bbs.pinggu.org/thread-5337782-1-1.html

人气文章

1.凡人大经济论坛-经管之家转载的文章,均出自其它媒体或其他官网介绍,目的在于传递更多的信息,并不代表本站赞同其观点和其真实性负责;
2.转载的文章仅代表原创作者观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,本站对该文以及其中全部或者部分内容、文字的真实性、完整性、及时性,不作出任何保证或承若;
3.如本站转载稿涉及版权等问题,请作者及时联系本站,我们会及时处理。
经管之家 人大经济论坛 大学 专业 手机版