初学者的问题 MQL5 MT5 MetaTrader 5 - 页 860

 
你好!是否有基于鳄鱼指标+EMA(233)+随机指数的机器人?你对这一战略的看法是什么?
 
Lizaku:
你好!有没有一个基于Alligator+ EMA (233) + Stochastic指标 的机器人? 如果你能给我一个链接。你对这一战略的看法是什么?

移动平均线在这里显然是不必要的,因为 "鳄鱼 "已经包括了三条移动平均线。这就留下了Alligator + Stochastic。

鳄鱼+随机性

 
如何在脚本/顾问中检查指标计算 结束的事实,其中哪个被调用?到目前为止,我不得不把Sleep(),但我已经花了半天时间不明白为什么缓冲区的值是零......
 
它总是在午夜。
 
Aleksey Vyazmikin:
我如何在脚本/顾问中检查指标的计算 是否完成,以及哪个指标被调用?到目前为止,我不得不把Sleep(),但我已经花了半天时间不明白为什么缓冲区的值是零......

我使用以下循环

 int n = 0;
    do
     {
      // Пытаемся получить нужное значение;
      if(значение не получено)
       {
        n++;
        Sleep(100);
       }
     }
    while(значение не получено && n < 7 && !IsStopped());
 
Alexey Viktorov:

我使用这样的循环。

谢谢。我希望有一个标准的工具来处理这个问题,只是不清楚为什么缓冲区要填上零,然后把计算值放在那里--这样会出现一个缓冲区复制的错误,而且会很好。

 
Aleksey Vyazmikin:

谢谢你。我希望有一个内部工具来处理这个问题,只是不清楚为什么缓冲区要填上零,然后再把计算值放在那里--这样就会出现缓冲区复制错误,而且会很好。

我有内部工具,我曾经试图弄清楚,但无济于事。我现在甚至不记得在哪一节文档中提到了它。如果我没记错的话,是和同步化有关的。

 

下午好,我正在编写一个基于5段布林线的指标,作为最后一步,我开始编写与指标线 有关的形成模式的条件,但在测试过程中,我得到了2种变体:要么警报以某种方式自行关闭,要么什么都没有发生。这里有一个片段。

你能告诉我这里有什么可以解决的吗,如果有什么可以解决的话?

int OnCalculate (const int rates_total,      // размер входных таймсерий 
                 const int prev_calculated,  // обработано баров на предыдущем вызове 
                 const datetime& time[],     // Time
                 const double& open[],       // Open 
                 const double& high[],       // High 
                 const double& low[],        // Low 
                 const double& close[],      // Close 
                 const long& tick_volume[],  // Tick Volume 
                 const long& volume[],       // Real Volume 
                 const int& spread[])         // Spread 
 {
 
//----     
//--- переменные
   int pos; // позиция
   static datetime prevtime = 0;
   int shift1;
   int shift2;
   int shift3;
   string pattern, period;
   int setPattern = 0;
   int alert = 0;
   double O, O1, O2, C, C1, C2, L, L1, L2, H, H1, H2;   
  
//----

//----   
//--- check for bars count - проверка колчества баров
   if(rates_total<ExtPlotBegin)
      return(0);
//--- начало вычисления
   if(prev_calculated>1) pos=prev_calculated-1;
   else pos=0;
//--- главный цикл
   for(int i = pos ; i < rates_total;i++)
    {
      int shift = 0;
      shift1 = shift + 1;
      shift2 = shift + 2;
      shift3 = shift + 3;      
      O = open[shift1];
      O1 = open[shift2];
      O2 = open[shift3];
      H = high[shift1];
      H1 = high[shift2];
      H2 = high[shift3];
      L = low[shift1];
      L1 = low[shift2];
      L2 = low[shift3];
      C = close[shift1];
      C1 = close[shift2];
      C2 = close[shift3]; 
      //--- middle line
      ExtMLBuffer[i]=SimpleMA(i,ExtBandsPeriod,close);
      //--- calculate and write down StdDev
      ExtStdDevBuffer[i]=StdDev_Func(i,close,ExtMLBuffer,ExtBandsPeriod);
      //--- upper line
      ExtTLBuffer[i]=ExtMLBuffer[i]+ExtBandsDeviations*ExtStdDevBuffer[i];
      //--- mediumH line
      ExtMDHBuffer[i]=ExtMLBuffer[i]+ExtBandsDeviationsM*ExtStdDevBuffer[i];
      //--- mediumL line
      ExtMDLBuffer[i]=ExtMLBuffer[i]-ExtBandsDeviationsM*ExtStdDevBuffer[i];  
      //--- lower line
      ExtBLBuffer[i]=ExtMLBuffer[i]-ExtBandsDeviations*ExtStdDevBuffer[i];
     
      // Импульсная свеча от нижней границы Боллинджера
        if(((O <= H) && (H <= ExtMDLBuffer[i])) && ((L >= C) && (C <= ExtBLBuffer[i])))
        {
            Alert("Pin up!");
            PlaySound ("UpperBandAlert.wav"); 
         }
            Sleep(5000);
    }                  
//---- OnCalculate done. Return new prev_calculated. Расчет закончен, возврат к новым предыдущим барам
   return(rates_total);
  }
//+-
 

你好。

第一个位置的成交量=0.1,最后一个位置=0.2,如何获得 最后一个位置=0.2的成交量

在套期保值账户中,情况就是如此。

double Lot_pos_b()
  {
   int total=0;
   double lot=0;
   for(int i=PositionsTotal()-1;i>=0;i--)
      if(m_position.SelectByIndex(i)) // selects the position by index for further access to its properties
         if(m_position.Symbol()==m_symbol.Name() && m_position.Magic()==m_magic)
            if(m_position.PositionType()==POSITION_TYPE_BUY)
              {
               lot=m_position.Volume();
              }
//---
   return(lot);
  }
在一个净值账户上,我如何获得手数?这个函数返回0.3而不是0.2。
 
lil_lil:

你好。

第一个位置的成交量=0.1,最后一个位置=0.2,如何获得最后一个位置=0.2的成交量?

在一个对冲账户中,是这样的。

在净值账户中,如何获得手数?这个函数返回0.3而不是0.2。

查看属于该位置的交易,并查看其交易量。

只要打印一个头寸的所有发现的交易(每个头寸的属性)--弄清楚你需要在那里搜索什么。