Тестируем 'CopyTicks' - страница 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);

 }  
 
Создайте максимально короткий пример, который будет явно демонстрировать проблему. Идеально - вся обработка в одном файле.
 
 

В отладчике смотрю значения:

last_tick получаемые через SymbolInfoTick(Symbol(),last_tick), 

tick_array через CopyTicks(_Symbol,tick_array,COPY_TICKS_ALL,0,1);

Все в реальном времени, тики одни и те же, во флагах отличие. Поймать таким образом разницу в объемах не удалось, встречается не так часто, как разница во флагах.

Давайте определимся хотя бы с ними.   

 
zimbabve15:

В отладчике смотрю значения:

last_tick получаемые через SymbolInfoTick(Symbol(),last_tick), 

tick_array через CopyTicks(_Symbol,tick_array,COPY_TICKS_ALL,0,1);

Все в реальном времени, тики одни и те же, во флагах отличие. Поймать таким образом разницу в объемах не удалось, встречается не так часто, как разница во флагах.

Давайте определимся хотя бы с ними.   

Для того, чтобы определится - нужен файл - пример. 
 

ED-3.16.txt - брокер Открытие через CopyTicks

 второ й файл тот же брокер через SymbolInfoTick(Symbol(),last_tick),  

Файлы:
ED-3.16.txt  707 kb
 
второй файл тот же брокер через SymbolInfoTick(Symbol(),last_tick),  
Файлы:
 
Скажите, каким образом я смогу *.txt файлы загнать в MetaEditor? Если есть проблема - составьте максимально упрощённый пример - одним файлом.
 
Karputov Vladimir:
Скажите, каким образом я смогу *.txt файлы загнать в MetaEditor? Если есть проблема - составьте максимально упрощённый пример - одним файлом.
Да вообще-то не проблема, поменяйте расширение и МетаЭдитор съест. Вы бы лучше попросили файлы исходного кода программы, благодаря которой получился такой лог.
 
Alexey Kozitsyn:
Да вообще-то не проблема, поменяйте расширение и МетаЭдитор съест. Вы бы лучше попросили файлы исходного кода программы, благодаря которой получился такой лог.
Так я уже две страницу прошу: дайте максимально короткий пример (уточняю, на всякий случай, что "пример" - это *.mq5 файл в количестве один штук - то есть совсем один) который показывает проблему.