Fracctal Break Out-Stuck - página 3

 

Troquei parâmetros em ambas as funções OrderModify e OrderSelect em vão...

O fluxo parece lógico e eu tenho dupla verificação de todos os parâmetros.


Isto está acontecendo durante o backtest, mas não deve importar.

 
//----------------------------------------------//
//-----------------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);}       
   }

Facilitar a leitura da codificação

veja a diferença com sua própria escrita isto é mais fácil de contar {{{{{{{{{{{{{{{ }}}}}}}}}}}}}}

 
ZacharyRC:

Ainda com dificuldades. Conduzi erros para descobrir o porquê.


A revista Reported:

1) Erro 4051=Parâmetro incorreto

2) Bilhete inválido para modificação de ordem

//----------------------------------------------//
//-----------------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);
               }
            }
         }
      }
   }

Para uma compra como o SL pode estar acima do preço Aberto? OrderOpenPrice() + Point * MoveStopTo

 
deVries:

para COMPRAR Possível ter OrderStopLoss() acima OrderOpenPrice() depois de modificado teve sucesso e o comércio está em lucro
LOL . . oops <red face smiley>
 
RaptorUK:
LOL . . oops <red face smiley>


Cuidado com a vergonha de apagar meu posto
 
ZacharyRC:

Ainda com dificuldades. Conduzi erros para descobrir o porquê.


A revista Reported:

1) Erro 4051=Parâmetro incorreto

2) Bilhete inválido para modificação de ordem

OK, talvez suas mensagens de erro sejam espúrias . .

 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);

Por que você está chamando GetLastError() se a OrderSelect() funcionar ? se ela mostrar um erro, não será devido à OrderSelect()

O mesmo caso para a OrderModify(), se as obras de modificação que você ainda está chamando GetLastError(), por que ? só chamá-la se a função falhar . .

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

Cuidado com a vergonha de apagar meu posto
Não, eu sou humano, eu também cometo erros, não me importo que as pessoas saibam disso :-)
 

AHHH eu amo isso. Ambos os seus pontos fazem muito sentido.


{{{{}}}}}-É muito mais fácil também!

Os erros só devem ser chamados se a função falhar.


Obrigado a ambos, espero que seus fins de semana tenham corrido bem.

 
RaptorUK:

Para uma compra como o SL pode estar acima do preço Aberto ? OrderOpenPrice() + Point * MoveStopTo


O SL está abaixo da ordem.



Você tem certeza de que não está se referindo à seção de venda?

 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 . . oops <red face smiley>

Foi um erro de minha parte.