Quaisquer perguntas de recém-chegados sobre MQL4 e MQL5, ajuda e discussão sobre algoritmos e códigos - página 1306

 

Por favor, ajude-me, adicionei mais um buffer ao indicador (duplo ma_buffer_stop[];), mas ele não desenha ou dá erros(

//+------------------------------------------------------------------+
//|                                                   MTF_Moving.mq4 |
//|                        Copyright 2017, MetaQuotes Software Corp. |
//|                             https://www.mql5.com/ru/users/melnik |
//+------------------------------------------------------------------+
#property copyright "Copyright 2017, MetaQuotes Software Corp."
#property link      "https://www.mql5.com/ru/users/melnik"
#property version   "1.00"
#property strict
#property indicator_chart_window
#property indicator_buffers 3
#property indicator_width1 2
#property indicator_width2 2
#property indicator_width3 2
#property indicator_color1 Red
#property indicator_color2 Blue
#property indicator_color3 Black
#property indicator_type1 DRAW_LINE
#property indicator_type2 DRAW_LINE
#property indicator_type3 DRAW_LINE

double ma_buffer_slow[];
double ma_buffer_fast[];
double ma_buffer_stop[];

//--- input parameters
input int                     PeriodMaSlow=21;  //Period slow Ma
input int                     PeriodMaFast=13;  //Pertiod fast Ma
input ENUM_APPLIED_PRICE      PriceMa=0;        //Applied price
input ENUM_MA_METHOD          MethodMa=0;       //Method Ma
input ENUM_TIMEFRAMES         Timeframe=60;     //Timeframe for calculate

ENUM_TIMEFRAMES prd;

int index=-1;
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int OnInit()
  {
//--- indicator buffers mapping
   SetIndexBuffer(0, ma_buffer_slow, INDICATOR_DATA);
   SetIndexBuffer(1, ma_buffer_fast, INDICATOR_DATA);
   SetIndexBuffer(2, ma_buffer_stop, INDICATOR_DATA);
//---
   return(INIT_SUCCEEDED);
  }
//+------------------------------------------------------------------+
//| Custom indicator iteration function                              |
//+------------------------------------------------------------------+
int OnCalculate(const int rates_total,
                const int prev_calculated,
                const datetime &time[],
                const double &open[],
                const double &high[],
                const double &low[],
                const double &close[],
                const long &tick_volume[],
                const long &volume[],
                const int &spread[])
  {
//---
   if((rates_total-prev_calculated-PeriodMaSlow)<=0)return(0);
  
   if(Period()>Timeframe) prd=PERIOD_CURRENT;
   if(Period()<=Timeframe) prd=prd=Timeframe;
  
   for(int i=rates_total-prev_calculated-PeriodMaSlow-1;i>=0;i--)
   {
      if(TimeMinute(time[i])==0)index=iBarShift(Symbol(), prd, time[i], false);
      
      ma_buffer_fast[i]=iMA(Symbol(), prd, PeriodMaFast, 0, MethodMa, PriceMa, index);
      ma_buffer_slow[i]=iMA(Symbol(), prd, PeriodMaSlow, 0, MethodMa, PriceMa, index);
      if(ma_buffer_fast[i+1]>=ma_buffer_slow[i+1]&&ma_buffer_fast[i]<ma_buffer_slow[i])
      {ma_buffer_stop[i]=ma_buffer_slow[i]+50*Point;}
      if(ma_buffer_fast[i+1]<=ma_buffer_slow[i+1]&&ma_buffer_fast[i]>ma_buffer_slow[i])
      {ma_buffer_stop[i]=ma_buffer_slow[i]-50*Point;}
   }
  
//--- return value of prev_calculated for next call
   return(rates_total);
  }
//+------------------------------------------------------------------+
 

Cheque, estamos sequer entrando aqui?

if(ma_buffer_fast[i+1]>=ma_buffer_slow[i+1]&&ma_buffer_fast[i]<ma_buffer_slow[i]) printf(ma_buffer_slow[i]);
isso é apenas a primeira coisa que me vem à mente.
 

Às vezes eu pego a divisão a zero. (Qualquer coisa pode acontecer na dinâmica).

Procuro isso comentando as operações de divisão e colocando a EA no gráfico.

Há alguma maneira de obter o fio com o erro usando métodos mais normais?

O problema é que o erro ocorre apenas em um determinado estado. Isto é, o erro pode desaparecer em um determinado período de tempo e com uma vela nova. É bom quando você percebe isso às 4 horas. Há tempo para encontrá-lo.

 
Valeriy Yastremskiy:

Existe alguma maneira de se obter a linha com o erro usando métodos mais convencionais?

Você deve ter uma entrada no registro de especialista com o arquivo e o número da linha onde ocorreu a divisão por zero

 
Igor Makanu:

Você deve ter uma entrada em seu registro de consultor especializado com o arquivo e o número da linha onde ocorreu a divisão por zero

2020.11.27 11:55:29.795 qstr7_52_1 EURUSD,H4: divisão zero em 'qstr7_52_1.mq4' (962,43)

Somente isto.

962,43 no entanto.

Aí está)))) Obrigado!!!!!


 
Aleksei Stepanenko:

Estamos sequer entrando aqui?

logo no topo da minha cabeça.

Indo para

Se eu fizer isso, ele desenha

   double prev01,prev02;

   if((rates_total-prev_calculated-PeriodMaSlow)<=0)return(0);
  
   if(Period()>Timeframe) prd=PERIOD_CURRENT;
   if(Period()<=Timeframe) prd=prd=Timeframe;
  
   for(int i=rates_total-prev_calculated-PeriodMaSlow-1;i>=0;i--)
   {
      if(TimeMinute(time[i])==0)index=iBarShift(Symbol(), prd, time[i], false);
      
      ma_buffer_fast[i]=iMA(Symbol(), prd, PeriodMaFast, 0, MethodMa, PriceMa, index);
      ma_buffer_slow[i]=iMA(Symbol(), prd, PeriodMaSlow, 0, MethodMa, PriceMa, index);
      prev01=iMA(Symbol(), prd, PeriodMaFast, 0, MethodMa, PriceMa, index+1);
      prev02=iMA(Symbol(), prd, PeriodMaSlow, 0, MethodMa, PriceMa, index+1);
      if(prev01>=prev02&&ma_buffer_fast[i]<ma_buffer_slow[i])
      {ma_buffer_stop[i]=ma_buffer_slow[i]+50*Point;}
      if(prev01<=prev02&&ma_buffer_fast[i]>ma_buffer_slow[i])
      {ma_buffer_stop[i]=ma_buffer_slow[i]-50*Point;}
   }
  
 

Esta matriz só tem os valores corretos nos pontos de cruzamento, em outros lugares seu valor é VAZIO_VALOR. Portanto, nada é visível. Você precisa inserir uma variável global e atribuir-lhe valores no momento da intersecção. E já dará o valor atual no momento da intersecção, ou o valor passado quando não houver intersecção.

double Stop=0;
int OnCalculate(....

if(ma_buffer_fast[i+1]>=ma_buffer_slow[i+1]&&ma_buffer_fast[i]<ma_buffer_slow[i]) Stop=ma_buffer_slow[i]+50*Point;
if(ma_buffer_fast[i+1]<=ma_buffer_slow[i+1]&&ma_buffer_fast[i]>ma_buffer_slow[i]) Stop=ma_buffer_slow[i]-50*Point;

ma_buffer_stop[i]=Stop;
 
Aleksei Stepanenko:

Esta matriz só tem os valores corretos nos pontos de cruzamento, em outros lugares seu valor é VAZIO_VALOR. Portanto, nada é visível. Você precisa inserir uma variável global e atribuir-lhe valores no momento da intersecção. E já dará o valor atual no momento da intersecção, ou o valor passado quando não houver intersecção.

Obrigado, funcionou)

 
É possível forçar uma mudança de prazo se a função indicadora ainda estiver em funcionamento?
 
Aleksei Stepanenko:

Esta matriz só tem os valores corretos nos pontos de cruzamento, em outros lugares seu valor é VAZIO_VALOR. Portanto, nada é visível. Você precisa inserir uma variável global e atribuir-lhe valores no momento da intersecção. E já dará o valor atual no momento da intersecção, ou o valor passado quando não houver intersecção.

Eu multipliquei o PeríodoMaSlow por 2

   if((rates_total-prev_calculated-PeriodMaSlow)<=0)return(0);
  
   if(Period()>Timeframe) prd=PERIOD_CURRENT;
   if(Period()<=Timeframe) prd=prd=Timeframe;
  
   for(int i=rates_total-prev_calculated-PeriodMaSlow-1;i>=0;i--)

e o código inicial funciona sem erros