Erros, bugs, perguntas - página 2906

 
A pesquisa do site não funciona durante um segundo dia.
 

As paragens e tomadas não funcionam durante os testes. Na imagem do ecrã um exemplo de um Limite de Venda desencadeado com o conjunto SL e TP, mas a paragem (e o take) não desencadeia para onde quer que o preço tenha ido. Onde cavar?

Arquivos anexados:
Screenshot_1.jpg  177 kb
 

Para posições, existe a propriedade POSITION_TIME_UPDATE - a hora da última mudança de posição.

Não existe tal propriedade para encomendas no terminal. Mas há um no servidor?


Compreendo correctamente que a modificação de uma ordem Limitada numa troca é uma reemissão da ordem Limitada: eliminar a antiga e definir uma nova?

Se assim for, então a modificação deve mudar ORDER_TIME_SETUP. No entanto, isto não está a acontecer.

 

Gráficos indicadores a desaparecer

Com bastante frequência, após algumas horas de trabalho, os gráficos indicadores desaparecem.

Para restaurar os dados e minimizar o cálculo do indicador, utilizo as fases de carregamento e cálculo dos dados.

Quando instalo o indicador no gráfico, todas as fases funcionam normalmente.

//+------------------------------------------------------------------+
//|                                                                  |
//+------------------------------------------------------------------+
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[]  
)
{
  if(prev_calculated == 0)
  {
    switch (mar_data.stage)
    {
      case LOAD_TICKS:
        if(LoadTicks(time) == true)
        {
          //--- 
          mar_data.stage = READ_PRIM_TICKS;
        }
        return(0);
      break;
      case READ_PRIM_TICKS:
        if(ReadPrimTicks() == true)
        {
          //---
          mar_data.stage = READ_SEC_TICKS;
        }  
        return(0);
      break;
      case READ_SEC_TICKS:
        if(ReadSecTicks() == true)
        {
          //---
          mar_data.stage = FILL_DATA;
        }  
        return(0);
      break;
      case FILL_DATA:
        //---
        FillData();
        mar_data.stage = LOAD_TICKS;
      break;
    }
  } 
  else
  {
    //--- Live data ---
  }
  return(rates_total);
}

Na última fase é atribuída a primeira fase, para que o indicador (quando é chave) possa carregar novamente os dados

mar_data.stage = LOAD_TICKS;

Mas, quando o indicador é reiniciado, os dados não serão restaurados

A função

//+------------------------------------------------------------------+
//| Custom indicator Load ticks function                             |
//+------------------------------------------------------------------+
bool LoadTicks(const datetime &a_times[])
{
  int result = CopyTime(Symbol(), PERIOD_M1, start_time, end_time, mar_data.time_array);
  if(result > 0)
  {
    if(mar_data.time_array[result - 1] == a_times[ArraySize(a_times) - 1])
    {
      mar_data.b_cnt = result;
      result = CopyTicksRange(Symbol(), mar_data.pr_ticks, COPY_TICKS_INFO, ulong(start_time) * 1000, ulong(end_time) * 1000);
      if(result > 0)
      {
        if(mar_data.pr_ticks[result-1].time >= mar_data.time_array[ArraySize(mar_data.time_array) - 1]) 
        {
          mar_data.pr_cnt = result;
          datetime sec_time_array[];
          result = CopyTime(sec_symbol, PERIOD_M1, start_time, end_time, sec_time_array);
          if(result > 0)
          {
            result = CopyTicksRange(sec_symbol, mar_data.sec_ticks, COPY_TICKS_INFO, ulong(start_time) * 1000, ulong(end_time) * 1000);
            if(result > 0)
            {
              if(mar_data.sec_ticks[result-1].time >= sec_time_array[ArraySize(sec_time_array) - 1])
              {
                mar_data.sec_cnt = result;
                return(true);
              } else Print("Не хватает тиков ", sec_symbol, "!");
            } else Print("Не получены тики по символу ", sec_symbol, "!");
          } else Print("Не скопировано время баров по символу ", sec_symbol, "!");
        } else Print("Не хватает тиков ", Symbol(), "!"); 
      } else Print("Не получены тики по символу ", Symbol(), "!");
    } else Print("Не хватает баров по символу ", Symbol(), "!");
  } else Print("Не скопировано время баров по символу ", Symbol(), "!");
  return(false);
}

Produz apenas isto

"Barras de tempo não copiadas pelo símbolo BR-1.21".

Mas nada acontece mais.

Porque há uma chamada de LoadTicks(), portanto todos os passos devem ser repetidos, como quando se carrega o indicador.

Caros programadores, porque é que o indicador deixa de funcionar?

Документация по MQL5: Программы MQL5 / Выполнение программ
Документация по MQL5: Программы MQL5 / Выполнение программ
  • www.mql5.com
Каждый скрипт, сервис и эксперт работает в собственном отдельном потоке. Все индикаторы, рассчитываемые на одном символе, даже если они запущены на разных графиках, работают в одном потоке. Таким образом, все индикаторы на одном символе делят между собой ресурсы одного потока. В одном потоке с индикаторами также последовательно выполняются...
 
fxsaber:
É o segundo dia em que a pesquisa do site não funciona.

A base de pesquisa tem diminuído muito. Há muitas coisas que não estão a ser encontradas.

 
Como posso saber quando a posição/ordem foi modificada pela última vez?
 
fxsaber:
Como é que sei quando modifiquei a minha posição/ordem pela última vez?

POSITION_TIME_UPDATE

 
Igor_Gagarin:

POSITION_TIME_UPDATE

Este é o momento da última mudança de volume. Echo Netting.

 
fxsaber:

Este é o momento da última mudança de volume. Rede de Ecos.

O tempo de abertura da posição está a dar. Sobre o que estava a perguntar?