найти ближайшую дату - страница 2

 
angevoyageur:

Что-то вроде этого?

Только одно из решений среди других.

Что-то не так... Я могу использовать его только на тиковых данных, иначе предыдущий максимум всегда =-1.

Но главная проблема в том, что и на тиковых данных иногда без причины предыдущий максимум меняется на =-1.

Еще раз спасибо за поддержку

doc

 
dr.house7:

Что-то не так... Я могу использовать его только на тиковых данных, иначе предыдущий максимум всегда =-1.

Но главная проблема в том, что и на тиковых данных иногда без причины предыдущий максимум меняется на =-1.

Еще раз спасибо за поддержку

doc

Я могу помочь, только если вы покажете код, который вы используете.
 
angevoyageur:
Я смогу помочь, только если вы покажете код, который вы используете.

Достаточно ли этого или вам нужен весь код?

Спасибо Анже за поддержку...

doc

int checkEntry()
  {
  datetime lastdealtime;
  HistorySelect(0, TimeCurrent());  
  lastdealtime = HistoryDealGetInteger(HistoryDealGetTicket(HistoryDealsTotal()-1),DEAL_TIME);
  //Print("lastdealtime :",lastdealtime);
  
//--- time filter
   if(!checkTimeLimits()) return(_doNothing);

double ema1[2],
       ema2[2];
       
       //

//-- get current Spread
   int spread=int(SymbolInfoInteger(_Symbol,SYMBOL_SPREAD));

//-- Get indicator and timeserie data
  if(CopyBuffer(handle_ema1,0,0,2,ema1)           !=2  ||
  if(CopyBuffer(handle_ema2,0,0,2,ema2)           !=2  ||
                
     
     CopyHigh(_Symbol,_Period,0,2,high)!=2          || 
      CopyLow(_Symbol,_Period,0,2,low)!=2 
     
     ) return(_doNothing);
//-------
MqlDateTime currentTime; TimeCurrent(currentTime);

TouchTime=TimeCurrent();

if(ema1[1] > ema2[1] && ema1[0]< ema2[0]) 
           {
           if(TouchTime != emacross1_TouchTime) 
           {
           drawArrow1(TouchTime,ema1,"Wingdings 3",ArrowSize,"p",ArrowColor); 
           emacross1_TouchTime= TouchTime;
           
           }
        
      
          } 
int touchedline[10];
int temp = 0;
int valuearray = 0;

touchedline[0]=emacross1_TouchTime;
touchedline[1]=emacross2_TouchTime;
touchedline[2]=emacross3_TouchTime;
touchedline[3]=emacross4_TouchTime;
touchedline[4]=emacross5_TouchTime;
touchedline[5]=emacross6_TouchTime;
touchedline[6]=emacross7_TouchTime;
touchedline[7]=emacross8_TouchTime;
touchedline[8]=emacross9_TouchTime;
touchedline[9]=emacross10_TouchTime;


int highest=-1, previoushighest=-1;

   for(int i=0;i<10;i++)
     {
      if(touchedline[i]>temp)
        {
         previoushighest=highest;
         highest=i;
         temp=touchedline[i];
        }
     }
     
Print("act_highest :",highest);
Print("prv_highest :",previoushighest);
 
dr.house7:

Достаточно ли этого или вам нужен весь код?

Спасибо Анже за поддержку...

doc

Да. Теперья понял, что предложенный мной способ не работает, если наибольшее значение touchline[0]. Поэтому в этом случае нужно найти другой способ, например, использовать ArrayMaximum().
 
angevoyageur:
Да. Теперья понимаю, что предложенный мной способ не работает, если наибольшее значение touchline[0]. Поэтому в этом случае нужно найти другой способ, например, использовать ArrayMaximum().

Привет, Анж,

Я старалась сделать все возможное, но думаю, что это немного сложнее... я написала это и не работает, есть предложения? спасибо.

int index_max;

for(int i=0;i<10;i++)
     {
      if(touchedline[i]>temp)
        {
         index_max=ArrayMaximum(touchedline[i],0,WHOLE_ARRAY); // maximum in High
         temp=touchedline[i];         
        }
     }
 
dr.house7:

Привет, Анж,

Я старалась сделать все возможное, но думаю, что это немного сложнее... я написала это и не работает, есть предложения? спасибо.

   int highest=-1,previoushighest=-1;

   for(int i=0;i<10;i++)
     {
      if(touchedline[i]>temp)
        {
         previoushighest=highest;
         highest=i;
         temp=touchedline[i];
        }
     }     
   if(previoushighest==-1) previoushighest=ArrayMaximum(touchedline,1,WHOLE_ARRAY);

   Print("act_highest :",highest);
   Print("prv_highest :",previoushighest);
Нет времени тестировать, и я не претендую на то, что это лучшее решение. Но я думаю, что это должно работать.
 
angevoyageur:
Нет времени на тестирование, и я не претендую на то, что это лучшее решение. Но я думаю, что это должно сработать.
Я пробовал, но теперь предыдущий и текущий дают мне один и тот же результат большую часть времени
 
dr.house7:
Я пытался, но теперь предыдущий и текущий дают мне один и тот же результат большую часть времени.
Извините, у меня нет времени, а пытаться помочь в таком состоянии - не лучшая идея. Я трачу ваше время.
 
angevoyageur:
Извините, у меня нет времени, а пытаться помочь в таком состоянии - не лучшая идея. Я трачу ваше время.
все равно спасибо
 
angevoyageur:
Извините, у меня нет времени, а пытаться помочь в таком состоянии - не лучшая идея. Я трачу ваше время.

Извините, но что вы имели в виду, говоря "в таком состоянии"?

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