trova la data più vicina - pagina 2

 
angevoyageur:

Qualcosa del genere?

Solo una soluzione tra le altre.

C'è qualcosa che non va...posso usarlo solo su dati in tick altrimenti il massimo precedente è sempre =-1

Ma il problema principale è che anche sui dati in tick a volte senza motivo il massimo precedente cambia in =-1

Grazie ancora per il supporto

doc

 
dr.house7:

C'è qualcosa che non va...posso usarlo solo su dati in tick altrimenti il massimo precedente è sempre =-1

Ma il problema principale è che anche sui dati in tick a volte senza motivo il massimo precedente cambia in =-1

Grazie ancora per il supporto

doc

Posso aiutarti solo se mostri il codice che stai usando.
 
angevoyageur:
Posso aiutare solo se mostri il codice che stai usando.

È sufficiente questo o hai bisogno dell'intero codice?

Grazie Ange per il supporto...

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:

È sufficiente questo o hai bisogno dell'intero codice?

Grazie Ange per il supporto...

doc

Sì. Mi rendo conto ora che ho suggerito non funziona se il valore più alto è touchedline[0]. Quindi devi trovare un altro modo in questo caso, per esempio usare ArrayMaximum().
 
angevoyageur:
Si. Mi rendo conto ora che ho suggerito non funziona se il valore più alto è touchedline[0]. Quindi devi trovare un altro modo in questo caso, per esempio usare ArrayMaximum().

Ciao Ange,

Ho provato a fare del mio meglio, ma penso che questo sia un po' più complicato...ho scritto questo e non funziona, qualche suggerimento? grazie

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:

Ciao Ange,

Ho provato a fare del mio meglio, ma penso che questo sia un po' più complicato...ho scritto questo e non funziona, qualche suggerimento? grazie

   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);
Non ho tempo per testare e non pretendo che sia la soluzione migliore. Ma penso che dovrebbe funzionare.
 
angevoyageur:
Non ho tempo per testare e non pretendo che sia la soluzione migliore. Ma penso che dovrebbe funzionare.
Ho provato, ma ora il precedente e l'attuale mi danno lo stesso risultato la maggior parte delle volte
 
dr.house7:
Ho provato, ma ora il precedente e l'attuale mi danno lo stesso risultato la maggior parte delle volte
Mi dispiace, non ho tempo e cercare di aiutare in queste condizioni non è una buona idea. Sto sprecando il vostro tempo.
 
angevoyageur:
Mi dispiace, non ho tempo e cercare di aiutare in queste condizioni non è una buona idea. Sto sprecando il vostro tempo.
grazie comunque
 
angevoyageur:
Mi dispiace, non ho tempo e cercare di aiutare in queste condizioni non è una buona idea. Vi sto facendo perdere tempo.

Scusa ma cosa intendevi con "queste condizioni"?