Странное поведение индикатора PivotPoints при вызове из советника или баг терминала ?

 

Всем салют !

Чет уже голову сломал на ровном месте.

Имеется стандартный индикатор PivotPoints.

#property copyright "Poul Trade Forum"
#property link      "http://forex.kbpauk.ru/"
//----
#property indicator_chart_window
//#property indicator_separate_window
#property indicator_buffers 7
#property indicator_color1 Orange
#property indicator_color2 DarkBlue
#property indicator_color3 Maroon
#property indicator_color4 DarkBlue
#property indicator_color5 Maroon
#property indicator_color6 Green
#property indicator_color7 Green
//---- input parameters
//---- buffers
double PBuffer[];
double S1Buffer[];
double R1Buffer[];
double S2Buffer[];
double R2Buffer[];
double S3Buffer[];
double R3Buffer[];
string Pivot="Pivot Point",Sup1="S 1", Res1="R 1";
string Sup2="S 2", Res2="R 2", Sup3="S 3", Res3="R 3";
int fontsize=10;
double P,S1,R1,S2,R2,S3,R3;
double LastHigh,LastLow,x;
//+------------------------------------------------------------------+
//| Custor indicator deinitialization function                       |
//+------------------------------------------------------------------+
int deinit()
  {
//---- TODO: add your code here
   ObjectDelete("Pivot");
   ObjectDelete("Sup1");
   ObjectDelete("Res1");
   ObjectDelete("Sup2");
   ObjectDelete("Res2");
   ObjectDelete("Sup3");
   ObjectDelete("Res3");
//----
   return(0);
  }
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int init()
  {
   string short_name;
//---- indicator line
   SetIndexStyle(0,DRAW_LINE,0,2,Orange);
   SetIndexStyle(1,DRAW_LINE,0,2,DarkBlue);
   SetIndexStyle(2,DRAW_LINE,0,2,Maroon);
   SetIndexStyle(3,DRAW_LINE,0,2,DarkBlue);
   SetIndexStyle(4,DRAW_LINE,0,2,Maroon);
   SetIndexStyle(5,DRAW_LINE,0,2,Green);
   SetIndexStyle(6,DRAW_LINE,0,2,Green);
   SetIndexBuffer(0,PBuffer);
   SetIndexBuffer(1,S1Buffer);
   SetIndexBuffer(2,R1Buffer);
   SetIndexBuffer(3,S2Buffer);
   SetIndexBuffer(4,R2Buffer);
   SetIndexBuffer(5,S3Buffer);
   SetIndexBuffer(6,R3Buffer);
//---- name for DataWindow and indicator subwindow label
   short_name="Pivot Point";
   IndicatorShortName(short_name);
   SetIndexLabel(0,short_name);
//----
   SetIndexDrawBegin(0,1);
//----
//----
   return(0);
  }
//+------------------------------------------------------------------+
//| Custom indicator iteration function                              |
//+------------------------------------------------------------------+
int start()
  {
   int    counted_bars=IndicatorCounted();
   int limit, i;
//---- indicator calculation
   if (counted_bars==0)
     {
      x=Period();
      if (x>240) return(-1);
      ObjectCreate("Pivot", OBJ_TEXT, 0, 0,0);
      ObjectSetText("Pivot", "                 Pivot Point",fontsize,"Arial",Red);
      ObjectCreate("Sup1", OBJ_TEXT, 0, 0, 0);
      ObjectSetText("Sup1", "      S 1",fontsize,"Arial",Red);
      ObjectCreate("Res1", OBJ_TEXT, 0, 0, 0);
      ObjectSetText("Res1", "      R 1",fontsize,"Arial",Red);
      ObjectCreate("Sup2", OBJ_TEXT, 0, 0, 0);
      ObjectSetText("Sup2", "      S 2",fontsize,"Arial",Red);
      ObjectCreate("Res2", OBJ_TEXT, 0, 0, 0);
      ObjectSetText("Res2", "      R 2",fontsize,"Arial",Red);
      ObjectCreate("Sup3", OBJ_TEXT, 0, 0, 0);
      ObjectSetText("Sup3", "      S 3",fontsize,"Arial",Red);
      ObjectCreate("Res3", OBJ_TEXT, 0, 0, 0);
      ObjectSetText("Res3", "      R 3",fontsize,"Arial",Red);
     }
   if(counted_bars<0) return(-1);
//---- last counted bar will be recounted
   //   if(counted_bars>0) counted_bars--;
   limit=(Bars-counted_bars)-1;
//----   
   for(i=limit; i>=0;i--)
     {
      if (High[i+1]>LastHigh) LastHigh=High[i+1];
      if (Low[i+1]<LastLow) LastLow=Low[i+1];
      if (TimeDay(Time[i])!=TimeDay(Time[i+1]))
        {
         P=(LastHigh+LastLow+Close[i+1])/3;
         R1=(2*P)-LastLow;
         S1=(2*P)-LastHigh;
         R2=P+(LastHigh - LastLow);
         S2=P-(LastHigh - LastLow);
         R3=(2*P)+(LastHigh-(2*LastLow));
         S3=(2*P)-((2* LastHigh)-LastLow);
         LastLow=Open[i]; LastHigh=Open[i];
//----
         ObjectMove("Pivot", 0, Time[i],P);
         ObjectMove("Sup1", 0, Time[i],S1);
         ObjectMove("Res1", 0, Time[i],R1);
         ObjectMove("Sup2", 0, Time[i],S2);
         ObjectMove("Res2", 0, Time[i],R2);
         ObjectMove("Sup3", 0, Time[i],S3);
         ObjectMove("Res3", 0, Time[i],R3);
        }
      PBuffer[i]=P;
      S1Buffer[i]=S1;
      R1Buffer[i]=R1;
      S2Buffer[i]=S2;
      R2Buffer[i]=R2;
      S3Buffer[i]=S3;
      R3Buffer[i]=R3;
     }
//----
   return(0);
  }
//+------------------------------------------------------------------+

Я считываю в тестере значения P на M15 вначале каждого нового бара.

P[0]= NormalizeDouble( iCustom(Symbol(),0,"Pivot",0,0),Digits );

На выходе получается такая непонятка. Первый день выдает нормальные результаты а со второго и последующих только на барах со временем 0:00. На 0:15 появляются какие то "левые" значения и так до конца дня. Причем отрисовывается индикатор как положено.

0    23:53:39    2015.07.22 00:15  MyPivot GBPUSD,M15:   P=1.55571
0    23:53:39    2015.07.22 00:30  MyPivot GBPUSD,M15:   P=1.55571
0    23:53:39    2015.07.22 00:45  MyPivot GBPUSD,M15:   P=1.55571
0    23:53:39    2015.07.22 01:00  MyPivot GBPUSD,M15:   P=1.55571
.........
..........
0    23:53:39    2015.07.22 23:30  MyPivot GBPUSD,M15:   P=1.55571
0    23:53:39    2015.07.22 23:45  MyPivot GBPUSD,M15:   P=1.55571
0    23:53:39    2015.07.23 00:00  MyPivot GBPUSD,M15:   P=1.55999
0    23:53:39    2015.07.23 00:15  MyPivot GBPUSD,M15:   P=1.56111
0    23:53:39    2015.07.23 00:30  MyPivot GBPUSD,M15:   P=1.56111
0    23:53:39    2015.07.23 00:45  MyPivot GBPUSD,M15:   P=1.56111
0    23:53:39    2015.07.23 01:00  MyPivot GBPUSD,M15:   P=1.56111

0    23:53:39    2015.07.23 01:15  MyPivot GBPUSD,M15:   P=1.56111

0    23:53:39    2015.07.23 01:30  MyPivot GBPUSD,M15:   P=1.56111

......


Решил исследовать поведение индикатора Pivot при вызове из советника.

Добавил код в советник.

Print("  P=",P[i], "  timeDay0=", TimeDay(Time[0]),"  timeDay1=", TimeDay(Time[1])); 

И такой код в индикатор.

......
if (TimeDay(Time[i])!= TimeDay(Time[i+1]))
   {
   Print ("Timei=", TimeDay(Time[i]), "  Time.i+1=", TimeDay(Time[i+1]),"   P=",P); 
   P=(LastHigh+LastLow+Close[i+1])/3;
   R1 = (2*P)-LastLow;
   S1 = (2*P)-LastHigh;
.......


Получилось на выходе вот такое

0    18:45:42    2015.07.23 21:30  MyPivot GBPUSD,M15:   P=1.55999  timeDay0=23  timeDay1=23
0    18:45:42    2015.07.23 21:45  MyPivot GBPUSD,M15:   P=1.55999  timeDay0=23  timeDay1=23
0    18:45:42    2015.07.23 22:00  MyPivot GBPUSD,M15:   P=1.55999  timeDay0=23  timeDay1=23
0    18:45:42    2015.07.23 22:15  MyPivot GBPUSD,M15:   P=1.55999  timeDay0=23  timeDay1=23
0    18:45:42    2015.07.23 22:30  MyPivot GBPUSD,M15:   P=1.55999  timeDay0=23  timeDay1=23
0    18:45:42    2015.07.23 22:45  MyPivot GBPUSD,M15:   P=1.55999  timeDay0=23  timeDay1=23
0    18:45:42    2015.07.23 23:00  MyPivot GBPUSD,M15:   P=1.55999  timeDay0=23  timeDay1=23
0    18:45:42    2015.07.23 23:15  MyPivot GBPUSD,M15:   P=1.55999  timeDay0=23  timeDay1=23
0    18:45:42    2015.07.23 23:30  MyPivot GBPUSD,M15:   P=1.55999  timeDay0=23  timeDay1=23
0    18:45:42    2015.07.23 23:45  MyPivot GBPUSD,M15:   P=1.55999  timeDay0=23  timeDay1=23
0    18:45:42    2015.07.24 00:00  Pivot_fix GBPUSD,M15: Timei=24  Time.i+1=23   P=1.56
0    18:45:42    2015.07.24 00:00  MyPivot GBPUSD,M15:   P=1.5561  timeDay0=24  timeDay1=23
0    18:45:42    2015.07.24 00:15  Pivot_fix GBPUSD,M15: Timei=24  Time.i+1=23   P=1.5561
0    18:45:42    2015.07.24 00:15  MyPivot GBPUSD,M15:   P=1.55128  timeDay0=24  timeDay1=24
0    18:45:42    2015.07.24 00:30  MyPivot GBPUSD,M15:   P=1.55128  timeDay0=24  timeDay1=24

0    18:45:42    2015.07.24 00:45  MyPivot GBPUSD,M15:   P=1.55128  timeDay0=24  timeDay1=24

То есть советник определяет дату правильно а индикатор при вызове глючит и попадает снова в процедуру расчета PP. Как так получается не пойму.
 

>> P[0]= NormalizeDouble( iCustom(Symbol(),0,"Pivot",0,0),Digits );

У Вас в терминале индикатор как называется, "Pivot"?

 
drknn:

>> P[0]= NormalizeDouble( iCustom(Symbol(),0,"Pivot",0,0),Digits );

У Вас в терминале индикатор как называется, "Pivot"?

Да. Вариант Fix такой же только с пропуском "воскресных" баров вот и всё.

Я вроде разобрался в чем дело. Ошибка эта возникает только в тестере. Онлайн всё работает отлично. При обращении к индикатору тестер рассчитывает сразу 1000 баров.

Потом по мере продвижения переменная counted_bars начинает возрастать но увеличивается и количество Bars. Переменная limit при этом получается всё время равна "1". В результате процедура попытки пересчета PP выполняется 2 раза. Причем на второй раз происходит тот самый глюк с определением даты. Почему не знаю :-). Наверное все таки баг но я не уверен.

Вылечил я это заменой "1" на "2" в строке. Хорошо бы разработчики это как то откомментировали......

limit=(Bars-counted_bars)-2;
 
goodearth:


Хорошо бы разработчики это как то откомментировали......

Разработчики чего?

Обратитесь к автору пользовательского индикатора "Pivot". Этот индикатор не является стандартным и не входит в комплект поставки даже в виде примера

 
stringo:

Разработчики чего?

Обратитесь к автору пользовательского индикатора "Pivot". Этот индикатор не является стандартным и не входит в комплект поставки даже в виде примера

Разработчики всего :))) Процедура расчета PP имеется в примере в руководстве пользователя MT4. Но она там "голая" просто ).

В общем это чисто алгоритмическая ошибка. Я вспомнил что утром и на графике была такая же лабуда которая появляется в тестере.

Как я уже писал процедура пересчета PP выполняется 2 раза а должна 1. Поэтому в тестере и онлайн возникает описанный выше косяк который не проявляется когда первый раз "бросаешь" индюк на котировки.

Так что всем спасибо. Я как обычно сам задал вопрос и сам же на него ответил ))).

З.Ы. Кстати хорошо бы индикатор PP был хотя бы в качестве нормального рабочего примера в MT4. Он ведь довольно широко используется.....

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