FORTS: Para ajudar iniciantes - página 5

 
Mikhail Filimonov:

Funções úteis e freqüentemente utilizadas:

Função GetPositionPrice() redesenhada:

Esta função mostra o resultado errado, ou melhor, o resultado errado. Investiguei e descobri que a identificação da posição não muda no retorno (isto é, durante uma troca de entrada/saída), como descrito na documentação:

https://www.mql5.com/ru/docs/constants/tradingconstants/positionproperties

Uma inversão de posição muda sua identificação para o bilhete de pedido que resultou na inversão.

Seu GetPositionPrice pode empilhar 2 ou mais posições opostas se houver uma inversão, e calcula um preço médio para elas. Tal preço médio de uma posição não tem utilidade prática.

Então, a identificação da posição muda ou não na inversão?

Документация по MQL5: Стандартные константы, перечисления и структуры / Торговые константы / Свойства позиций
Документация по MQL5: Стандартные константы, перечисления и структуры / Торговые константы / Свойства позиций
  • www.mql5.com
Стандартные константы, перечисления и структуры / Торговые константы / Свойства позиций - справочник по языку алгоритмического/автоматического трейдинга для MetaTrader 5
 
o número de posição não muda ao girar
 
Como você pode dizer qual volume fechou uma posição anterior e qual abriu uma nova de um comércio de entrada e saída?
 
igorbel:
Como você pode dizer a partir de um comércio de entrada/saída qual volume fechou uma posição anterior e qual abriu uma nova posição?
Você pode compará-lo com o atual aberto. Mas é melhor examinar a história da posição por seu id, que não muda quando se vira a posição... Comprar/vender volumes para ajudar.
 
Dennis Kirichenko:
Pode ser comparado com a atual posição aberta. Mas é melhor examinar a história da posição por seu id, que não muda quando a posição é revertida... Comprar/vender volumes para ajudar.

A partir de recentemente, as MUDANÇAS de ID de posição quando você se vira. A documentação sobre isso já foi atualizada....

POSITION_IDENTIFIER

O ID da posição é um número único, que é atribuído a cada posição recém-aberta e não muda ao longo de sua vida útil. Corresponde ao bilhete do pedido com o qual a posição foi aberta.

O identificador de posição é especificado em cada ordem (ORDER_POSITION_ID) e cada comércio (DEAL_POSITION_ID) que o abriu, alterou ou fechou. Use esta propriedade para procurar ordens e negócios relacionados com a posição.

A inversão de uma posição muda seu identificador para o bilhete de pedido, o que resultou na inversão.

longo

 
Dennis Kirichenko:
Você poderia compará-lo com o atual aberto. Mas é melhor examinar a história da posição pelo id, que não muda durante uma inversão... Comprar/vender volumes para ajudar.

Esta não é uma opção de forma alguma. A posição anterior também poderia estar aberta devido à inversão, etc. Poderia ser uma opção, mas claramente não uma opção ótima.

 
Andrey Barinov:

A partir de recentemente, as MUDANÇAS de ID de posição quando você se vira. A documentação sobre isso já foi atualizada....

POSITION_IDENTIFIER

O ID da posição é um número único, que é atribuído a cada posição recém-aberta e não muda ao longo de sua vida útil. Corresponde ao bilhete do pedido com o qual a posição foi aberta.

O identificador de posição é especificado em cada ordem (ORDER_POSITION_ID) e cada comércio (DEAL_POSITION_ID) que o abriu, alterou ou fechou. Use esta propriedade para procurar ordens e negócios relacionados com a posição.

A inversão de uma posição muda seu identificador para o bilhete de pedido, o que resultou na inversão.

longo

Está escrito assim, mas na realidade nada muda.

Meu código, se você quiser:

long pos_id1,pos_id2,pos_id3;
   ulong deal1_ticket=xxx;
   ulong deal2_ticket=xxx;
   ulong deal3_ticket=xxx;
   if(!HistoryDealSelect(deal1_ticket))
      Print(__FUNCTION__+": deal 1 not selected. Error=",GetLastError());   
   pos_id1=HistoryDealGetInteger(deal1_ticket,DEAL_POSITION_ID);
   Print(__FUNCTION__+": ticket=",deal1_ticket,", position ID=",pos_id1);
   if(!HistoryDealSelect(deal2_ticket))
      Print(__FUNCTION__+": deal 2 not selected. Error=",GetLastError());
   pos_id2=HistoryDealGetInteger(deal2_ticket,DEAL_POSITION_ID);
   Print(__FUNCTION__+": ticket=",deal2_ticket,", position ID=",pos_id2);
   if(!HistoryDealSelect(deal3_ticket))
      Print(__FUNCTION__+": deal 3 not selected. Error=",GetLastError());
   pos_id3=HistoryDealGetInteger(deal3_ticket,DEAL_POSITION_ID);
   Print(__FUNCTION__+": ticket=",deal3_ticket,", position ID=",pos_id3);

Onde deal2_ticket é o in/out transaction ticket, deal1_ticket é o ticket que precede a transação in/out, deal3_ticket é o ticket após a transação in/out. Em todos os três casos recebo a mesma identificação de posição.

 
igorbel:

É o que diz, mas na realidade nada muda.

Se você quiser, meu código:

Onde deal2_ticket é o in/out transaction ticket, deal1_ticket é o ticket que precede a transação in/out, deal3_ticket é o ticket após a transação in/out. Em todos os três casos recebo a mesma identificação de posição.

O meu está mudando. Experimente a construção mais recente 1340.
 
igorbel:
E como podemos determinar a partir de um comércio in/out que volume fechou a posição anterior e que abriu a nova?

Este Expert Advisor é executado no modo "Debugging on History" em uma conta netting. O exemplo é um pouco rude, pois calcula-se que há apenas um negócio do tipo "IN/OUT" na história do negócio.

//+------------------------------------------------------------------+
//|                                                         Test.mq5 |
//|                              Copyright © 2016, Vladimir Karputov |
//|                                           http://wmua.ru/slesar/ |
//+------------------------------------------------------------------+
#property copyright "Copyright © 2016, Vladimir Karputov"
#property link      "http://wmua.ru/slesar/"
#property version   "1.00"
#include <Trade\Trade.mqh>
CTrade my_trade;
long deal_positions_id_in_out=0;
//+------------------------------------------------------------------+
//| Expert initialization function                                   |
//+------------------------------------------------------------------+
int OnInit()
  {
//---

//---
   return(INIT_SUCCEEDED);
  }
//+------------------------------------------------------------------+
//| Expert deinitialization function                                 |
//+------------------------------------------------------------------+
void OnDeinit(const int reason)
  {
//---

  }
//+------------------------------------------------------------------+
//| Expert tick function                                             |
//+------------------------------------------------------------------+
void OnTick()
  {
//---
   static int t=0;
   if(t==20)
     {
      my_trade.Buy(0.02);
     }
   if(t==25)
     {
      my_trade.Buy(0.01);
     }
   if(t==30)
     {
      my_trade.Sell(0.07);
     }
   if(t==40)
     {
      my_trade.PositionClose(Symbol());
     }
   if(t==50)
     {
      //--- request trade history 
      HistorySelect(0,TimeCurrent());
      long     deal_positions_id=0;
      double   deal_volume=0;
      long     deal_entry=0;
      long     deal_type=0;
      ulong    ticket=0;
      for(int i=0;i<HistoryDealsTotal();i++)
        {
         if((ticket=HistoryDealGetTicket(i))>0)
           {
            deal_positions_id=HistoryDealGetInteger(ticket,DEAL_POSITION_ID);
            deal_volume=HistoryDealGetDouble(ticket,DEAL_VOLUME);
            deal_entry=HistoryDealGetInteger(ticket,DEAL_ENTRY);
            deal_type=HistoryDealGetInteger(ticket,DEAL_TYPE);
            if(deal_entry==DEAL_ENTRY_INOUT)
               deal_positions_id_in_out=deal_positions_id;
            Print("DEAL_POSITION_ID ",deal_positions_id,
                  ", DEAL_VOLUME ",DoubleToString(deal_volume,2),
                  ", DEAL_ENTRY ",EnumToString((ENUM_DEAL_ENTRY)deal_entry),
                  ", DEAL_TYPE ",EnumToString((ENUM_DEAL_TYPE)deal_type));
           }
        }
     }
   if(t==55)
     {
      //--- request trade history 
      HistorySelect(0,TimeCurrent());
      long     deal_positions_id=0;
      double   deal_volume=0;
      long     deal_entry=0;
      long     deal_type=0;
      ulong    ticket=0;
      double   volume_in=0;
      double   volume_out=0;
      for(int i=0;i<HistoryDealsTotal();i++)
        {
         if((ticket=HistoryDealGetTicket(i))>0)
           {
            deal_positions_id=HistoryDealGetInteger(ticket,DEAL_POSITION_ID);
            deal_volume=HistoryDealGetDouble(ticket,DEAL_VOLUME);
            deal_entry=HistoryDealGetInteger(ticket,DEAL_ENTRY);
            deal_type=HistoryDealGetInteger(ticket,DEAL_TYPE);
            if(deal_positions_id==deal_positions_id_in_out && deal_entry==DEAL_ENTRY_IN)
               volume_in+=deal_volume;
            else if(deal_positions_id==deal_positions_id_in_out && deal_entry==DEAL_ENTRY_INOUT)
               volume_out=deal_volume;
           }
        }
      Print("DEAL_POSITION_ID ",deal_positions_id_in_out,
            ": volume in ",DoubleToString(volume_in,2),", volume out ",DoubleToString(volume_out,2));
     }
   t++;
  }
//+------------------------------------------------------------------+
//| Trade function                                                   |
//+------------------------------------------------------------------+
void OnTrade()
  {
//---

  }
//+------------------------------------------------------------------+

A princípio, depois de todos os negócios executados e do fechamento completo de uma posição, as descrições de todos os negócios são mostradas(DEAL_POSITION_ID, DEAL_VOLUME, DEAL_ENTRY,DEAL_TYPE), nesse DEAL_POSITION_ID para um negócio do tipo IN/OUT é memorizado.

Em seguida, ele percorre novamente a história e soma todas as entradas para o comércio com DEAL_POSITION_ID.

Obtemos algo como isto:

10:58:23.963    Test (EURUSD,H1)        2016.01.04 00:06:42   CTrade::OrderSend: instant buy 0.04 EURUSD at 1.08732 [done at 1.08732]
10:58:30.692    Test (EURUSD,H1)        2016.01.04 00:07:10   DEAL_POSITION_ID 0, DEAL_VOLUME 0.00, DEAL_ENTRY DEAL_ENTRY_IN, DEAL_TYPE DEAL_TYPE_BALANCE
10:58:30.784    Test (EURUSD,H1)        2016.01.04 00:07:10   DEAL_POSITION_ID 2, DEAL_VOLUME 0.02, DEAL_ENTRY DEAL_ENTRY_IN, DEAL_TYPE DEAL_TYPE_BUY
10:58:32.074    Test (EURUSD,H1)        2016.01.04 00:07:10   DEAL_POSITION_ID 2, DEAL_VOLUME 0.01, DEAL_ENTRY DEAL_ENTRY_IN, DEAL_TYPE DEAL_TYPE_BUY
10:58:33.826    Test (EURUSD,H1)        2016.01.04 00:07:10   DEAL_POSITION_ID 2, DEAL_VOLUME 0.07, DEAL_ENTRY DEAL_ENTRY_INOUT, DEAL_TYPE DEAL_TYPE_SELL
10:58:37.237    Test (EURUSD,H1)        2016.01.04 00:07:10   DEAL_POSITION_ID 4, DEAL_VOLUME 0.04, DEAL_ENTRY DEAL_ENTRY_OUT, DEAL_TYPE DEAL_TYPE_BUY
10:59:07.397    Test (EURUSD,H1)        2016.01.04 00:07:19   DEAL_POSITION_ID 2: volume in 0.03, volume out 0.07
Arquivos anexados:
Test.mq5  5 kb
 
Andrey Barinov:
Está mudando para mim. Experimente o último build 1340.
Foi o que eu tentei. Em que mercado você muda?
Razão: