Fractal Break Out-Stuck - страница 3

 

Я поменял параметры в обеих функциях OrderModify и OrderSelect безрезультатно...

Поток кажется логичным, и я дважды проверил все параметры.


Это происходит во время бэктеста, но не должно иметь значения.

 
//----------------------------------------------//
//-----------------EXITING ORDERS---------------//


for(int i=OrdersTotal()-1; i>=0;i--)
   {
    if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==false)  break;
    if(OrderMagicNumber()!=MagicNumber || OrderSymbol() !=Symbol()) continue;
    double SL=OrderStopLoss();
    bool   result;
    int    error;
    //Different OrderTypes
    if(OrderType()==OP_BUY)
       {
        if(BreakEven > 0) 
          {
           if(Bid - OrderOpenPrice() >= Point * BreakEven * mypoint)  //make input for BreakEven    StopLoss)
              {                                                                   //and don't forget mypoint !!!
               if(OrderStopLoss() < OrderOpenPrice()) 
                 {
                  SL = OrderOpenPrice()+Point;
                 }
              }
          }
       }
    if(OrderType()==OP_SELL)              
       {
         //For you to do
          
              
               
                
               
                  
                   
             
             
       }
    if(SL != OrderStopLoss()) result=OrderModify(OrderTicket(),OrderOpenPrice(),SL,OrderTakeProfit(),0,CLR_NONE);
         if(result!=TRUE) { error=GetLastError(); Print("ModifyError = ",OrderTicket(),"   ",error);}       
   }

Сделать кодировку более легкой для чтения

увидеть разницу с вашим собственным письмом это легче считать {{{{{{{{{{{{{{{ }}}}}}}}}}}}}}

 
ZacharyRC:

Все еще испытываю трудности. Я проанализировал ошибки, чтобы выяснить их причину.


Журнал сообщил:

1) Ошибка 4051=Неправильный параметр

2) Недействительный билет для изменения заказа

//----------------------------------------------//
//-----------------EXITING ORDERS---------------//


for(int i=OrdersTotal()-1; i>=0;i--)
   {
   if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==false)  break;


   if(OrderMagicNumber()!=MagicNumber || OrderSymbol() !=Symbol()) continue;

   if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==true) Print(GetLastError(),i);
   if(OrderType()==OP_BUY)
      {
      if(Move.BE && StopLoss > 0) 
         {
         if(Bid - OrderOpenPrice() >= Point * StopLoss)
            {
            if(OrderStopLoss() < OrderOpenPrice() + Point * MoveStopTo) 
               {
               OrderModify(OrderTicket(),OrderOpenPrice(), OrderOpenPrice() + Point * MoveStopTo, OrderTakeProfit(), 0, Red);
               Print("Cant Modify Order"+GetLastError(),i);
               }
            } 
         }
      }
   else
      {
      if(Move.BE && StopLoss > 0) 
         {
         if(OrderOpenPrice() - Ask >= Point * StopLoss)
            {
            if(OrderStopLoss() > OrderOpenPrice() - Point * MoveStopTo)
               {
               OrderModify(OrderTicket(),OrderOpenPrice(), OrderOpenPrice() - Point * MoveStopTo, OrderTakeProfit(), 0, Red);
               Print("Cant Modify Order"+GetLastError(),i);
               }
            }
         }
      }
   }

Для покупки как SL может быть выше цены открытия? OrderOpenPrice() + Point * MoveStopTo

 
deVries:

для BUY Возможно иметь OrderStopLoss() выше OrderOpenPrice() после того, как модификация прошла успешно и сделка в прибыли.
ЛОЛ . . упс <красный смайлик>
 
RaptorUK:
LOL . . . упс <красный смайлик>


остерегайтесь позора, удалите мой пост
 
ZacharyRC:

Все еще испытываю трудности. Я проанализировал ошибки, чтобы выяснить их причину.


Журнал сообщил:

1) Ошибка 4051=Неправильный параметр

2) Недействительный билет для изменения заказа

Хорошо, возможно, ваши сообщения об ошибках являются надуманными...

 if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==true) Print(GetLastError(),i);


               OrderModify(OrderTicket(),OrderOpenPrice(), OrderOpenPrice() - Point * MoveStopTo, OrderTakeProfit(), 0, Red);
               Print("Cant Modify Order"+GetLastError(),i);

Почему вы вызываете GetLastError(), если OrderSelect() работает? Если он покажет вам ошибку, это не будет связано с OrderSelect().

То же самое для OrderModify(), если модификация работает, вы все равно вызываете GetLastError(), зачем? Вызывайте ее только если функция не сработала. ...

            if(OrderStopLoss() > OrderOpenPrice() - Point * MoveStopTo)
               {
               if(!OrderModify(OrderTicket(),OrderOpenPrice(), OrderOpenPrice() - Point * MoveStopTo, OrderTakeProfit(), 0, Red))
                  Print("Cant Modify Order, error# " + GetLastError()," index ", i);
 
deVries:

остерегайтесь позора, удалите мой пост
Неа, я человек, я тоже делаю ошибки, я не против, чтобы люди это знали :-)
 

Мне это нравится. Оба ваших пункта имеют большой смысл.


{{{{}}}}}-так же намного проще!

Ошибки должны вызываться только в случае сбоя функции.


Спасибо вам обоим, надеюсь, ваши выходные прошли отлично.

 
RaptorUK:

Для покупки как SL может быть выше цены открытия? OrderOpenPrice() + Point * MoveStopTo


SL находится ниже ордера.



Вы уверены, что не имеете в виду секцию продажи?

 else{
 
    if(Move.BE && StopLoss > 0) {
               if(OrderOpenPrice() - Ask >= Point * StopLoss)
                {
                  if(OrderStopLoss() > OrderOpenPrice() - Point * MoveStopTo)
                   {
                  OrderModify(OrderTicket(),OrderOpenPrice(), OrderOpenPrice() - Point * MoveStopTo, OrderTakeProfit(), 0, Red);
                  Print("Cant Modify Order"+GetLastError(),i);
}
 
RaptorUK:
LOL . . . упс <красный смайлик>

Это была ошибка с моей стороны.