关于本站
人大经济论坛-经管之家:分享大学、考研、论文、会计、留学、数据、经济学、金融学、管理学、统计学、博弈论、统计年鉴、行业分析包括等相关资源。
经管之家是国内活跃的在线教育咨询平台!
经管之家新媒体交易平台
提供"微信号、微博、抖音、快手、头条、小红书、百家号、企鹅号、UC号、一点资讯"等虚拟账号交易,真正实现买卖双方的共赢。【请点击这里访问】
期刊
- 期刊库 | 马上cssci就要更新 ...
- 期刊库 | 【独家发布】《财 ...
- 期刊库 | 【独家发布】“我 ...
- 期刊库 | 【独家发布】“我 ...
- 期刊库 | 【独家发布】国家 ...
- 期刊库 | 请问Management S ...
- 期刊库 | 英文期刊库
- 核心期刊 | 歧路彷徨:核心期 ...
TOP热门关键词
坛友互助群 |
扫码加入各岗位、行业、专业交流群 |
策略名称: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
您可能感兴趣的文章
本站推荐的文章
人气文章
2.转载的文章仅代表原创作者观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,本站对该文以及其中全部或者部分内容、文字的真实性、完整性、及时性,不作出任何保证或承若;
3.如本站转载稿涉及版权等问题,请作者及时联系本站,我们会及时处理。