Замучила ошибка there are no trading operations - страница 19

 

Вот купил я 1 бакс за свои деньги - и жду, когда он подрастет. 

Понравилось, купил 1 бакс взаймы, жду, пока упадёт. 

У меня такое впечатление, что не все это понимают. 

 
Отвечаю по теме: нет торговых операций. Ну, нет, совсем. 
 
Алексей Тарабанов:
Отвечаю по теме: нет торговых операций. Ну, нет, совсем. 

есть дельта меж покупками и продажами

она и двигает цену, она по сути и есть рыночная, пусть она станет открытым интересом

остальное мы назовем базовым активом, он в локе и он же вне рынка и образован процедурой клиринга

 
Алексей Тарабанов:

Это внушает надежду. 

Вы такие умные, пока сами с проблемой не сталкиваетесь...

 

На этот код валидатор ругается 

   if(aTicket > 0)
      if(OrderSelect(aTicket, SELECT_BY_TICKET, MODE_TRADES))
         if(!OrderClose(aTicket, NormalizeDouble(OrderLots(), 2), NormalizeDouble(OrderType() == 0 ? Bid : Ask, Digits()), 30))
            return (false);

Валидатор пишет 131 ошибка, не правильный объем...

 

Добрый день, форумчане. Подскажите пожалуйста, бьюсь вторую неделю с валидацией для мт5. Выдает ошибку

test on EURUSD,H1 (hedging) 2019.04.16 22:00:00 failed cancel order #73 sell stop 0.6 EURUSD at 1.12685 sl: 1.12851 tp: 1.11503 [Invalid stops]

2019.05.02 12:00:00 failed cancel order #136 sell stop 0.55 EURUSD at 1.11636 sl: 1.11814 tp: 1.10367 [Invalid stops]

2019.05.06 03:00:00 failed cancel order #147 sell stop 0.45 EURUSD at 1.11359 sl: 1.11578 tp: 1.09797 [Invalid stops]

2019.05.06 08:00:00 failed cancel order #148 sell stop 0.5 EURUSD at 1.11447 sl: 1.11645 tp: 1.10036 [Invalid stops]

2019.05.06 18:00:00 failed cancel order #151 sell stop 0.5 EURUSD at 1.11585 sl: 1.11783 tp: 1.10175 [Invalid stops]

2019.05.08 14:00:00 failed cancel order #167 sell stop 0.6 EURUSD at 1.11772 sl: 1.11938 tp: 1.10593 [Invalid stops]

2019.05.09 21:00:00 failed cancel order #175 sell stop 0.45 EURUSD at 1.11921 sl: 1.12138 tp: 1.10377 [Invalid stops]

2019.05.13 16:00:00 failed cancel order #181 sell stop 0.6 EURUSD at 1.12225 sl: 1.12390 tp: 1.11054 [Invalid stops] strategy tester report 5 total trades


Проверки все делаю. И самое странное что только на удаление ордера Sell Stop. Убираю выставление ордеров Sell Stop из кода

, проходит. В чем может быть проблема?

bool sqDeletePendingOrder(ulong ticket) {
   Verbose(" Deleting pending order, ticket: " + IntegerToString(ticket));
   
   if(!OrderSelect(ticket)) return false;
   
   double order_price = OrderGetDouble(ORDER_PRICE_OPEN);
   
   ENUM_ORDER_TYPE orderType = (ENUM_ORDER_TYPE) OrderGetInteger(ORDER_TYPE);

   if(orderType == ORDER_TYPE_BUY || orderType == ORDER_TYPE_SELL) {
      Verbose("Trying to delete non-pending order");
      return(false);
   }

  MqlTick tick;

   GetLastError(); // clear the global variable.
   int error = 0;
   int retries = 0;
   bool result;
   
   double stops_level = (double)SymbolInfoInteger(_Symbol, SYMBOL_TRADE_FREEZE_LEVEL);
   double freeze_level = (double)SymbolInfoInteger(_Symbol, SYMBOL_TRADE_STOPS_LEVEL);  
   double level = MathMax(stops_level,freeze_level);
   
   while (true) {  
      
      if (!SymbolInfoTick(_Symbol,tick)) return(false);
 
      double spread = ((tick.ask-tick.bid)/_Point); 
      if (level<=0) level = spread*3;

      bool del = true;
     
      if(orderType == ORDER_TYPE_BUY_LIMIT){ //Ask-Open  OrderGetDouble(ORDER_PRICE_CURRENT)
         if((tick.ask-order_price)/_Point <= level){
            VerboseLog("Cannot delete of order with Ticket#:", IntegerToString(ticket));            
            del = false;
         } 
      }
      else if(orderType == ORDER_TYPE_SELL_LIMIT){ //Open - Bid
         if((order_price-tick.bid)/_Point <= level) {
            VerboseLog("Cannot delete of order with Ticket#:", IntegerToString(ticket));           
            del = false;
         } 
      }
      else if(orderType == ORDER_TYPE_BUY_STOP){ //Open - Ask
         if((order_price-tick.ask)/_Point <= level) {
            VerboseLog("Cannot delete of order with Ticket#:", IntegerToString(ticket));           
            del = false;
         }
      }
      else if(orderType == ORDER_TYPE_SELL_STOP){ //Bid - Open
         //Print("SELLSTOP: ",(tick.bid-order_price)/_Point," ;  ",level);
         if((tick.bid-order_price) <= level*_Point) {        
            VerboseLog("Cannot delete of order with Ticket#:", IntegerToString(ticket));           
            del = false;
         } 
      }
      if (IsTradeAllowed() && del == true) {
         result = OrderDelete(ticket);    // Удаление отложки  Trade.Delete(ticket)                             
         if(result) {
            Verbose("Order deleted successfuly");
            return(true);
         }
      }

      retries++;
      if(!sqProcessErrors(retries, GetLastError())) {
         return(false);
      }
   }
 return(false);
}
 

Проблема решена, но мне кажется это баг валидатора. Взял цену на tick.bid, а цену OrderGetDouble(ORDER_PRICE_CURRENT).

Причем эта ошибка распространяется только на ордера SellStop

 
Alexey Osipov:

Проблема решена, но мне кажется это баг валидатора. Взял цену на tick.bid, а цену OrderGetDouble(ORDER_PRICE_CURRENT).

Причем эта ошибка распространяется только на ордера SellStop

Давно не работал с стоп левеламы но помню что всегда добавлял 1 пункт как раз из за Invalid stops. Попробуйте увеличить стоп левелы на один пункт.
 

Новая сложность: 


При публикации Утилиты, тестер выдает 

test on EURUSD,H1
strategy tester report not found

Утилита не имеет никаких торговых функций


Как пройти такую валидацию?

 
Sergey Likho:

Новая сложность: 

При публикации Утилиты, тестер выдает 

Утилита не имеет никаких торговых функций

Как пройти такую валидацию?

Это баг валидатора, ждите поправят...