Testando 'CopyTicks'. - página 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);

 }  
 
Criar um exemplo tão curto quanto possível que demonstre claramente o problema. Idealmente, todo o processamento em um único arquivo.
 
 

No depurador eu olho para os valores:

último_tick obtido viaSymbolInfoTick(Symbol(),last_tick),

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

Tudo em tempo real, os carrapatos são os mesmos, as bandeiras são diferentes. Não tenho conseguido captar a diferença de volumes desta forma, não é tão freqüente quanto a diferença de bandeiras.

Vamos ao menos defini-los.

 
zimbabve15:

No depurador eu olho para os valores:

último_tick obtido via SymbolInfoTick(Symbol(),last_tick),

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

Tudo em tempo real, os carrapatos são os mesmos, as bandeiras são diferentes. Não tenho conseguido captar a diferença de volumes desta forma, não é tão freqüente quanto a diferença de bandeiras.

Vamos ao menos defini-los.

Para defini-la, precisamos de um arquivo de exemplo.
 

ED-3.16.txt - Abertura do corretor via CopyTicks

Segundo arquivo mesmo corretor viaSymbolInfoTick(Symbol(),last_tick),

Arquivos anexados:
ED-3.16.txt  707 kb
 
segundo arquivo mesmo corretor viaSymbolInfoTick(Symbol(),last_tick),
Arquivos anexados:
 
Diga-me, como serei capaz de carregar arquivos *.txt no MetaEditor? Se houver um problema, torne o exemplo o mais simples possível - um arquivo.
 
Karputov Vladimir:
Diga-me, como serei capaz de carregar arquivos *.txt no MetaEditor? Se houver um problema, torne o exemplo o mais simples possível - um arquivo.
Na verdade, não é um problema, mude a extensão e o MetaEditor o comerá. É melhor solicitar os arquivos de código fonte do programa, devido ao qual este log é obtido.
 
Alexey Kozitsyn:
Sem problemas, troque a extensão e o MetaEditor vai comê-la. É melhor perguntar pelos arquivos de código fonte do programa, que produziu este registro.
Portanto, já pedi duas páginas: dê o exemplo mais curto (esclareço, para o caso de "exemplo" ser *.mq5 arquivo em número de uma peça - que é apenas uma) que mostra o problema.
Razão: