Perguntas de Iniciantes MQL5 MT5 MetaTrader 5 - página 463

 

Como obter o volume da posição a 0 (zero)? (FORTS, Otkrytie-Broker, Real)

Temos o seguinte código:

#property strict
long     gTicks=0;
int      Step=0;
//=====
void OnTick()
{
   gTicks++;
   PositionSelect(_Symbol);
   //-----
   {if((gTicks>1000)&&(Step==0))
   {
      Print("OPEN>> *** VOLUME=",PositionGetDouble(POSITION_VOLUME),
                        " *** ID=",PositionGetInteger(POSITION_IDENTIFIER),
                        " *** TYPE=",EnumToString((ENUM_POSITION_TYPE)PositionGetInteger(POSITION_TYPE)),
                        " *** OrdersTotal()=",OrdersTotal());
      MqlTradeRequest request={0};                                   //Обнулим записи запроса
      MqlTradeResult result={0};                                     //Обнулим записи ответа
      request.action=TRADE_ACTION_PENDING;                           //Отложенный ордер
      request.symbol=_Symbol;                                        //Инструмент
      request.price=SymbolInfoDouble(_Symbol,SYMBOL_BID);            //Прайс (цена) исполнения ордера
      request.type=ORDER_TYPE_SELL_STOP;                             //Тип ордера
      request.type_filling=ORDER_FILLING_RETURN;                     //Разрешить исполнять частями (ORDER_FILLING_RETURN)
      request.type_time=ORDER_TIME_SPECIFIED_DAY;                    //В очереди до экспирации
      request.expiration=
         (datetime)SymbolInfoInteger(_Symbol,SYMBOL_EXPIRATION_TIME);//Время истечения фьючерсного контракта
      request.volume=1;                                              //Объем
      Print("OPEN OrderSend=",OrderSend(request,result));
      Print("OPEN Retcode=",result.retcode);
      Print("OPEN Order=",result.order);
      Print("OPEN Deal=",result.deal);
      Print("OPEN OrdersTotal()=",OrdersTotal());
      Print("OPEN Volume=",PositionGetDouble(POSITION_VOLUME));
      Step=1;
      return;
   }}//if((gTicks>1000)&&(Step==0))
   //-----
   {if((gTicks>2000)&&(Step==1))
   {
   Print("CLOSE>> *** VOLUME=",PositionGetDouble(POSITION_VOLUME),
                     " *** ID=",PositionGetInteger(POSITION_IDENTIFIER),
                     " *** TYPE=",EnumToString((ENUM_POSITION_TYPE)PositionGetInteger(POSITION_TYPE)),
                     " *** OrdersTotal()=",OrdersTotal());
      MqlTradeRequest request={0};                                   //Обнулим записи запроса
      MqlTradeResult result={0};                                     //Обнулим записи ответа
      request.action=TRADE_ACTION_DEAL;                              //Отложенный ордер
      request.symbol=_Symbol;                                        //Инструмент
      request.price=SymbolInfoDouble(_Symbol,SYMBOL_ASK);            //Прайс (цена) исполнения ордера
      request.type=ORDER_TYPE_BUY;                                   //тип ордера
      request.type_filling=ORDER_FILLING_FOK;                        //Исполнять только в полном объёме
      request.type_time=ORDER_TIME_DAY;                              //В очереди до снятия
      request.volume=1;                                              //Объем Правильно
      Print("CLOSE OrderSend=",OrderSend(request,result));
      Print("CLOSE Retcode=",result.retcode);
      Print("CLOSE Order=",result.order);
      Print("CLOSE Deal=",result.deal);
      Print("CLOSE OrdersTotal()=",OrdersTotal());
      Print("CLOSE Volume=",PositionGetDouble(POSITION_VOLUME));
      Step=2;
      return;
   }}//if((gTicks>2000)&&(Step==1))        
   //-----   
   {if((gTicks>3000)&&(Step==2))
   {
      Print("INFO>> *** VOLUME=",PositionGetDouble(POSITION_VOLUME),
                        " *** ID=",PositionGetInteger(POSITION_IDENTIFIER),
                        " *** TYPE=",EnumToString((ENUM_POSITION_TYPE)PositionGetInteger(POSITION_TYPE)),
                        " *** OrdersTotal()=",OrdersTotal());
      Step=3;
      return;
   }}//if((gTicks>3000)&&(Step==2))
   {if((gTicks>4000)&&(Step==3))
   {
      ExpertRemove();
   }}//if((gTicks>4000)&&(Step==3))
}//OnTick()

Ou seja, abrimos uma posição com uma ordem, fechamo-la com uma ordem inversa, e olhamos para o volume da posição como resultado.

Esperamos 0 (zero) e temos 1 (um). Registos abaixo (início abaixo).

2015.10.27 16:28:11.476 2015.10.26 10:05:08   ExpertRemove() function called
2015.10.27 16:28:11.465 2015.10.26 10:03:14   INFO>> *** VOLUME=1.0 *** ID=2 *** TYPE=POSITION_TYPE_SELL *** OrdersTotal()=0
2015.10.27 16:28:11.450 2015.10.26 10:01:47   CLOSE Volume=1.0
2015.10.27 16:28:11.450 2015.10.26 10:01:47   CLOSE OrdersTotal()=0
2015.10.27 16:28:11.450 2015.10.26 10:01:47   CLOSE Deal=3
2015.10.27 16:28:11.450 2015.10.26 10:01:47   CLOSE Order=3
2015.10.27 16:28:11.450 2015.10.26 10:01:47   CLOSE Retcode=10009
2015.10.27 16:28:11.450 2015.10.26 10:01:47   CLOSE OrderSend=true
2015.10.27 16:28:11.449 2015.10.26 10:01:47   order performed buy 1.00 at 9249 [#3  buy 1.00 SBRF-12.15 at 9249]
2015.10.27 16:28:11.449 2015.10.26 10:01:47   deal performed [#3  buy 1.00 SBRF-12.15 at 9249]
2015.10.27 16:28:11.449 2015.10.26 10:01:47   deal #3  buy 1.00 SBRF-12.15 at 9249 done (based on order #3)
2015.10.27 16:28:11.449 2015.10.26 10:01:47   exchange buy 1.00 SBRF-12.15 at 9249 (9242 / 9249 / 9242)
2015.10.27 16:28:11.449 2015.10.26 10:01:47   CLOSE>> *** VOLUME=1.0 *** ID=2 *** TYPE=POSITION_TYPE_SELL *** OrdersTotal()=0
2015.10.27 16:28:11.422 2015.10.26 10:00:57   order performed sell 1.00 at 9205 [#2  sell stop 1.00 SBRF-12.15 at 9205]
2015.10.27 16:28:11.422 2015.10.26 10:00:57   deal performed [#2  sell 1.00 SBRF-12.15 at 9205]
2015.10.27 16:28:11.422 2015.10.26 10:00:57   deal #2  sell 1.00 SBRF-12.15 at 9205 done (based on order #2)
2015.10.27 16:28:11.422 2015.10.26 10:00:57   order [#2  sell stop 1.00 SBRF-12.15 at 9205] triggered
2015.10.27 16:28:11.422 2015.10.26 10:00:57   OPEN Volume=0.0
2015.10.27 16:28:11.422 2015.10.26 10:00:57   OPEN OrdersTotal()=1
2015.10.27 16:28:11.422 2015.10.26 10:00:57   OPEN Deal=0
2015.10.27 16:28:11.422 2015.10.26 10:00:57   OPEN Order=2
2015.10.27 16:28:11.422 2015.10.26 10:00:57   OPEN Retcode=10009
2015.10.27 16:28:11.422 2015.10.26 10:00:57   OPEN OrderSend=true
2015.10.27 16:28:11.422 2015.10.26 10:00:57   sell stop 1.00 SBRF-12.15 at 9205 (9205 / 9227 / 9205)
2015.10.27 16:28:11.422 2015.10.26 10:00:57   OPEN>> *** VOLUME=0.0 *** ID=0 *** TYPE=POSITION_TYPE_BUY *** OrdersTotal()=0
2015.10.27 16:28:11.344 SBRF-12.15,M1: testing of Experts\Projects\CoinAge5\Helper_v01\mq5\Tst\TST006_Open_Close_Positions_001.ex5 from 2015.10.26 00:00 to 2015.10.27 00:00 started

Qual é a razão?

 
Yury Kirillov:

Como obter o volume da posição a 0 (zero)? (FORTS, Otkrytie-Broker, Real)

Temos o seguinte código:

Ou seja, abrimos uma posição com uma ordem, fechamo-la com uma ordem inversa, e olhamos para o volume da posição como resultado.

Esperamos 0 (zero) e temos 1 (um). Registos abaixo (início abaixo).

Qual é a razão?

Obrigado pela vossa atenção! Tem uma explicação num fio vizinho. :-)
 
Alexey Viktorov:
Exactamente correcto. Quando escrevi esta fórmula, o meu SL não foi definido por um valor pré-definido, mas foi calculado como a diferença entre o preço da ordem aberta e algum nível, pelo que tive de multiplicar o montante do risco por _Ponto
Então deve dividir, e não multiplicar.
 

Olá a todos! Não consigo lidar com um problema... Por favor, ajudem!! Havia um Consultor Especialista com Martingale (2SS), retrabalhei quase tudo - agora também abre por Trend. Há uma contagem em bloco do lucro acumulado de ordens fechadas separadamente e foi reposto a "0" - quando toda a série foi fechada, e em particular a 1ª ordem aberta. Agora esta 1ª encomenda pode fechar a qualquer momento... E o lucro acumulado é anulado. TAREFA: Segurar esta bandeira (aberturas em série) até que TODAS as encomendas sejam fechadas depois de esta bandeira "aparecer". No código-fonte, era assim que se parecia:

  if(OrderSelect(TicketB[totb-1],SELECT_BY_TICKET)) TimeB=OrderOpenTime();
  if(OrderSelect(TicketS[tots-1],SELECT_BY_TICKET)) TimeS=OrderOpenTime();
.......//...........//...........//............//............//........
         if(!OrderSelect(k,SELECT_BY_POS,MODE_HISTORY)) break;
         if((OrderOpenTime()<TimeB || totb==0) && (OrderOpenTime()<TimeS || tots==0)) break;
         if(OrderSymbol()==Symbol())
           {
            if((OrderMagicNumber()==magicbuy || OrderMagicNumber()==magicbuyTrEnd) && OrderType()==OP_BUY  && OrderOpenTime()>TimeB) ProfitBuyN  += OrderProfit()+OrderSwap()+OrderCommission();
            if((OrderMagicNumber()==magicsell || OrderMagicNumber()==magicsellTrEnd) && OrderType()==OP_SELL && OrderOpenTime()>TimeS) ProfitSellN += OrderProfit()+OrderSwap()+OrderCommission();
           }

Obrigado de antemão!

 
Artyom Trishkin:
Depois dividir, não multiplicar.
Não olhou cuidadosamente para a minha variante, não multipliquei a paragem, embora seja de facto a variante certa, mas multipliquei o dinheiro, o que após 5-6 anos parece irracional, mas o resultado é correcto. Não voltei a esta variante durante todos estes anos, mal encontrei um consultor especializado onde isto seja feito. Quando o encontrei, já tinha escrito dois posts :))))
 
Alexey Viktorov:
Não olhou cuidadosamente para a minha variante, não multipliquei a paragem, embora seja de facto a variante certa, e multipliquei o dinheiro, o que após 5-6 anos parece irracional, mas o resultado é correcto. Não voltei a esta variante durante todos estes anos, mal encontrei um consultor especializado onde isto seja feito. Quando o encontrei, já tinha escrito dois posts :))))

E a partir de um smartphone ;)

É estranho, é claro. Se escrevi o valor de paragem em pips, é 300 (no seu exemplo). Multiplicou-o por _Ponto. Como resultado, a cinco dígitos o valor de paragem em pips é 300*0,00001=0,003

Ok. Se a diferença entre o preço de fecho necessário e o preço aberto é igual a 0,003 (no preço), porque é que ele o multiplicou e obteve 0,00000003 pontos? Se ele a tivesse dividido, teria conseguido 300 como devia.

De facto, respondi do meu smartphone, sem sequer me aperceber que estava a responder e não o questionador original ;)

 
Artyom Trishkin:

E a partir de um smartphone ;)

É estranho, é claro. Se escrevi o valor de paragem em pips, é 300 (no seu exemplo). Multiplicou-o por _Ponto. Como resultado, a cinco dígitos o valor de paragem em pips é 300*0,00001=0,003

Ok. Se a diferença entre o preço de fecho necessário e o preço aberto é igual a 0,003 (no preço), porque é que ele o multiplicou e obteve 0,00000003 pontos? Se ele a tivesse dividido, teria conseguido 300 como deveria ser.

De facto, estava a responder a partir do meu smartphone sem sequer me aperceber que estava a responder a si e não ao autor da pergunta no início ;)

E agora já jantei e não me interessa o que ele recebe. :)))

O principal é que nos entendemos... :)))))))))))))))))))

 
Alexey Viktorov:

E agora já jantei e não me interessa o que ele recebe. :)))

O importante é que tu e eu nos entendemos... :)))))))))))))))))))

Estou muito contente por se entenderem)) Eu, que sou muito jovem, não sei o que dividir e multiplicar. Por favor, ajude-me com a informação, terei todo o prazer em ter uma ligação a um artigo, uma explicação simples nos meus dedos, estou grato por qualquer ajuda.
 
Alexey Viktorov:

Agora já jantei e não me interessa o que ele recebe. :)))

O principal é que tu e eu nos entendemos... :)))))))))))))))))))

Acho que já percebi, cavalheiros))))

double Test=100/(300*SymbolInfoDouble(_Symbol,SYMBOL_TRADE_TICK_VALUE))

É assim que funciona, obrigado a todos)

 
PabloEs:

Acho que já o tenho, cavalheiros))

double Test=100/(300*SymbolInfoDouble(_Symbol,SYMBOL_TRADE_TICK_VALUE))

É assim que funciona, obrigado a todos)

Vês, jantei e conseguiste fazê-lo em 11 minutos. :)))
Razão: