encontrar a data mais próxima - página 2

 
angevoyageur:

Algo assim ?

Apenas uma solução entre outras.

Há algo errado...posso usá-lo apenas em dados de carrapatos, caso contrário o maior valor anterior é sempre =-1

Mas o principal problema é que também nos dados do tick, em algum momento sem razão, a mudança anterior mais alta para =-1

Mais uma vez obrigado pelo apoio

doc

 
dr.house7:

Há algo errado...posso usá-lo apenas em dados de carrapatos, caso contrário o maior valor anterior é sempre =-1

Mas o principal problema é que também nos dados do tick, em algum momento sem razão, a mudança anterior mais alta para =-1

Mais uma vez obrigado pelo apoio

doc

Eu só posso ajudar se você mostrar o código que está usando.
 
angevoyageur:
Eu só posso ajudar se você mostrar o código que está usando.

Isso é suficiente ou você precisa do código inteiro?

Obrigado Ange pelo apoio...

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:

Isso é suficiente ou você precisa do código inteiro?

Obrigado Ange pelo apoio...

doc

Sim. Agorapercebo que eu sugeri que não funcionasse se o valor mais alto fosse a linha de toque [0]. Portanto, é preciso encontrar outra forma neste caso, por exemplo, usar ArrayMaximum().
 
angevoyageur:
Sim. Percebo agora que a minha sugestão não funciona se o valor mais alto for a linha de toque [0]. Portanto, é preciso encontrar outra forma neste caso, por exemplo, usar ArrayMaximum().

Olá Ange,

Eu tentei fazer o meu melhor, mas acho que isto é um pouco mais complicado...escrevi isto e não funciona, alguma sugestão? obrigado

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:

Olá Ange,

Eu tentei fazer o meu melhor, mas acho que isto é um pouco mais complicado...eu escrevi isto e não funciona, alguma sugestão? obrigado

   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);
Não há tempo para testar, e eu não finjo que seja a melhor solução. Mas eu acho que deve funcionar.
 
angevoyageur:
Não há tempo para testar, e eu não finjo que seja a melhor solução. Mas eu acho que deve funcionar.
Eu tentei, mas agora o anterior e o atual me dão o mesmo resultado na maior parte do tempo.
 
dr.house7:
Eu tentei, mas agora o anterior e o atual me dão o mesmo resultado na maior parte do tempo.
Lamento não ter tempo e tentar ajudar nestas condições não é uma boa idéia. Estou perdendo seu tempo.
 
angevoyageur:
Lamento não ter tempo e tentar ajudar nestas condições não é uma boa idéia. Estou perdendo seu tempo.
obrigado de qualquer forma
 
angevoyageur:
Desculpe não ter tempo e tentar ajudar nestas condições não é uma boa idéia. Estou perdendo seu tempo.

Desculpe, mas o que você quis dizer com "estas condições"?

Razão: