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

EA设计零起点!点点鼠标就能拥有属于自己的EA!

EA设计零起点!点点鼠标就能拥有属于自己的EA!

  1. EA的基本框架
  2. /+------------------------------------------------------------------+
  3. //|                           Designed by bull, China                |
  4. //|                   Copyright 2007, bull                         |
  5. //|                                 bbs.520fx.com                         |
  6. //+------------------------------------------------------------------+
  7. #property  copyright "Copyright 2007 , bull, China."
  8. #property  link      "bbs.520fx.com"
  9. #define MAGICMA
  10. //+------------------------------------------------------------------+
  11. //| 注意没有指标文件那些property                   |
  12. //+------------------------------------------------------------------+
  13. extern int whichmethod = 1;   //1~4 种下单方式  1 仅开仓, 2 有止损无止赢, 3 有止赢无止损, 4 有止赢也有止损
  14. extern double TakeProfit = 100;   //止赢点数
  15. extern   double StopLoss = 20;    //止损点数
  16. extern double MaximumRisk     = 0.3; //资金控制,控制下单量
  17. extern double TrailingStop =25;     //跟踪止赢点数设置
  18. extern   int maxOpen = 3;   //最多开仓次数限制
  19. extern   int maxLots = 5;   //最多单仓持仓量限制
  20. extern int bb = 0;       //非零就允许跟踪止赢
  21. extern double MATrendPeriod=26;//使用26均线 开仓条件参数  本例子

  22. int i, p2, xxx,p1, res;
  23. double Lots;
  24. datetime lasttime;       //时间控制, 仅当一个时间周期完成才检查条件
  25. int init()   //初始化
  26. {
  27. Lots = 1;
  28. lasttime = NULL;
  29. return(0);
  30. }
  31. int deinit() { return(0); } //反初始化
  32. //主程序
  33. int start()
  34. {
  35. CheckForOpen();    //开仓 平仓 条件检查 和操作
  36. if (bb>0)   CTP();   //跟踪止赢
  37. return(0);
  38. }
  39. //+------下面是各子程序--------------------------------------------+
  40. double LotsOptimized()   //确定下单量,开仓调用 资金控制
  41. {
  42. double lot=Lots;
  43. int   orders=HistoryTotal();   // history orders total
  44. int   losses=0;             // number of losses orders without a break
  45. //MarketInfo(Symbol(),MODE_MINLOT);     相关信息
  46. //MarketInfo(Symbol(),MODE_MAXLOT);
  47. //MarketInfo(Symbol(),MODE_LOTSTEP);
  48. lot=NormalizeDouble(MaximumRisk * AccountBalance()/AccountLeverage(),1);     //开仓量计算
  49. if(lot<0.1) lot=0.1;
  50. if(lot>maxLots) lot=maxLots;
  51. return(lot);
  52. }
  53.   
  54. //平仓持有的买单
  55. void CloseBuy()
  56. {
  57. if (OrdersTotal( ) > 0 )   
  58. {
  59.   for(i=OrdersTotal()-1;i>=0;i--)
  60.   {
  61.   if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==false)     break;
  62.   if(OrderType()==OP_BUY)
  63.   {
  64.     OrderClose(OrderTicket(),OrderLots(),Bid,3,White);
  65.     Sleep(5000);
  66.   }
  67.   }
  68. }
  69. }
  70. //平仓持有的卖单
  71. void CloseSell()
  72. {
  73. if (OrdersTotal( ) > 0 )   
  74. {
  75.   for(i=OrdersTotal()-1;i>=0;i--)
  76.   {
  77.   if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==false)     break;
  78.   if(OrderType()==OP_SELL)
  79.     {
  80.     OrderClose(OrderTicket(),OrderLots(),Ask,3,White);
  81.     Sleep(5000);
  82.     }
  83.   }
  84. }
  85. }
  86. //判断是否买或卖或平仓
  87. int buyorsell()   //在这个函数计算设置你的交易信号  这里使用MACD 和MA 做例子
  88. {
  89.   double MacdCurrent, MacdPrevious, SignalCurrent;
  90.   double SignalPrevious, MaCurrent, MaPrevious;
  91.   MacdCurrent=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_MAIN,0);
  92.   MacdPrevious=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_MAIN,1);
  93.   SignalCurrent=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_SIGNAL,0);
  94.   SignalPrevious=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_SIGNAL,1);
  95.   MaCurrent=iMA(NULL,0,MATrendPeriod,0,MODE_EMA,PRICE_CLOSE,0);
  96.   MaPrevious=iMA(NULL,0,MATrendPeriod,0,MODE_EMA,PRICE_CLOSE,1);
  97. if(MacdCurrent<0 && MacdCurrent>SignalCurrent && MacdPrevious<SignalPrevious
  98.     && MaCurrent>MaPrevious)
  99.   return (1); // 买 Ma在上升,Macd在0线上,并且两线上交叉
  100. if(MacdCurrent>0 && MacdCurrent<SignalCurrent && MacdPrevious>SignalPrevious
  101.     && MaCurrent<MaPrevious)
  102.   return (-1); // 卖
  103. return (0); //不交易
  104. }
  105. int nowbuyorsell = 0;
  106. void CheckForOpen()
  107. {
  108. if (Time[0] == lasttime ) return; //每时间周期检查一次  时间控制
  109. lasttime = Time[0];
  110. nowbuyorsell = buyorsell(); //获取买卖信号

  111. if (nowbuyorsell == 1) //买 先结束已卖的
  112.   CloseSell();
  113. if (nowbuyorsell == -1) //卖 先结束已买的
  114.     CloseBuy();
  115. if (TimeDayOfWeek(CurTime()) == 1)
  116.   {
  117.   if (TimeHour(CurTime()) < 3 ) return; //周一早8点前不做 具体决定于你的时区和服务器的时区  时间控制
  118.   }
  119. if (TimeDayOfWeek(CurTime()) == 5)
  120.   {
  121.   if (TimeHour(CurTime()) > 19 ) return; //周五晚11点后不做
  122.   }

  123. if (OrdersTotal( ) >= maxOpen) return ;   
  124. //如果已持有开仓次数达到最大,不做
  125. if (nowbuyorsell==0) return;   //不交易
  126. TradeOK();   //去下单交易
  127. }
  128. void TradeOK()   //去下单交易
  129. {
  130. int error ;
  131. if (nowbuyorsell == 1) //买
  132.   {
  133.     switch (whichmethod)
  134.     {
  135.     case 1:   res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,0,0,"",MAGICMA,0,Blue);break;
  136.     case 2:   res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,Ask-StopLoss*Point,0,"",MAGICMA,0,Blue); break;
  137.     case 3:   res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,0,Ask+TakeProfit*Point,"",MAGICMA,0,Blue);break;
  138.     case 4:   res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,Ask-StopLoss*Point,Ask+TakeProfit*Point,"",MAGICMA,0,Blue);break;
  139.     default : res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,0,0,"",MAGICMA,0,Blue);break;
  140.     }
  141.     if (res <=0)
  142.     {
  143.     error=GetLastError();
  144.     if(error==134)Print("Received 134 Error after OrderSend() !! ");         // not enough money
  145.     if(error==135) RefreshRates();   // prices have changed
  146.     }
  147.     Sleep(5000);
  148.     return ;   
  149.   }
  150. if (nowbuyorsell == -1) //卖
  151.   {
  152.     switch (whichmethod)
  153.     {
  154.     case 1:   res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,0,0,"",MAGICMA,0,Red); break;
  155.     case 2:   res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,Bid+StopLoss*Point,0,"",MAGICMA,0,Red); break;
  156.     case 3:   res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,0,Bid-TakeProfit*Point,"",MAGICMA,0,Red); break;
  157.     case 4:   res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,Bid+StopLoss*Point,Bid-TakeProfit*Point,"",MAGICMA,0,Red); break;
  158.     default : res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,0,0,"",MAGICMA,0,Red); break;
  159.     }
  160.     if (res <=0)
  161.     {
  162.     error=GetLastError();
  163.     if(error==134) Print("Received 134 Error after OrderSend() !! ");         // not enough money
  164.     if(error==135) RefreshRates();   // prices have changed
  165.     }
  166.     Sleep(5000);
  167.     return ;   
  168.   }
  169. }
  170. void CTP()   //跟踪止赢
  171. {
  172. bool bs = false;
  173. for (int i = 0; i < OrdersTotal(); i++)
  174. {
  175.   if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==false)     break;
  176.   if (OrderType() == OP_BUY)
  177.   {
  178.     if ((Bid - OrderOpenPrice()) > (TrailingStop * MarketInfo(OrderSymbol(), MODE_POINT)))    //开仓价格 当前止损和当前价格比较判断是否要修改跟踪止赢设置
  179.     {
  180.     if (OrderStopLoss() < Bid - TrailingStop * MarketInfo(OrderSymbol(), MODE_POINT))
  181.     {
  182.       bs = OrderModify(OrderTicket(), OrderOpenPrice(), Bid - TrailingStop * MarketInfo(OrderSymbol(), MODE_POINT), OrderTakeProfit(),0, Green);
  183.     }
  184.     }
  185.   }
  186.   else if (OrderType() == OP_SELL)
  187.   {
  188.     if ((OrderOpenPrice() - Ask) > (TrailingStop * MarketInfo(OrderSymbol(), MODE_POINT)))  //开仓价格 当前止损和当前价格比较判断是否要修改跟踪止赢设置

  189.     {
  190.     if ((OrderStopLoss()) > (Ask + TrailingStop * MarketInfo(OrderSymbol(), MODE_POINT)))
  191.     {     
  192.       bs = OrderModify(OrderTicket(), OrderOpenPrice(),
  193.         Ask + TrailingStop * MarketInfo(OrderSymbol(), MODE_POINT), OrderTakeProfit(),0, Tan);
  194. }
  195.     }
  196.   }
  197. }
  198. }
复制代码

论坛官方微信、群(期货热点、量化探讨、开户与绑定实盘)
 
期货论坛 - 版权/免责声明   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

返回列表