[Qualsiasi domanda da principiante, per non ingombrare il forum. Professionisti, non passate oltre. Da nessuna parte senza di te - 4. - pagina 495

 
fmillion:
'' - fine inaspettata del programma G:\work\MetaTrader Group\experts\Balista.mq4 (576, 1)

Poke con il mouse - si sposta nel luogo con i commenti ((... Cosa fare?


Il modo più semplice per trovare l'errore è il pulsante magico in MetaEditor "Undo". E dopo un altro annullamento, prova a compilare di nuovo il codice.
 
Buona giornata! Ditemi. Diciamo che userò
double iMA(     string symbol, int timeframe, int period, int ma_shift, int ma_method, int applied_price, int shift)

Nell'aiuto c'è scritto timeframe - Punto. Può essere uno dei periodi di un grafico. 0 significa il periodo del grafico corrente.

Può, o è sicuramente il periodo del grafico? Ma se mettessi 20 invece di 15? È meglio usare un numero o è meglio PERIOD_M15?

Ok, ho messo 0 e non mi preoccupo.

 

Buona giornata a tutti. Sarei molto grato se qualcuno potesse inserire un suono in questo indicatore.

Cioè quando c'è un attraversamento di .... e naturalmente il suono dovrebbe essere fatto solo una volta alla chiusura della candela su cui questo incrocio è avvenuto.

Grazie in anticipo per il vostro aiuto.

 
Dimka-novitsek:
Buona giornata! Ditemi. Diciamo che userò

Nell'aiuto c'è scritto timeframe - Punto. Può essere uno dei periodi di un grafico. 0 significa il periodo del grafico corrente.

Può, o è sicuramente il periodo del grafico? Ma se mettessi 20 invece di 15? È meglio usare un numero o è meglio PERIOD_M15?

Ok, ho messo 0 e non mi preoccupo.

Il periodo è impostato in minuti. Per esempio, 60 è un'ora, 240 è 4 ore... ecc, 5 è M5.
 

Non ho trovato la funzione diKimIV per restituire l'importo del drawdown/profitto dell'ultimo ordine chiuso.

L'idea è semplice: è necessario tracciare quanto in valuta di deposito era il Profitto o il Drawdown nell'ultimo ordine chiuso.

 
fmillion:

Non ho trovato la funzione diKimIV per restituire l'importo del drawdown/profitto dell'ultimo ordine chiuso.

L'idea è semplice: devi tracciare quanto in valuta di deposito era il Profitto o il Drawdown nell'ultimo ordine chiuso.

Questo design funziona per me:

//---Поиск крайнего отработавшего ордера для открытия очередной позиции ---   
   for (orderIndex = (OrdersHistoryTotal() - 1); orderIndex >= 0; orderIndex--)
   {   
      if (!OrderSelect(orderIndex, SELECT_BY_POS, MODE_HISTORY)) {Print("Ошибка при доступе к исторической базе (",GetLastError(),")");continue;}   
      if ((OrderSymbol() != Symbol()) || (OrderMagicNumber() != MagicNumber))  continue;              
   //------------------------- Принимаем в расчет только ордер, закрытый cамым крайним -----------------------
      if (time<OrderCloseTime())     //(сравниваем его с хранящимся в пероеменной time) 
        {
         time=OrderCloseTime();     //если время закрытия ордера больше - ложим его в переменную     
         int lastType = OrderType();
         double lastLots = OrderLots();
         double lastProfit = OrderProfit() + OrderSwap();
         
         // Анализ только что закрывшегося ордера      
         if (lastProfit >= 0.0)
         {
...
 
Roman.:

Ho un tale disegno che funziona:

e a cosa è uguale la variabile tempo all'inizio del ciclo?
 
fmillion:

Non ho trovato la funzione diKimIV per restituire l'importo del drawdown/profitto dell'ultimo ordine chiuso.

L'idea è semplice: devi tracciare quanto in valuta di deposito era il Profitto o il Drawdown nell'ultimo ordine chiuso.

L'algoritmo è il seguente: cercate QUALSIASI funzione che restituisca QUALSIASI cosa sull'ultimo ordine chiuso. Prendi il biglietto dell'ultimo ordine chiuso. Quando il ciclo è finito, si seleziona un ordine in base al biglietto ottenuto e si calcola il suo profitto (se è importante, non dimenticare di considerare lo swap e la commissione nel calcolo):

    Profit = OrderProfit() + OrderSwap() + OrderCommission();
 
Zhunko:
Eseguilo e dai un'occhiata. Un "kit" abbastanza utile.

Vedo che il "cane" e gli spazi tra di esso sono usati per visualizzare un numero. Ma perché succede questo? È qualcosa che non proviene dalla programmazione mql? Esiste una cosa simile in C?

Non capisco davvero perché succede. E non sono nemmeno sicuro di cosa produca. Vedo numeri Fibo ad alcuni livelli attraverso il "cane", e ad alcuni livelli qualcos'altro?

Può spiegare la ragione della loro apparizione? Sono diventato molto curioso. Ma l'ho aperto per il secondo giorno e non l'ho capito.

Duplicherò il codice dello script per evitare di cercarlo nella storia:

//+------------------------------------------------------------------+
//|                              Brooky_FibIt_Retracement_Script.mq4 |
//|                        Copyright 2012, www.Brooky_Indicators.com |
//|                                        www.Brooky_Indicators.com |
//+------------------------------------------------------------------+
#property copyright "Copyright 2012, www.Brooky_Indicators.com"
#property link      "www.Brooky_Indicators.com"
#property show_confirm  
#property show_inputs
//+------------------------------------------------------------------+
//| script program start function                                    |
//+------------------------------------------------------------------+

extern int       FibOnChartNum =1;

extern color     Fib_Cbar_Color = Red;
extern int       Fib_Cbar_Size=1;
extern int       Fib_Cbar_Style=2;

extern color     Fib_Level_Color = Gray;
extern int       Fib_Level_Size=1;
extern int       Fib_Level_Style=2;

extern double     Fib_Level_1 = 0;
extern double     Fib_Level_2 = 0.236;
extern double     Fib_Level_3 = 0.382;
extern double     Fib_Level_4 = 0.5;
extern double     Fib_Level_5 = 0.618;
extern double     Fib_Level_6 = 0.764;
extern double     Fib_Level_7 = 1;

string Xtra_txtFib_Level_1  = "Extreme ";
string Xtra_txtFib_Level_2  = "Break OUT ";
string Xtra_txtFib_Level_3  = "Break IN ";
string Xtra_txtFib_Level_4  = "Centre ";
string Xtra_txtFib_Level_5  = "Break IN ";
string Xtra_txtFib_Level_6  = "Break OUT ";
string Xtra_txtFib_Level_7  = "Extreme ";


string txtFib_Level_1  = "";
string txtFib_Level_2  = "";
string txtFib_Level_3  = "";
string txtFib_Level_4  = "";
string txtFib_Level_5  = "";
string txtFib_Level_6  = "";
string txtFib_Level_7  = "";


string FibPrice = " @ %$";
string FibPrice1 = " ";
string FibName = "";

int start()
  {

//----
      txtFib_Level_1 = StringConcatenate(Xtra_txtFib_Level_1,DoubleToStr(Fib_Level_1,3),FibPrice1);
      txtFib_Level_2 = StringConcatenate(Xtra_txtFib_Level_2,DoubleToStr(Fib_Level_2,3),FibPrice);
      txtFib_Level_3 = StringConcatenate(Xtra_txtFib_Level_3,DoubleToStr(Fib_Level_3,3),FibPrice1);
      txtFib_Level_4 = StringConcatenate(Xtra_txtFib_Level_4,DoubleToStr(Fib_Level_4,3),FibPrice);
      txtFib_Level_5 = StringConcatenate(Xtra_txtFib_Level_5,DoubleToStr(Fib_Level_5,3),FibPrice1);
      txtFib_Level_6 = StringConcatenate(Xtra_txtFib_Level_6,DoubleToStr(Fib_Level_6,3),FibPrice);
      txtFib_Level_7 = StringConcatenate(Xtra_txtFib_Level_7,DoubleToStr(Fib_Level_7,3),FibPrice);
      
      
      
      FibName = "Brooky_FibR_"+FibOnChartNum;
      ObjectDelete(FibName);
      
      ObjectCreate(FibName,OBJ_FIBO,0,Time[21],High[24],Time[1],Low[1]);
      
      ObjectSet(FibName, OBJPROP_COLOR,Fib_Cbar_Color);
      ObjectSet(FibName, OBJPROP_WIDTH ,Fib_Cbar_Size);
      ObjectSet(FibName, OBJPROP_STYLE ,Fib_Cbar_Style);
      
      ObjectSet(FibName, OBJPROP_RAY,True);
       
      ObjectSet(FibName, OBJPROP_LEVELSTYLE,Fib_Level_Style);
      ObjectSet(FibName, OBJPROP_LEVELCOLOR,Fib_Level_Color);      
      ObjectSet(FibName, OBJPROP_LEVELWIDTH,Fib_Level_Size);  
       
          
      ObjectSet(FibName, OBJPROP_FIBOLEVELS,7);
      ObjectSet(FibName, OBJPROP_FIRSTLEVEL+0,Fib_Level_1);
      ObjectSet(FibName, OBJPROP_FIRSTLEVEL+1,Fib_Level_2);
      ObjectSet(FibName, OBJPROP_FIRSTLEVEL+2,Fib_Level_3);
      ObjectSet(FibName, OBJPROP_FIRSTLEVEL+3,Fib_Level_4);
      ObjectSet(FibName, OBJPROP_FIRSTLEVEL+4,Fib_Level_5);
      ObjectSet(FibName, OBJPROP_FIRSTLEVEL+5,Fib_Level_6);
      ObjectSet(FibName, OBJPROP_FIRSTLEVEL+6,Fib_Level_7);
      

     
      ObjectSetFiboDescription(FibName,0,txtFib_Level_1);
      ObjectSetFiboDescription(FibName,1,txtFib_Level_2);
      ObjectSetFiboDescription(FibName,2,txtFib_Level_3);
      ObjectSetFiboDescription(FibName,3,txtFib_Level_4);
      ObjectSetFiboDescription(FibName,4,txtFib_Level_5);
      ObjectSetFiboDescription(FibName,5,txtFib_Level_6);
      ObjectSetFiboDescription(FibName,6,txtFib_Level_7);      
      
//----
   return(0);
  }
//+------------------------------------------------------------------+
 

Amici, mi sono imbattuto in un semplice problema, ma non riesco a risolverlo. L'essenza è la seguente. Quando certe condizioni sono soddisfatte, si apre un trade (chiamiamolo lead trade). E ho bisogno che entro le prossime 3 barre, se questa condizione si ripete, si apra un altro trade (ripetizione). Se entro le prossime tre barre la condizione di cui ho bisogno non è soddisfatta, allora un trade non dovrebbe aprirsi di nuovo fino alla prossima volta che il trade sarà aperto di nuovo. E così via. Ho, per qualche motivo, riaprire solo una volta (voglio dire, quando tutte le condizioni sono soddisfatte in generale la prima volta - si apre, ma in seguito, quando dopo il nuovo accordo leader appare condizione di apertura di un commercio ripetere - non è aperto). Aiuto, per favore.

//условие открытия повторной сделки
for (povtor_up=1;povtor_up<4;povtor_up++)
if ((povtor_buy==1) && (adx_cont==1)&&(sb==1))
{
  CL = iClose(NULL,0,1);
  stop = CL - SLP*Point;
  raz_up = (CL - frac_down);
  take_1 = 0;
  take_2 = 0;
  if (CL<(frac_up-FR_OVER*Point))
  take_1 = (CL + raz_up*MNP_1);
  if (CL>=(frac_up-FR_OVER*Point))
  take_2 = (CL + raz_up*MNP_2);
  if (take_1>0)
  {
  take_1n = NormalizeDouble(take_1,5);
  take = take_1n;
  }
  if (take_2>0)
  {
  take_2n = NormalizeDouble(take_2,5);
  take = take_2n;
  }

    if(!IsTradeAllowed())
      {
      Alert("занят торговый поток, повторим попытку buy");
      return(-1);
      }
  ticket_buy_cont=OrderSend(Symbol(),OP_BUY,Lots,Ask,Slippage,stop,take,com,Magic,0,Yellow);
    if(ticket_buy_cont == -1)
    {
    Alert(Symbol(),"ошибка:buy", GetLastError());
    return(-1);
    }
    if(ticket_buy_cont > 1)
    {Alert (Symbol(),"buy повтор - ок !");
    povtor_buy=0;
    povtor_up=0;
    }

}
else 
    povtor_buy=0;
    povtor_up=0;


//условие открытия ведущей сделки
if ((adx_ts==1) && (sb==1) && (FLAG==0))
{
  CL = iClose(NULL,0,1);
  stop = CL - SL*Point;
  raz_up = (CL - frac_down);
  take_1 = 0;
  take_2 = 0;
  if (CL<(frac_up-FR_OVER*Point))
  take_1 = (CL + raz_up*MN_1);
  if (CL>=(frac_up-FR_OVER*Point))
  take_2 = (CL + raz_up*MN_2);
  if (take_1>0)
  {
  take_1n = NormalizeDouble(take_1,5);
  take = take_1n;
  }
  if (take_2>0)
  {
  take_2n = NormalizeDouble(take_2,5);
  take = take_2n;
  }

    if(!IsTradeAllowed())
      {
      Alert("занят торговый поток, повторим попытку buy");
      return(-1);
      }
  ticket_buy=OrderSend(Symbol(),OP_BUY,Lots,Ask,Slippage,stop,take,com,Magic,0,Yellow);
    if(ticket_buy == -1)
    {
    Alert(Symbol(),"ошибка:buy", GetLastError());
    return(-1);
    }
    if(ticket_buy > 1)
    {Alert (Symbol(),"buy при начале - ок !");
    FLAG=1;
    povtor_up=1;
    povtor_buy=1;
    }

}
Motivazione: