Tutte le domande dei nuovi arrivati su MQL4 e MQL5, aiuto e discussione su algoritmi e codici - pagina 1359

 
azolotta:
OK, allora come faccio a rielaborare il codice se ho bisogno, per esempio, di selezionare il massimo più alto delle ultime 3 barre (che soddisfano le condizioni in if) e mettere un punto su di esso (proprio su questo alto!), quindi trovare anche il punto basso.

Prova in questo modo, ma non sono sicuro

//+------------------------------------------------------------------+
//|                                                           AZ.mq4 |
//|                        Copyright 2020, MetaQuotes Software Corp. |
//|                                             https://www.mql5.com |
//+------------------------------------------------------------------+
#property copyright "Anastasiya Zolotareva"
#property link      "insta"
#property version   "1.00"
#property strict
#property indicator_chart_window
#property indicator_buffers 5
//--- plot myAZ
#property indicator_label1  "myAZ"
#property indicator_color1  Black
#property indicator_color2  Blue
#property indicator_color3  Orange
#property indicator_color4  Blue
#property indicator_color5  Orange
#property indicator_style1 STYLE_SOLID
#property indicator_style2 STYLE_SOLID
#property indicator_style3 STYLE_SOLID
#property indicator_style4 STYLE_SOLID
#property indicator_style5 STYLE_SOLID
#property indicator_width1 1
#property indicator_width2 1
#property indicator_width3 1
#property indicator_width4 1
#property indicator_width5 1

extern int barsToProcess=200; //количество последних баров в истории
//--- indicator buffers
double myAZBuffer[];
double ExtHighBuffer01[];
double ExtLowBuffer01[];
double ExtHighBuffer02[];
double ExtLowBuffer02[];
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int OnInit()
  {
//---- drawing settings
   SetIndexStyle(0,DRAW_NONE);
   SetIndexStyle(1,DRAW_ARROW);
   SetIndexShift(1,-2);
   SetIndexStyle(2,DRAW_ARROW);
   SetIndexShift(2,-2);
   SetIndexStyle(3,DRAW_ARROW);
   SetIndexShift(3,-3);
   SetIndexStyle(4,DRAW_ARROW);
   SetIndexShift(4,-3);

//--- indicator buffers mapping
   SetIndexBuffer(0,myAZBuffer);
   SetIndexBuffer(1,ExtHighBuffer01);
   SetIndexBuffer(2,ExtLowBuffer01);
   SetIndexBuffer(3,ExtHighBuffer02);
   SetIndexBuffer(4,ExtLowBuffer02);
   IndicatorShortName("AZ");
//---
   return(0);
  }
//+------------------------------------------------------------------+
//|         deinit                                                         |
//+------------------------------------------------------------------+
int deinit()
  {
//----
  return(0);
  }
//+------------------------------------------------------------------+
//| 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-barsToProcess)<=0)return(0);
   int limit, val_index;
   if(barsToProcess>0) limit=barsToProcess; 
   else
   limit=rates_total-prev_calculated-barsToProcess-1;
  
   for(int n=limit;n>=0;n--)
     {
      if(Close[n+1]>Open[n+1] && Open[n+2]>=Close[n+2])
        {
         val_index=iLowest(NULL,0,MODE_LOW,3,n+1);
         myAZBuffer[n]=Low[val_index];
         ExtLowBuffer01[n]=Low[val_index];
        }
      else
      if(Open[n+1]>Close[n+1] && Close[n+2]>=Open[n+2])
        {
         val_index=iHighest(NULL,0,MODE_HIGH,3,n+1);
         myAZBuffer[n]=High[val_index];
         ExtHighBuffer01[n]=High[val_index];
        }
      else
      if(Close[n+1]>Open[n+1] && Open[n+3]>Close[n+3])
        {
         val_index=iLowest(NULL,0,MODE_LOW,3,n+1);
         myAZBuffer[n]=Low[val_index];
         ExtLowBuffer02[n]=Low[val_index];
        }
      else
      if(Close[n+1]<Open[n+1] && Close[n+3]>Open[n+3])
        {
         val_index=iHighest(NULL,0,MODE_HIGH,3,n+1);
         myAZBuffer[n]=High[val_index];
         ExtHighBuffer02[n]=High[val_index];
        }
     }
//--- return value of prev_calculated for next call
   return(rates_total);
  }
 
MakarFX:

Prova in questo modo, ma non sono sicuro

Sfortunatamente lo shift offset non è l'opzione giusta. Sto pensando che forse dovrei provare a inserire il mio codice in standard-zigzag. Lo sto provando ora, ma finora senza successo. Perché alla fine ho bisogno di trovare i vertici collegati alternativamente, come alto-basso-alto, e se incontro un'opzione alto-alto, o basso-basso, allora questi secondi alti e bassi non includere nell'array, e attendere il contrario.

 
azolotta:

Sfortunatamente, lo shift offset non è un'opzione adatta. Sto pensando che forse dovrei provare a inserire il mio codice nello zigzag standard. Ora sto curiosando, ma finora senza risultato. Pensi che sia possibile passare attraverso lo zigzag? Perché alla fine ho bisogno di collegare i top trovati alternativamente, come high-low-high, e se incontro un'opzione high-low, o low-low, allora questi secondi highs e lows non dovrebbero includere negli array, e aspettare il contrario.

No. Il precedente dovrebbe essere azzerato, e quello attuale dovrebbe essere aggiunto al buffer dell'indicatore.

 
azolotta:

Sfortunatamente, il cambio di marcia non è un'opzione. Sto pensando che forse dovrei provare a inserire il mio codice nello zigzag standard. Ora sto curiosando, ma finora senza risultato. Perché alla fine ho bisogno di trovare i vertici collegati alternativamente, come alto-basso-alto, e se incontro un'opzione alto-alto, o basso-basso, allora questi secondi alti e bassi non includere nell'array, e attendere il contrario.

In ogni caso, ci sarà un ritardo, cioè fino a quando le condizioni per 2-3 barre precedenti sono soddisfatte - non disegnerà.

Ho capito che abbiamo bisogno di uno zig-zag dall'alto al basso?
 
MakarFX:

In ogni caso, ci sarà un ritardo, cioè fino a quando le condizioni per 2-3 barre precedenti sono soddisfatte - non disegnerà.

Immagino di dover passare a zig-zag dagli alti ai bassi?

Sì, idealmente abbiamo bisogno di uno zig-zag dai massimi ai minimi (quindi questi alti e bassi sono nelle mie condizioni in if, e se ci sono due o più alti/bassi in fila, allora questi secondi alti/bassi non dovrebbero essere visualizzati, e dovremmo aspettare l'inversione). Mi basta visualizzare gli ultimi 6 minimi e 6 massimi nell'indicatore. E poi voglio chiamare questi punti trovati a zig-zag nello script/advisor per ulteriori necessità.

 

Ciao!

Qualcuno può consigliare perché nessun valore viene mostrato attraverso la modalità debug?

Sembra che dopo aver aggiornato il programma mt5, il problema sia iniziato

E cosa significa il rosso nella colonna - Valori?

 
Mikhail Toptunov:

Ciao!

Qualcuno può consigliare perché nessun valore viene mostrato attraverso la modalità debug?

Sembra che dopo aver aggiornato il programma mt5, il problema sia iniziato

E cosa significa il colore rosso del valore nella colonna - Values?

1. Si prega di fornire informazioni minime (le prime tre righe della scheda del diario dopo aver riavviato il terminale)

2) Aggiornare la costruzione

 
azolotta:

Sì, idealmente abbiamo bisogno di uno zig-zag dai massimi ai minimi (in modo che questi alti e bassi siano nelle mie condizioni in se, e se ci sono due o più alti/bassi in una fila, allora questi secondi alti/bassi non dovrebbero essere visualizzati, ma aspettare un'inversione). Mi basta visualizzare gli ultimi 6 minimi e 6 massimi nel mio indicatore. E poi voglio chiamare questi punti trovati a zig-zag nello script/advisor per ulteriori necessità.

Non sono un programmatore e non so ancora come aiutare, ma ci penserò...
 
MakarFX:
Non sono un programmatore e non so ancora come aiutare, ma ci penserò...
//+----------------------------------------------------------------------------+
//|  Автор    : Ким Игорь В. aka KimIV,                                                           |
//+----------------------------------------------------------------------------+
//|  Версия   : 07.10.2006                                                     |
//|  Описание : Возвращает экстремум ЗигЗага по его номеру.                    |
//+----------------------------------------------------------------------------+
//|  Параметры:                                                                |
//|    sy - наименование инструмента   (NULL или "" - текущий символ)          |
//|    tf - таймфрейм                  (      0     - текущий ТФ)              |
//|    ne - номер экстремума           (      0     - последний)               |
//|    dp - ExtDepth                                                           |
//|    dv - ExtDeviation                                                       |
//|    bs - ExtBackstep                                                        |
//+----------------------------------------------------------------------------+
double GetExtremumZZPrice(string sy="", int tf=0, int ne=0, int dp=12, int dv=5, int bs=3) {
  if (sy=="" || sy=="0") sy=Symbol();
  double zz;
  int    i, k=iBars(sy, tf), ke=0;

  for (i=1; i<k; i++) {
    zz=iCustom(sy, tf, "ZigZag", dp, dv, bs, 0, i);
    if (zz!=0) {
      ke++;
      if (ke>ne) return(zz);
    }
  }
  Print("GetExtremumZZPrice(): Экстремум ЗигЗага номер ",ne," не найден");
  return(0);
}

indicatoreZigZag standardpersonalizzato e restituisce il suo livello di prezzo. La funzione accetta i seguenti parametri opzionali:
  • sy- Nome dello strumento."" oNULL- simbolo corrente. Il valore predefinito èNULL.
  • tf- Timeframe. Valore predefinito 0- simbolo corrente.
  • ne- Numero estremo. 0- ultimo, 1- precedente, 2- precedente, ecc.
  • dp,dv,bs- parametri ZigZaga: ExtDepth, ExtDeviation, ExtBackstep.

Переход на новые рельсы: пользовательские индикаторы в MQL5
Переход на новые рельсы: пользовательские индикаторы в MQL5
  • www.mql5.com
Я не буду перечислять все новые возможности и особенности нового терминала и языка. Их действительно много, и некоторые новинки вполне достойны освещения в отдельной статье. Вы не увидите здесь кода, написанного по принципам объектно-ориентированного программирования — это слишком серьезная тема для того, чтобы просто быть упомянутой в контексте как дополнительная вкусность для кодописателей. В этой статье остановимся подробней на индикаторах, их строении, отображении, видах, а также особенностях их написания по сравнению с MQL4.
 
Iurii Tokman:

indicatoreZigZag standardpersonalizzato e restituisce il suo livello di prezzo. La funzione accetta i seguenti parametri opzionali:
  • sy- Nome dello strumento."" oNULL- simbolo corrente. Il valore predefinito èNULL.
  • tf- Timeframe. Valore predefinito 0- simbolo corrente.
  • ne- Numero estremo. 0- ultimo, 1- precedente, 2- precedente, ecc.
  • dp,dv,bs- parametri ZigZaga: ExtDepth, ExtDeviation, ExtBackstep.

questo non è adatto, avete bisogno di estremi non a zig-zag
Motivazione: