FORTS: Per aiutare i principianti - pagina 5

 
Mikhail Filimonov:

Funzioni usate frequentemente e utili:

Funzione GetPositionPrice() ridisegnata:

Questa funzione mostra il risultato sbagliato, o meglio il risultato sbagliato. Mi sono informato e ho scoperto che il Position ID non cambia a U-turn (cioè durante un trade in/out), come descritto nella documentazione:

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

Un'inversione di posizione cambia il suo ID al ticket dell'ordine che ha portato all'inversione.

Il tuo GetPositionPrice può accumulare 2 o più posizioni opposte se c'è un'inversione, e calcola un prezzo medio per esse. Un tale prezzo medio di una posizione non ha alcuna utilità pratica.

Quindi, il Position ID cambia all'inversione o no?

Документация по MQL5: Стандартные константы, перечисления и структуры / Торговые константы / Свойства позиций
Документация по MQL5: Стандартные константы, перечисления и структуры / Торговые константы / Свойства позиций
  • www.mql5.com
Стандартные константы, перечисления и структуры / Торговые константы / Свойства позиций - справочник по языку алгоритмического/автоматического трейдинга для MetaTrader 5
 
il numero di posizione non cambia quando si gira
 
Come puoi dire quale volume ha chiuso una posizione precedente e quale ne ha aperta una nuova da un trade in/out?
 
igorbel:
Come puoi dire da un trade in/out quale volume ha chiuso una posizione precedente e quale ne ha aperta una nuova?
Potete confrontarlo con l'attuale aperto. Ma è meglio esaminare la storia della posizione in base al suo id, che non cambia quando la girate... Volumi di acquisto/vendita per aiutare.
 
Dennis Kirichenko:
Può essere confrontato con l'attuale posizione aperta. Ma è meglio esaminare la storia della posizione tramite il suo id, che non cambia quando la posizione è invertita... Volumi di acquisto/vendita per aiutare.

Da poco, l'ID di posizione CAMBIA quando si gira. La documentazione su questo è già stata aggiornata....

IDENTIFICATORE DI POSIZIONE

Il Position ID è un numero unico, che viene assegnato ad ogni posizione appena aperta e non cambia per tutta la sua durata. Corrisponde al ticket dell'ordine con cui è stata aperta la posizione.

L'identificatore di posizione è specificato in ogni ordine (ORDER_POSITION_ID) e ogni trade (DEAL_POSITION_ID) che lo ha aperto, modificato o chiuso. Usa questa proprietà per cercare ordini e compravendite relative alla posizione.

Un'inversione di una posizione cambia il suo identificatore al biglietto d'ordine che ha portato all'inversione.

lungo

 
Dennis Kirichenko:
Potreste confrontarlo con l'attuale aperto. Ma è meglio esaminare la storia della posizione dall'id, che non cambia durante un'inversione... Volumi di acquisto/vendita per aiutare.

Questa non è affatto un'opzione. La posizione precedente potrebbe anche essere aperta a causa dell'inversione ecc. Potrebbe essere un'opzione, ma chiaramente non ottimale.

 
Andrey Barinov:

Da poco, l'ID della posizione CAMBIA quando ci si gira. La documentazione su questo è già stata aggiornata....

IDENTIFICATORE DI POSIZIONE

Il Position ID è un numero unico, che viene assegnato ad ogni posizione appena aperta e non cambia per tutta la sua durata. Corrisponde al ticket dell'ordine con cui è stata aperta la posizione.

L'identificatore di posizione è specificato in ogni ordine (ORDER_POSITION_ID) e ogni trade (DEAL_POSITION_ID) che lo ha aperto, modificato o chiuso. Usa questa proprietà per cercare ordini e compravendite relative alla posizione.

Un'inversione di una posizione cambia il suo identificatore al biglietto d'ordine che ha portato all'inversione.

lungo

È scritto così, ma in realtà non cambia nulla.

Il mio codice, se volete:

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

Dove deal2_ticket è il ticket della transazione in/out, deal1_ticket è il ticket che precede la transazione in/out, deal3_ticket è il ticket dopo la transazione in/out. In tutti e tre i casi ottengo lo stesso ID di posizione.

 
igorbel:

Lo dice, ma in realtà non cambia nulla.

Se volete, il mio codice:

Dove deal2_ticket è il ticket della transazione in/out, deal1_ticket è il ticket che precede la transazione in/out, deal3_ticket è il ticket dopo la transazione in/out. In tutti e tre i casi ottengo lo stesso ID di posizione.

Il mio sta cambiando. Prova sulla build 1340 più recente.
 
igorbel:
E come possiamo determinare da un trade in/out quale volume ha chiuso la posizione precedente e quale ha aperto quella nuova?

Questo Expert Advisor viene eseguito in modalità "Debugging on History" su un conto netting. L'esempio è un po' approssimativo, perché si calcola che ci sia solo un affare di tipo "IN/OUT" nella storia dell'affare.

//+------------------------------------------------------------------+
//|                                                         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()
  {
//---

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

All'inizio, dopo tutte le operazioni eseguite e la chiusura completa di una posizione, vengono mostrate le descrizioni di tutte le operazioni(DEAL_POSITION_ID, DEAL_VOLUME, DEAL_ENTRY, DEAL_TYPE), a quel punto DEAL_POSITION_ID per un'operazione di tipo IN/OUT viene memorizzato.

Poi passa di nuovo attraverso la storia e somma tutte le voci per le compravendite con DEAL_POSITION_ID.

Questo è approssimativamente ciò che otteniamo:

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
File:
Test.mq5  5 kb
 
Andrey Barinov:
Sta cambiando per me. Prova con l'ultima build 1340.
Questo è quello che ho provato. Su quale mercato si cambia?