Testare 'CopyTicks'. - pagina 4

 
CopyTicks 

////////////////////////////////////////////////////////////////////////////////////////////////////////// 

MqlTick tick_array[];  

int OnInit()
  {
   int copied=CopyTicks(_Symbol,tick_array,COPY_TICKS_ALL,0,countHistoryTicks);
   if(Save_File!=NOT_SAVE)
     {
      SaveTicksToFile(tick_array);
     }
   return(INIT_SUCCEEDED);
  }



void SaveTicksToFile(MqlTick &massiveTicks[])

  {

   string filename,file_buffer;

   StringConcatenate(filename,Symbol(),".txt");

   int file_handle=FileOpen(filename,FILE_READ|FILE_WRITE|FILE_ANSI|FILE_SHARE_READ);

FileSeek(file_handle,0,SEEK_END);

   int sizeMassiveTicks=ArraySize(massiveTicks);

   int i=0;

   while(i<sizeMassiveTicks)

     {

      StringConcatenate(file_buffer,TimeToString(massiveTicks[i].time,TIME_DATE|TIME_SECONDS)," ",DoubleToString(massiveTicks[i].bid,_Digits)," ",DoubleToString(massiveTicks[i].ask,_Digits)," ",DoubleToString(massiveTicks[i].last,_Digits)," ",IntegerToString(massiveTicks[i].volume,_Digits)," ",IntegerToString(massiveTicks[i].time_msc)," ",IntegerToString(massiveTicks[i].flags,_Digits));

      FileWrite(file_handle,file_buffer);

      i++;

     }

   FileClose(file_handle);

  } 
 

SymbolInfoTick 

////////////////////////////////////////////////////////////////////////

int OnCalculate(const int rates_total,

                const int prev_calculated,

                const datetime &time[],

                const double &open[],

                const double &high[],

                const double &low[],

                const double &close[],

                const long &tick_volume[],

                const long &volume[],

                const int &spread[])

  {

   MqlTick last_tick;

   SymbolInfoTick(Symbol(),last_tick);



   TickStruct tick={0,0,0,0,0,0,0};

   tick.time=TimeCurrent();

   tick.bid=last_tick.bid;

   tick.ask=last_tick.ask;

   tick.flag=last_tick.flags;

   tick.last=last_tick.last;

   tick.time_msc=last_tick.time_msc;

   tick.volume=last_tick.volume;

   int total=ArraySize(g_ticks);

   if(ArrayResize(g_ticks,total+1,1000)<0)

     {

      Alert(": индикатору не хватает памяти для сохранения данных об очередном тике.");

     }

   else

     {

      g_ticks[total]=tick;

      UpTick[rates_total-1]=total;

     }

   if(total>999)

     {

      SaveTempTicks();

      ArrayFree(g_ticks);

     }

   return(rates_total);

  } 

 

 

void SaveTempTicks()

  {

// Создание файла тиковой истории

   int hTicksFile=FileOpen(Symbol()+"fullTicks.tks",FILE_BIN|FILE_READ|FILE_WRITE|FILE_SHARE_READ|FILE_SHARE_WRITE);

   if(hTicksFile<1)

      return;

   FileSeek(hTicksFile,0,SEEK_END);

// Запись файла 

   int total=ArraySize(g_ticks),i=0;

   while(i<total)

     {

      if(FileWriteStruct(hTicksFile,g_ticks[i])==0)

        {

         Print("Ошибка сохранения данных во временный файл...");

         return;

        }

  i++;

     }

FileClose(hTicksFile);

 }  
 
Crea un esempio il più breve possibile che dimostri chiaramente il problema. Idealmente, tutta l'elaborazione in un unico file.
 
 

Nel debugger guardo i valori:

last_tick ottenuto tramiteSymbolInfoTick(Symbol(),last_tick),

tick_array tramite CopyTicks(_Symbol,tick_array,COPY_TICKS_ALL,0,1);

Tutto in tempo reale, i tick sono gli stessi, le bandiere sono diverse. Non sono riuscito a cogliere la differenza di volumi in questo modo, non è così frequente come la differenza di bandiere.

Cerchiamo almeno di definirli.

 
zimbabve15:

Nel debugger guardo i valori:

last_tick ottenuto tramite SymbolInfoTick(Symbol(),last_tick),

tick_array tramite CopyTicks(_Symbol,tick_array,COPY_TICKS_ALL,0,1);

Tutto in tempo reale, i tick sono gli stessi, le bandiere sono diverse. Non sono riuscito a cogliere la differenza di volumi in questo modo, non è così frequente come la differenza di bandiere.

Cerchiamo almeno di definirli.

Per definirlo, abbiamo bisogno di un file di esempio.
 

ED-3.16.txt - apertura broker tramite CopyTicks

Secondo file stesso broker tramiteSymbolInfoTick(Symbol(),last_tick),

File:
ED-3.16.txt  707 kb
 
secondo file stesso broker tramiteSymbolInfoTick(Symbol(),last_tick),
File:
 
Dimmi, come potrò caricare file *.txt in MetaEditor? Se c'è un problema, fate l'esempio il più semplice possibile - un solo file.
 
Karputov Vladimir:
Dimmi, come potrò caricare file *.txt in MetaEditor? Se c'è un problema, fate l'esempio il più semplice possibile - un solo file.
In realtà non è un problema, cambia l'estensione e MetaEditor la mangerà. È meglio chiedere i file del codice sorgente del programma, grazie al quale si ottiene questo registro.
 
Alexey Kozitsyn:
Nessun problema, cambia l'estensione e MetaEditor se la mangerà. È meglio chiedere i file del codice sorgente del programma che ha prodotto questo log.
Quindi ho già chiesto due pagine: date l'esempio più breve (chiarisco, per sicurezza, che "esempio" è il file *.mq5 in numero di un pezzo - che è solo uno) che mostra il problema.
Motivazione: