漆学军:MACD交叉,金叉做多,死叉做空的例子程序

《MT4EA编程速成教程》中第33页习题:

第二题:将交易信号改成MACD交叉,金叉做多,死叉做空。

这道题的重点和难点就是获取MACD的指标值,MACD和之前的抛物线指标或者均线指标不一样,稍微复杂些。

MACD指标有两个缓存数组,一个显示的是柱体部分,一个显示的是红色虚线。

double  iMACD( 
   string       symbol,           // 品种
   int          timeframe,        // 时间周期
   int          fast_ema_period,  // 快线周期
   int          slow_ema_period,  // 慢线周期
   int          signal_period,    // 信号线周期 
   int          applied_price,    // 应用于价格 
   int          mode,             // 线索引 
   int          shift             // 位移 
   );

 系统规定,柱体部分的线索引为0,常量是,红色虚线的线索引为1。

下面是MQL4参考中的常量信息:

ID

Value

Description

MODE_MAIN

0

基础指标线

MODE_SIGNAL

1

信号线

获取MACD指标基础指标线和信号线的值,可以用如下参数:

//如果要获取位移为1的MACD的柱体指标值,可以用如下参数: 
double macd_main1=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_MAIN,1);
//如果要获取位移为2的MACD的柱体指标值,可以用如下参数: 
 double macd_main2=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_MAIN,2);
//如果要获取位移为1的MACD的信号线指标值,可以用如下参数: 
 double macd_signal1=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_SIGNAL,1);
//如果要获取位移为2的MACD的信号线指标值,可以用如下参数: 
 double macd_signal2=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_SIGNAL,2);

金叉和死叉就是四个数据的比较了,信号函数修改如下

int signal()
  {
   int res=0;
//如果要获取位移为1的MACD的柱体指标值,可以用如下参数:
   double macd_main1=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_MAIN,1);
//如果要获取位移为2的MACD的柱体指标值,可以用如下参数:
   double macd_main2=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_MAIN,2);
//如果要获取位移为1的MACD的信号线指标值,可以用如下参数:
   double macd_signal1=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_SIGNAL,1);
//如果要获取位移为2的MACD的信号线指标值,可以用如下参数:
   double macd_signal2=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_SIGNAL,2);
   
   if(macd_main1>macd_signal1 && macd_main2<macd_signal2)
     {
      res=1;
     }
   if(macd_main1<macd_signal1 && macd_main2>macd_signal2)
     {
      res=-1;
     }
   return(res);
  }
//+------------------------------------------------------------------+

这个EA的完整代码如下:

//+------------------------------------------------------------------+
//|                                                 Test_EA_05_2.mq4 |
//|                                                             云开 |
//|                                             https://www.mql5.com |
//+------------------------------------------------------------------+
#property copyright "http://www.forexmt4.cn"
#property link      "http://www.forexmt4.cn"

#property description "【漆天编程】 习题EA2"
#property description "  "
#property description "这是一款测试EA,作者QQ:80364276"
#property description "  "
#property description "发布时间:2021.10.26"
#property strict
#property icon "//Images//sea.ico"

input double lots=0.1; //交易手数
input int SL=600;      //止损点数
input int TP=200;      //止盈点数

//+------------------------------------------------------------------+
//| Expert initialization function                                   |
//+------------------------------------------------------------------+
int OnInit()
  {
//---
//---
   return(INIT_SUCCEEDED);
  }
//+------------------------------------------------------------------+
//| Expert deinitialization function                                 |
//+------------------------------------------------------------------+
void OnDeinit(const int reason)
  {
//---

  }
//+------------------------------------------------------------------+
//| Expert tick function                                             |
//+------------------------------------------------------------------+
void OnTick()
  {
   int buys=0;  //多单持仓有几笔
   int sells=0; //空单持仓有几笔
   int signal=signal();
   for(int i=0; i<OrdersTotal(); i++)
     {
      if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES))
        {
         if(OrderSymbol()==Symbol() && OrderMagicNumber()==16384 && OrderType()==OP_BUY)
           {
            buys++;
            if(signal<0)
              {
               bool res=OrderClose(OrderTicket(),OrderLots(),Bid,0);
               if(res)
                 {
                  Print("订单平仓成功");
                 }
               return;
              }
            if(OrderStopLoss()==0)
              {
               bool res=OrderModify(OrderTicket(),OrderOpenPrice(),OrderOpenPrice()-SL*Point,OrderOpenPrice()+TP*Point,0);
               if(res)
                  Print("订单修改成功");
              }
           }

         if(OrderSymbol()==Symbol() && OrderMagicNumber()==16384 && OrderType()==OP_SELL)
           {
            sells++;
            if(OrderStopLoss()==0)
              {
               bool res=OrderModify(OrderTicket(),OrderOpenPrice(),OrderOpenPrice()+SL*Point,OrderOpenPrice()-TP*Point,0);
               if(res)
                  Print("订单修改成功");
              }
            if(signal>0)
              {
               bool res=OrderClose(OrderTicket(),OrderLots(),Ask,0);
               if(res)
                 {
                  Print("订单平仓成功");
                 }
               return;
              }
           }
        }
     }
//---
   if(signal>0 && buys==0)
     {
      int ticket=OrderSend(Symbol(),OP_BUY,lots,Ask,3,0,0,"My buy order",16384,0,clrGreen);
      if(ticket<0)
        {
         Print("OrderSend failed with error #",GetLastError());
        }
      else
        {
         Print("OrderSend placed successfully");
        }
     }

   if(signal<0 && sells==0)
     {
      int ticket=OrderSend(Symbol(),OP_SELL,lots,Bid,3,0,0,"My sell order",16384,0,clrRed);
      if(ticket<0)
        {
         Print("OrderSend failed with error #",GetLastError());
        }
      else
        {
         Print("OrderSend placed successfully");
        }
     }
  }
//+------------------------------------------------------------------+
int signal()
  {
   int res=0;
//如果要获取位移为1的MACD的柱体指标值,可以用如下参数:
   double macd_main1=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_MAIN,1);
//如果要获取位移为2的MACD的柱体指标值,可以用如下参数:
   double macd_main2=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_MAIN,2);
//如果要获取位移为1的MACD的信号线指标值,可以用如下参数:
   double macd_signal1=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_SIGNAL,1);
//如果要获取位移为2的MACD的信号线指标值,可以用如下参数:
   double macd_signal2=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_SIGNAL,2);
   
   if(macd_main1>macd_signal1 && macd_main2<macd_signal2)
     {
      res=1;
     }
   if(macd_main1<macd_signal1 && macd_main2>macd_signal2)
     {
      res=-1;
     }
   return(res);
  }
//+------------------------------------------------------------------+

一单一结的EA使用了这个模版之后,只需要修改信号函数部分,是不是很简单?

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: "郭学军,王润秋。基于MPU6050和HMC5883的九轴传感器地磁场测量系统研究"是一篇关于使用九轴传感器进行地磁场测量的研究文章。该研究旨在通过结合MPU6050和HMC5883两种传感器,设计一种能够准确测量地磁场的系统。文章以化工自为刊物,突出了地磁场在化工领域中的重要性和应用价值。 研究背景介绍了地磁场的定义和特性,并指出了地磁场在化工工程中的多个应用领域,如地下管道的检测、石油勘探等。随后,文章详细介绍了MPU6050和HMC5883这两种九轴传感器的原理和特点,以及它们分别用于加速度和角速度测量、地磁场测量的方法。 接下来,文章详细描述了基于MPU6050和HMC5883的九轴传感器地磁场测量系统的设计和实现。系统采用了微处理器作为控制核心,通过对传感器输出信号的处理和转换,实现了对地磁场的测量。其中,通过校准和滤波等技术手段,提高了测量的准确性和稳定性。 研究结果部分展示了实验数据和分析结果。通过对比系统测量值与标准值的差异,验证了系统的可靠性和准确性。实验结果表明,该系统能够精确地测量地磁场的强度和方向,并在化工领域中具有广泛的应用前景。 最后,文章总结了研究的成果和不足之处,并对未来的研究方向提出了展望。研究者指出,进一步优化和改进传感器的设计,提高系统的测量精度和稳定性,以及应用于更广泛的化工领域,都是未来研究的重点和挑战。 总的来说,这篇文章详细介绍了基于MPU6050和HMC5883九轴传感器的地磁场测量系统的研究。该系统具有准确测量地磁场的能力,对化工领域具有重要的应用价值和发展潜力。该研究为相关领域的学者和工程师提供了有价值的参考和借鉴。 ### 回答2: 《基于mpu6050和hmc5883的九轴传感器地磁场测量系统研究》是由郭学军和王润秋共同完成的研究项目。该研究旨在利用mpu6050和hmc5883两种传感器实现对地磁场的测量。 地磁场是地球所产生的磁场,它对于导航、定位和姿态控制等领域具有重要的应用价值。为了实现对地磁场的准确测量,研究团队选择了mpu6050和hmc5883这两种传感器。 mpu6050是一种六轴传感器,可以实时测量物体的加速度和角速度。而hmc5883是一种三轴磁强计,主要用于测量地磁场的强度和方向。通过将两种传感器进行组合,可以完整地获取九轴信息,从而实现对地磁场的测量。 研究团队首先对mpu6050和hmc5883进行了校准和性能评估,确保传感器的准确度和稳定性。随后,他们开发了基于九轴传感器的地磁场测量系统,并进行了实验验证。 实验结果表明,该系统能够准确地测量地磁场的强度和方向。同时,由于mpu6050和hmc5883两种传感器具有体积小、功耗低等优点,该系统在应用于导航、定位和姿态控制等领域时具有较大的实用性和便利性。 综上所述,郭学军和王润秋基于mpu6050和hmc5883的九轴传感器地磁场测量系统研究为地磁场测量领域提供了一种新的解决方案。该系统准确度高、稳定性好,并具有实用性和便利性,有望在相关领域得到广泛应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

漆学军

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值