ある時間間隔で水平方向の全チャンネル/フロートをプログラム的に見つけることは可能でしょうか、少なくともToRを正しく定式化することは可能でしょうか。 - ページ 7

 
Rayder69:

ここで、いつどこで見つけたか覚えていないスクリプトを紹介します。

もしかしたら、誰かが使ってくれるかもしれない!?


何をするものなのか?
 
全履歴の中でどのようなフロップに興味があるかを変数に入力すると、指定したpips数の中で最も長いフロップを、いつ、どれくらいの時間続いたかを教えてくれます。
 

ありがとうございました。

 
Rayder69:
履歴の中で何pipsのフリップに興味があるかを変数に入力すると、指定したpips数のフリップが、いつ、どのくらい続いたかを教えてくれるのです。


エラー: スクリプトはこのチャートでは動作しません。

私は何を間違えているのだろう?

 
言えません。私の場合は問題なく使えています。experts/scriptsフォルダに入れたら、通貨でも先物でもすべて正常に動作するようになりました。
 
alsu:
5桁では動作しない

また、フラットな状態を探す時間間隔を変数に入れるようお願いします。
 
sever30:

を探す時間間隔を変数に入れるようお願いします。
//////////////////////////////////////////////////////////////////////
//   ПОИСК САМОГО ДЛИННОГО ФЛЕТА ПО ВРЕМЕНИ      +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:

雪崩型EAの性能を評価するためにスクリプトを使用したい場合、これは静止チャンネルを持つ古典的な雪崩にのみ適しています。非定常なチャンネルを使用する場合、発散する三角形はこの場合最も危険である。
 
khorosh:
雪崩型EAの性能を評価するためにスクリプトを使用したい場合、これは静止チャンネルを持つ古典的な雪崩にのみ適しています。非定常なチャンネルを使用する場合、発散する三角形はこの場合最も危険である。
定常水路とは、平行な2つの境界を持つ水路のことでしょうか?