Вопросы от начинающих MQL5 MT5 MetaTrader 5 - страница 1253

 
Vladimir Karputov:

Оптимизация выполняется АГЕНТАМИ (в вашем случае - ЛОКАЛЬНЫМИ АГЕНТАМИ).

Чтобы просмотреть логи локальных агентов: правый клик во вкладке Журнал и перейти в папку агента

В том то и дело что нет ошибок. Все считается.  Может какие то файерволы или еще что то?

Файлы:
 
Aleksandr Dziuba:

В том то и дело что нет ошибок. Все считается.  Может какие то файерволы или еще что то?

Запустите одиночное тестирование - одиночный проход. Не оптимизацию, а одиночный проход. Так точно будет виден лог.

 
Vladimir Karputov:

Запустите одиночное тестирование - одиночный проход. Не оптимизацию, а одиночный проход. Так точно будет виден лог.

В смысле визуальный? Ну вот лог  получил. Ничего там не видно плохого. Параметры все переданы. Даже он выполнился. а выход Баланс как был 20000 так и остался.

Файлы:
20200924.log  17 kb
 
Aleksandr Dziuba:

В смысле визуальный? Ну вот лог  получил. Ничего там не видно плохого. Параметры все переданы. Даже он выполнился. а выход Баланс как был 20000 так и остался.

Значит измените код так, чтобы он выдавал при ошибках сообщения об ошибках или если невозможно выполнить торговую операцию. Или вообще код ошибочный и не даёт сигналов. Чудес не бывает. 

Документация по MQL5: Константы, перечисления и структуры / Коды ошибок и предупреждений / Ошибки компиляции
Документация по MQL5: Константы, перечисления и структуры / Коды ошибок и предупреждений / Ошибки компиляции
  • www.mql5.com
Импортируемая функция не может иметь такого параметра (нельзя передавать указатель, класс или структуру, содержащую динамический массив, указатель, класс и т.д.) Недопустимый возвращаемый тип. Например, такая ошибка будет выдана для функций, импортированных из...
 
Vladimir Karputov:

Значит измените код так, чтобы он выдавал при ошибках сообщения об ошибках или если невозможно выполнить торговую операцию. Или вообще код ошибочный и не даёт сигналов. Чудес не бывает. 

Ага. 

В общем не входит оптимизация в Ontick. OnInit обрабатываеся. А On Tick не генерируется. В чем проблема. 

Поставил точки Print ( ) во входах и выходах.  В лог записывается только Init. 

P.S.

Ошибки обрабатываю. Привычка. Пишу программы с 1987 года. 

 
Aleksandr Dziuba:

Ага. 

В общем не входит оптимизация в Ontick. OnInit обрабатываеся. А On Tick не генерируется. В чем проблема. 

Поставил точки Print ( ) во входах и выходах.  В лог записывается только Init. 

P.S.

Ошибки обрабатываю. Привычка. Пишу программы с 1987 года. 

Без кода помочь смогут только телепаты - а сейчас, как назло, все телепаты в отпуске.

 
Vladimir Karputov:

Без кода помочь смогут только телепаты - а сейчас, как назло, все телепаты в отпуске.

Нашел причину. По какой то причине не происходит пересчет индикаторов в Ontick( не выдает количество пересчитанных баров) . Может нужно обновлять котировки. 

Все равно спасибо. Стал умнее. Узнал где логи пишутся.  

 

Конвертировал простой индикатор с MQL4 -> MQL5, но на последних нескольких барах нет сигнала. Помогите пожалуйста найти причину. Исходный код и результат в аттаче. Конвертированный еще и сюда вложу.

#property indicator_chart_window
#property indicator_plots   4
#property indicator_buffers 4
#property indicator_color1 PaleVioletRed
#property indicator_color2 DeepSkyBlue
#property indicator_color3 Red
#property indicator_color4 LimeGreen

input int  dist2           = 21;       // Distance#2
input int  dist1           = 14;       // Distance#1

double b1[];
double b2[];
double b3[];
double b4[];

int    handle_atr;
int    min_rates_total;
double atr[];

//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int OnInit() {

   SetIndexBuffer(0,b1,INDICATOR_DATA);
   SetIndexBuffer(1,b2,INDICATOR_DATA);
   SetIndexBuffer(2,b3,INDICATOR_DATA);
   SetIndexBuffer(3,b4,INDICATOR_DATA);
   
   ArraySetAsSeries(b1,true);
   ArraySetAsSeries(b2,true);
   ArraySetAsSeries(b3,true);
   ArraySetAsSeries(b4,true);

   PlotIndexSetInteger(0,PLOT_DRAW_TYPE,DRAW_LINE);
   PlotIndexSetInteger(1,PLOT_DRAW_TYPE,DRAW_LINE);
   PlotIndexSetInteger(2,PLOT_DRAW_TYPE,DRAW_ARROW);
   PlotIndexSetInteger(3,PLOT_DRAW_TYPE,DRAW_ARROW);

      PlotIndexSetInteger(2,PLOT_ARROW,159);
      PlotIndexSetInteger(3,PLOT_ARROW,159);
   
   ResetLastError();
   handle_atr = iATR(NULL,PERIOD_CURRENT,50);
   if(handle_atr==INVALID_HANDLE) {
      Print("   ***   ATR handle was unable to create. Error ",GetLastError());
      return INIT_FAILED;
   }

   PlotIndexSetDouble(0,PLOT_EMPTY_VALUE,EMPTY_VALUE);
   PlotIndexSetDouble(1,PLOT_EMPTY_VALUE,EMPTY_VALUE);
   PlotIndexSetDouble(2,PLOT_EMPTY_VALUE,EMPTY_VALUE);
   PlotIndexSetDouble(3,PLOT_EMPTY_VALUE,EMPTY_VALUE);
   
   PlotIndexSetString(0,PLOT_LABEL,"SuperSignals Upper");
   PlotIndexSetString(1,PLOT_LABEL,"SuperSignals Lower");
   PlotIndexSetString(2,PLOT_LABEL,"SuperSignals Sell");
   PlotIndexSetString(3,PLOT_LABEL,"SuperSignals Buy");

        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[]) {
                
   int counted_bars=prev_calculated;
   int i,limit;
   
   ArraySetAsSeries(Low,true);
   ArraySetAsSeries(High,true);

   if(counted_bars<0) return 0;
   if(counted_bars>0) counted_bars--;
           limit=rates_total-counted_bars;
           limit=MathMax(limit,dist1);
           limit=MathMax(limit,dist2);

   for (i = limit-1; i >= 0; i--) {
         int hhb1 = ArrayMaximum(High,i-dist1/2,dist1);
         int llb1 = ArrayMinimum(Low, i-dist1/2,dist1);
         int hhb  = ArrayMaximum(High,MathMax(0,i-dist2/2),dist2);
         int llb  = ArrayMinimum(Low, MathMax(0,i-dist2/2),dist2);

            b1[i] = EMPTY_VALUE;
            b2[i] = EMPTY_VALUE;
            b3[i] = EMPTY_VALUE;
            b4[i] = EMPTY_VALUE;
         
         ArraySetAsSeries(atr,true);
         int copied=CopyBuffer(handle_atr,0,0,limit,atr);
         if (copied<=0) Print("   ***   ATR failed to copy.");
         double tr = atr[i];

                      b1[i] = High[hhb];
                      b2[i] = Low[llb];
         if (i==hhb1) b3[i] = High[hhb1]+tr/2;
         if (i==llb1) b4[i] = Low[llb1] -tr/2;
    }
   
   return rates_total;
}
//+------------------------------------------------------------------+

Результат.


 
Grigori.S.B:

Конвертировал простой индикатор с MQL4 -> MQL5, но на последних нескольких барах нет сигнала. Помогите пожалуйста найти причину. Исходный код и результат в аттаче. Конвертированный еще и сюда вложу.

Результат.


Вроде как виновником может быть что-то не логично сделанное между платформами 

Обратите внимание на разные входные параметры

МТ4

ArrayMaximum
Ищет в одномерном числовом массиве максимальный элемент.

int  ArrayMaximum(
   const void&   array[],             // массив для поиска
   int           count=WHOLE_ARRAY,   // количество проверяемых
   int           start=0              // с какого индекса начинаем поиск
   );

МТ5

ArrayMaximum
Ищет максимальный элемент в первом измерении многомерного числового массива.

int  ArrayMaximum(
   const void&   array[],             // массив для поиска
   int           start=0,             // с какого индекса начинаем поиск
   int           count=WHOLE_ARRAY    // количество проверяемых
   );
 
Vitaly Muzichenko:

Вроде как виновником может быть что-то не логично сделанное между платформами 

Обратите внимание на разные входные параметры

МТ4

МТ5

Спасибо, Виталий. 

В этом месте порядок переменных правильный, я их поменял местами при конвертации. Да и в MQL4 версии были функции iHighest / iLowest. 

Тут что-то другое. Уже всю голову сломал.

Причина обращения: