È possibile trovare programmaticamente TUTTI i canali orizzontali/float in un certo intervallo di tempo o almeno formulare correttamente il ToR? - pagina 7

 
Rayder69:

Ecco uno script che non riesco a ricordare dove o quando l'ho trovato.

Forse qualcuno potrebbe usarlo?


Cosa fa?
 
Inserite nella variabile il tipo di flop che vi interessa durante tutta la storia e vi dà il flop più lungo nel numero di pip specificato, quando e quanto è durato.
 

Grazie

 
Rayder69:
Si inserisce nella variabile quale flip in pip si è interessati in tutta la storia, e ti dà il flip più lungo nel numero specificato di pip, quando e quanto tempo è durato.


Errore: lo script non può funzionare su questo grafico.

Cosa sto facendo di sbagliato?

 
Non posso dirlo. Per me funziona bene. L'ho messo nella cartella experts/scripts e tutto funziona bene, che si tratti di valute o futures.
 
non funziona su cinque cifre
 
alsu:
non funziona su cinque cifre

è possibile aggiustarlo? e oso chiedere di mettere nelle variabili l'intervallo di tempo in cui cerca un piatto
 
sever30:

e oso chiedere di mettere nelle variabili l'intervallo di tempo in cui si cerca un piatto
//////////////////////////////////////////////////////////////////////
//   ПОИСК САМОГО ДЛИННОГО ФЛЕТА ПО ВРЕМЕНИ      +111.mq4           //
//////////////////////////////////////////////////////////////////////
#property show_inputs  
  extern int ПУНКТЫ=300;
  extern datetime НАЧАЛО=D'2010.9.3';
  extern datetime КОНЕЦ=D'2010.1.1';
//----------Переменные для вывода данных--------------  
  int FBars,          //кол-во баров в коридоре      
      SiftBars;       //индекс бара
  double PriceMin,    //минимум коридора
         PriceMax;    //максимум коридора
//----------------------------------------------------
int init()
  {
   НАЧАЛО=iBarShift(0,0,НАЧАЛО);
   КОНЕЦ=iBarShift(0,0,КОНЕЦ);
  }
//----------------------------------------------------
int start()
  {
   int i,n,D,ST,Bar;
//----
   Alert("*********************");
   int Shift_Min=iLowest(Symbol(),0,MODE_LOW,Bars,0);     //Находим индекс минимального бара
   int Shift_Max=iHighest(Symbol(),0,MODE_HIGH,Bars,0);   //Находим индекс максимального бара
   double Min=iLow(Symbol(),0,Shift_Min);                 //Находим минимум на графике
   double Max=iHigh(Symbol(),0,Shift_Max);                //Нходим максимум на графике
   double Z=(Max-Min)/Point;             //Растояние в пунктах от минимума до максимума на всем графике
   double W=Z-ПУНКТЫ;                //Переменная W нужна для ограничения бесполезных циклов по ценам ось(Y)  
//--------------------------------------------------------   
   for (i=0;i<=W;i++)//Цикл по ценам ось(Y) 
    { 
     ST=0;                                
     for(n=НАЧАЛО;n<=КОНЕЦ&&n<Bars;n++)//Цикл по барам ось(X)
      {
       if(Low[n]>Min && High[n]<Min+ПУНКТЫ*Point)
        {
         if(ST==0)
          {
           Bar=n;
          }
         ST++;
        }else
        {
         if(FBars<ST)
          {
           FBars=ST;                   //Сохраним кол-во баров в коридоре
           PriceMin=Min;               //Сохраним минимум коридора
           PriceMax=Min+ПУНКТЫ*Point;  //Сохраним максимум коридора
           SiftBars=Bar;               //Сохраним индекс бара
           ST=0;                       //Обнуляем счетчик
          }else
          {
           ST=0;                       //Обнуляем счетчик
          }
        }
      }
     Min+=1*Point;                     //Сдвигаем коридор на один пункт вверх                   
    }
//--------------------- ВЫВОД ДАННЫХ --------------------
   ObjectDelete("q9w8e5");
   ObjectCreate("q9w8e5",OBJ_RECTANGLE,0,Time[SiftBars],PriceMin,Time[SiftBars+FBars],PriceMax);
   
   datetime Нач=Time[SiftBars+FBars];
   datetime Кон=Time[SiftBars];
   
   Alert("Самый длинны флет в ",ПУНКТЫ," пунктов был с ",TimeDay(Нач),".",TimeMonth(Нач),".",TimeYear(Нач),"   ",TimeHour(Нач),":",TimeMinute(Нач),
        "  по ",TimeDay(Кон),".",TimeMonth(Кон),".",TimeYear(Кон),"   ",TimeHour(Кон),":",TimeMinute(Кон),"    Цена :  MAX = ",PriceMax,"  MIN = ",PriceMin,
        "   Кол-во баров в коридоре = ",FBars,"       :)"); 
   
   return(0);
  }
//+------------------------------------------------------------------+
 
sever29:

Se vuoi usare lo script per valutare la performance di EAs simili a valanghe, questo è adatto solo per una valanga classica con canali stazionari. Se si utilizzano canali non stazionari, i triangoli divergenti sono i più pericolosi in questo caso.
 
khorosh:
Se vuoi usare lo script per valutare la performance di EAs simili a valanghe, questo è adatto solo per una valanga classica con canali stazionari. Se si utilizzano canali non stazionari, i triangoli divergenti sono i più pericolosi in questo caso.
I canali stazionari sono un canale con due confini paralleli?