: | : | :期货量化学习 | :期货量化 |
返回列表 发帖

[MC源码] 最终版

[MC源码] 最终版

  1. Input:N1(120),N2(3),N3(5),inicap(1000000),riskratio(0.2),atrlength(14);
  2. var:top(0),bot(0),mp(0),totalamt(0),lots(1),stoploss(0),stopearn(0),exetripoint(0),entrATR(0),trailatr(0),trail(False),closehl(0),initrail(0);

  3. totalamt =inicap + (netprofit + openpositionprofit);

  4. if AvgTrueRange(atrlength) <> 0 then lots = ((totalamt/100)*riskratio)/(AvgTrueRange(atrlength)*bigpointvalue);

  5. mp = marketposition;

  6. top = Highest(high,N1);
  7. bot = Lowest(low,N1);

  8. if mp = 0 then begin  //entry model
  9.   if Close > top[1] then buy("buylong") lots shares next bar at market;
  10.   if Close < bot[1] then sellshort("sellshort") lots shares next bar at market;
  11. end;

  12. if marketposition <> 0 and barssinceentry = 0 then begin
  13.      entrATR = AvgTrueRange(atrlength);
  14.      exetripoint = Close;
  15.      trail = False;
  16.      if marketposition =1 then
  17.        value1 = text_new(date,time,low - 100,"L:"+numtostr(entryprice,0)+ "Atr:"+numtostr(entrATR,0) + "STP:" + NumToStr(entryprice - 3*entratr,0))
  18.      else if marketposition =-1 then
  19.        value1 = text_new(date,time,high + 100,"S:"+numtostr(entryprice,0)+ "Atr:"+numtostr(entrATR,0) + "STP:" + NumToStr(entryprice + 3*entratr,0));
  20. end;

  21. //long order
  22. if marketposition = 1 and barssinceentry > 0 then begin
  23.    if Close > exetripoint then begin
  24.       exetripoint = Close;   
  25.       trailatr = AvgTrueRange(atrlength);
  26.    end;         
  27.    if exetripoint > entryprice + 2*entrATR then begin //tril start     
  28.       value2 = text_new(date,time,high + 30,"T:"+numtostr(exetripoint,0)+"Atr:"+numtostr(trailatr,0)+"TRAIL:"+NumToStr(exetripoint - N3*trailatr,0));  
  29.       value3 = tl_new(date[1],time[1],exetripoint[1],date,time,exetripoint);
  30.       sell("L-stopearn") all shares next bar at exetripoint - N3*trailatr stop;
  31.    end;
  32.    
  33.    sell("L-stoploss") all shares next bar at entryprice - N2*entratr stop;  
  34. end;  

  35. //short order
  36. if marketposition = -1 and barssinceentry> 0 then begin
  37.    if Close < exetripoint then begin
  38.       exetripoint = Close;
  39.       trailatr = AvgTrueRange(atrlength);
  40.    end;
  41.    if exetripoint < entryprice - 2*entrATR then begin
  42.       value2 = text_new(date,time,low - 30,"B:"+numtostr(exetripoint,0)+"Atr:"+numtostr(trailatr,0)+"TRAIL:"+NumToStr(exetripoint + N3*trailatr,0));  
  43.       value3 = tl_new(date[1],time[1],exetripoint[1],date,time,exetripoint);
  44.       buytocover("S-stopearn") all shares next bar at exetripoint + N3*trailatr stop;
  45.    end;

  46.   buytocover("S-stoploss") all shares next bar at entryprice + N2*entratr stop;
  47. end;
复制代码

论坛官方微信、群(期货热点、量化探讨、开户与绑定实盘)
 
期货论坛 - 版权/免责声明   1.本站发布源码(包括函数、指标、策略等)均属开放源码,用意在于让使用者学习程序化语法撰写,使用者可以任意修改语法內容并调整参数。仅限用于个人学习使用,请勿转载、滥用,严禁私自连接实盘账户交易
  2.本站发布资讯(包括文章、视频、历史记录、教材、评论、资讯、交易方案等)均系转载自网络主流媒体,内容仅为作者当日个人观点,本网转载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。本网不对该类信息或数据做任何保证。不对您构成任何投资建议,不能依靠信息而取代自身独立判断,不对因使用本篇文章所诉信息或观点等导致的损失承担任何责任。
  3.本站发布资源(包括书籍、杂志、文档、软件等)均从互联网搜索而来,仅供个人免费交流学习,不可用作商业用途,本站不对显示的内容承担任何责任。请在下载后24小时内删除。如果喜欢,请购买正版,谢谢合作!
  4.龙听期货论坛原创文章属本网版权作品,转载须注明来源“龙听期货论坛”,违者本网将保留追究其相关法律责任的权力。本论坛除发布原创文章外,亦致力于优秀财经文章的交流分享,部分文章推送时若未能及时与原作者取得联系并涉及版权问题时,请及时联系删除。联系方式:http://www.qhlt.cn/thread-262-1-1.html
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

返回列表