Fragen von Anfängern MQL5 MT5 MetaTrader 5 - Seite 1239

 
Alexey Viktorov:

Ich kann Ihnen keinen Rat geben. Ich verwende keine Optimierung. Ich halte das für Quacksalberei.

Da bin ich anderer Meinung. Optimierung ist meiner Meinung nach die Auswahl der am besten geeigneten Parameter für ein bestimmtes Paar und eine bestimmte Strategie.

P.S. Jetzt scheinen die Spreads normal zu sein.

 
Youri Lazurenko:

Da bin ich anderer Meinung.

Ich habe Sie nicht aufgeregt. Ich gebe nur meine persönliche Meinung wieder.))

 
Alexey Viktorov:

Ich habe Sie nicht aufgeregt. Ich habe nur meine persönliche Meinung geäußert.))

Vielleicht ist meine Meinung falsch. Ich bin auch nicht aufgeregt.

 

Hallo. Ich brauche Hilfe. Ich muss die Lebensdauer eines schwebenden Auftrags begrenzen, vorzugsweise in der Anzahl der Balken. Ich habe die Funktion in mql4 verwendet:

datetime DateExp()                                 
{
   datetime expDate = 0;
   
   if(Period() == PERIOD_M1)
      expDate = TimeCurrent() + ExpDate*60;
      
   if(Period() == PERIOD_M5)
      expDate = TimeCurrent() + ExpDate*5*60;
    
   if(Period() == PERIOD_M15)
      expDate = TimeCurrent() + ExpDate*15*60;
    
   if(Period() == PERIOD_M30)
      expDate = TimeCurrent() + ExpDate*30*60;
    
   if(Period() == PERIOD_H1)
      expDate = TimeCurrent() + ExpDate*60*60;
    
   if(Period() == PERIOD_H4)
      expDate = TimeCurrent() + ExpDate*4*60*60;
   
   if(Period() == PERIOD_D1)
      expDate = TimeCurrent() + ExpDate*24*60*60;      
    
   if(Period() == PERIOD_W1) 
      expDate = TimeCurrent() + ExpDate*7*24*60*60; 
   
   if(Period() == PERIOD_MN1)
      expDate = TimeCurrent() + ExpDate*30*24*60*60;
          
   return(expDate);  
}

wobei

extern intDate = 6; //Anzahl der Balken der Auftragslaufzeit

Alles funktioniert.

Ich habe etwas Ähnliches in mql5 versucht:

datetime DateExp()                                 
{
   datetime expDate = 0;
   
   if(Period() == PERIOD_M1)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_M1)*ExpDate;
      
   if(Period() == PERIOD_M2)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_M2)*ExpDate;
   
   if(Period() == PERIOD_M3)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_M3)*ExpDate;
   
   if(Period() == PERIOD_M4)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_M4)*ExpDate;
      
   if(Period() == PERIOD_M5)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_M5)*ExpDate;
   
   if(Period() == PERIOD_M6)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_M6)*ExpDate;
   
   if(Period() == PERIOD_M10)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_M10)*ExpDate;
   
   if(Period() == PERIOD_M12)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_M12)*ExpDate;
    
   if(Period() == PERIOD_M15)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_M15)*ExpDate;
   
   if(Period() == PERIOD_M20)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_M20)*ExpDate;
    
   if(Period() == PERIOD_M30)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_M30)*ExpDate;
    
   if(Period() == PERIOD_H1)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_H1)*ExpDate;
   
   if(Period() == PERIOD_H2)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_H2)*ExpDate;
   
   if(Period() == PERIOD_H3)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_H3)*ExpDate;
    
   if(Period() == PERIOD_H4)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_H4)*ExpDate;
   
   if(Period() == PERIOD_H6)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_H6)*ExpDate;
   
   if(Period() == PERIOD_H8)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_H8)*ExpDate;
   
   if(Period() == PERIOD_H12)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_H12)*ExpDate;
   
   if(Period() == PERIOD_D1)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_D1)*ExpDate;      
    
   if(Period() == PERIOD_W1) 
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_W1)*ExpDate; 
   
   if(Period() == PERIOD_MN1)
      expDate = TimeCurrent() + PeriodSeconds(PERIOD_MN1)*ExpDate;
          
   return(expDate);  
}

wobei

input int ExpDate = 6; //Anzahl der Balken der Auftragslaufzeit

Dann habe ich versucht, sie (die oben gezeigte Funktion) zu verwenden, wenn ich einen schwebenden Auftrag erteile, z. B. zum Kauf

               request.action       = TRADE_ACTION_PENDING;                                         
               request.magic        = Magic;                                                       
               request.symbol       = _Symbol;                                                      
               request.volume       = GetLots();                                                    
               request.price        = openBuy;                                                      
               request.sl           = slBuy;                                                        
               request.tp           = tpBuy;                                                        
               request.type         = ORDER_TYPE_BUY_STOP;                                          
               request.type_filling = ORDER_FILLING_FOK;                                           
               request.expiration   = DateExp();                                                    
               request.deviation    = SG; 

Der schwebende Auftrag wird erteilt, ist aber erst aktiv, wenn er (im Testgerät) aktiviert wird. Ich habe versucht, eine einfache Zahl in request.expiration einzustellen, aber es funktioniert nicht. Ich habe bei Google keine Informationen gefunden. Was ist los mit mir? Warum wird die Bestellung nicht nach einer bestimmten Zeit gelöscht?

P.S. Wenn die Funktion DateExp() in Comment angezeigt wird, werden Datum und Uhrzeit angezeigt.

Документация по MQL5: Константы, перечисления и структуры / Торговые константы / Свойства ордеров
Документация по MQL5: Константы, перечисления и структуры / Торговые константы / Свойства ордеров
  • www.mql5.com
Приказы на проведение торговых операций оформляются ордерами. Каждый ордер имеет множество свойств для чтения, информацию по ним можно получать с помощью функций Идентификатор позиции, который ставится на ордере при его исполнении. Каждый исполненный ордер порождает сделку, которая открывает новую или изменяет уже существующую позицию...
 
Youri Lazurenko:


Sie haben vergessen, das anzugeben:

struct MqlTradeRequest
  {
   ENUM_TRADE_REQUEST_ACTIONS    action;           // Тип выполняемого действия
   ulong                         magic;            // Штамп эксперта (идентификатор magic number)
   ulong                         order;            // Тикет ордера
   string                        symbol;           // Имя торгового инструмента
   double                        volume;           // Запрашиваемый объем сделки в лотах
   double                        price;            // Цена 
   double                        stoplimit;        // Уровень StopLimit ордера
   double                        sl;               // Уровень Stop Loss ордера
   double                        tp;               // Уровень Take Profit ордера
   ulong                         deviation;        // Максимально приемлемое отклонение от запрашиваемой цены
   ENUM_ORDER_TYPE               type;             // Тип ордера
   ENUM_ORDER_TYPE_FILLING       type_filling;     // Тип ордера по исполнению
   ENUM_ORDER_TYPE_TIME          type_time;        // Тип ордера по времени действия
   datetime                      expiration;       // Срок истечения ордера (для ордеров типа ORDER_TIME_SPECIFIED)
   string                        comment;          // Комментарий к ордеру
   ulong                         position;         // Тикет позиции
   ulong                         position_by;      // Тикет встречной позиции
  };
 
Vladimir Karputov:

Sie haben vergessen, das anzugeben:

Danke, habe es selbst schon gefunden, wollte nur schreiben, dass die Frage entfernt wird. Vor diesen, aber ich setzen, es stellt sich heraus, falsche Parameter request.type_time = ORDER_TIME_GTC; Korrigiert, um request.type_time = ORDER_TIME_SPECIFIED; und alles funktioniert. Aber vielen Dank für das Feedback und den Tipp.

 
Artyom Trishkin:

Alexey hat Ihnen gesagt, dass Sie Ihren Indikator zunächst einmal nur Kerzen ziehen sollten. So wie sie sind. Zumindest auf dem aktuellen Balken. Wenn Sie es schaffen, haben Sie den ersten Schritt zum Verständnis getan. Es ist jedoch wünschenswert, ihn nicht durch Ausprobieren verschiedener Parameter, sondern mit dem eigenen Verstand zu finden.

Was hat das mit Apriori zu tun? Man braucht sie wirklich, denn man kann keine Kerze mit nur vier Werten zeichnen.

Hier habe ich einen sehr einfachen Testindikator geschrieben, der 5 Kerzen (echte) aus dem USDJPY H8-Chart zeichnen soll

//+------------------------------------------------------------------+
//|                                                        cTest.mq5 |
//|                                     Copyright 2020, Tabolin S.N. |
//|                           https://www.mql5.com/ru/users/vip.avos |
//+------------------------------------------------------------------+
#property copyright "Copyright 2020, Tabolin S.N."
#property link      "https://www.mql5.com/ru/users/vip.avos"
#property version   "1.00"
//#property indicator_separate_window
#property indicator_chart_window
#property indicator_buffers 4
#property indicator_plots   1
//--- plot bars
#property indicator_label1  "bars"
#property indicator_type1   DRAW_CANDLES
#property indicator_color1  clrGold
#property indicator_style1  STYLE_SOLID
#property indicator_width1  1
//--- indicator buffers
double   barsBuffer1[];
double   barsBuffer2[];
double   barsBuffer3[];
double   barsBuffer4[];
//+------------------------------------------------------------------+
double   newCandles_Open[5]   = {106.785, 106.724, 106.760, 106.767, 106.769};
double   newCandles_High[5]   = {106.792, 106.765, 106.780, 106.781, 106.769};
double   newCandles_Low[5]    = {106.716, 106.719, 106.746, 106.758, 106.715};
double   newCandles_Close[5]  = {106.724, 106.760, 106.766, 106.769, 106.725};

int      tick_count           = 0;
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int OnInit()
{
//--- indicator buffers mapping
   SetIndexBuffer(0, barsBuffer1, INDICATOR_DATA);
   SetIndexBuffer(1, barsBuffer2, INDICATOR_DATA);
   SetIndexBuffer(2, barsBuffer3, INDICATOR_DATA);
   SetIndexBuffer(3, barsBuffer4, INDICATOR_DATA);
   
   ArraySetAsSeries(barsBuffer1  ,true);
   ArraySetAsSeries(barsBuffer2  ,true);
   ArraySetAsSeries(barsBuffer3  ,true);
   ArraySetAsSeries(barsBuffer4  ,true);
   
   ArrayInitialize(barsBuffer1   ,0.0);
   ArrayInitialize(barsBuffer2   ,0.0);
   ArrayInitialize(barsBuffer3   ,0.0);
   ArrayInitialize(barsBuffer4   ,0.0);
//---
   return(INIT_SUCCEEDED);
}
//+------------------------------------------------------------------+
//| Custom indicator iteration function                              |
//+------------------------------------------------------------------+
int  OnCalculate(
   const int        rates_total,       // размер входных таймсерий
   const int        prev_calculated,   // количество обработанных баров на предыдущем вызове
   const datetime&  time[],            // массив Time
   const double&    open[],            // массив Open
   const double&    high[],            // массив High
   const double&    low[],             // массив Low
   const double&    close[],           // массив Close
   const long&      tick_volume[],     // массив Tick Volume
   const long&      volume[],          // массив Real Volume
   const int&       spread[]           // массив Spread
   )
{
   if(rates_total - prev_calculated > 1)
   {
      if(prev_calculated == 0)
      {
         Print("~~~~ Предварительный расчёт индикатора.");
         for(int i = 0; i < 5; i++)
         {
            barsBuffer1[0] = newCandles_Open[i];
            barsBuffer2[0] = newCandles_High[i];
            barsBuffer3[0] = newCandles_Low[i];
            barsBuffer4[0] = newCandles_Close[i];
         }
         Print("~~~~ Предварительный расчёт индикатора закончен.");
      }
      else return(0);
   }
   else Print("tick_count = ",++tick_count);
//--- return value of prev_calculated for next call
   return(rates_total);
}
//+------------------------------------------------------------------+

Sie zeichnet nur diese Kerzenständer, mehr nicht.

Aber wenn ich es ausführe, zeichnet es einfach das verdammte Ding...

Sagen Sie mir also, was mache ich falsch?


Übrigens, in der Dokumentation gibt es einen Tippfehler:

const datetime&  time{},            // массив Time
Документация по MQL5: Обработка событий / OnCalculate
Документация по MQL5: Обработка событий / OnCalculate
  • www.mql5.com
события Calculate для обработки изменений ценовых данных. Существуют два варианта функции, в пределах одного индикатора нельзя использовать оба варианта. [in]  Размер массива price[] или входных таймсерий, доступных индикатору для расчета. Во втором варианте функции значение параметра соответствует количеству баров на графике, на котором он...
Dateien:
cTest.mq5  8 kb
 
Сергей Таболин:

Ich habe einen sehr einfachen Testindikator geschrieben, der 5 Kerzen (echte) aus dem USDJPY,H8 Chart zeichnen soll

Es zeichnet nur diese Leuchter, mehr nicht.

Aber wenn ich es ausführe, zeichnet es einfach das verdammte Ding...

Wie kann ich erklären, was ich falsch mache?


Übrigens, in der Dokumentation gibt es einen Tippfehler:

Prüfen Sie im Debugger time[0] und beantworten Sie die Frage: "Warum versuchen Sie, Candlesticks von der LINKEN Vorderseite des Charts zu zeichnen?


Ich habe Ihnen gesagt, dass Sie die Hilfe für DRAW_CANDLES verwenden sollen. Kopieren Sie das Beispiel aus der DRAW_CANDLES-Hilfe. Finden Sie es heraus. Es ist noch zu früh, um sich mit Zecken zu beschäftigen.

Документация по MQL5: Пользовательские индикаторы / Стили индикаторов в примерах / DRAW_CANDLES
Документация по MQL5: Пользовательские индикаторы / Стили индикаторов в примерах / DRAW_CANDLES
  • www.mql5.com
//|                                                 DRAW_CANDLES.mq5 | //|                        Copyright 2011, MetaQuotes Software Corp. | //|                                             https://www.mql5.com | "Рисует в отдельном окне разным цветом свечи по случайно выбранному из MarketWatch символу...
 
Vladimir Karputov:

Prüfen Sie im Debugger time[0] und beantworten Sie die Frage: "Warum versuchen Sie, die Kerzen vom LINKEN Rand des Diagramms zu zeichnen?


Ich habe Ihnen gesagt, dass Sie die Hilfe für DRAW_CANDLES verwenden sollen. Kopieren Sie das Beispiel aus der DRAW_CANDLES-Hilfe. Finden Sie es heraus. Es ist noch zu früh, um sich mit Zecken zu beschäftigen.

Vladimir, ich habe bereits verstanden, was ich mit dem linken Rand zu zeichnen versuchte. Das Testbild hat den richtigen Rand.

   ArraySetAsSeries(barsBuffer1  ,true);
   ArraySetAsSeries(barsBuffer2  ,true);
   ArraySetAsSeries(barsBuffer3  ,true);
   ArraySetAsSeries(barsBuffer4  ,true);

Und die Preise der Kerzenleuchter sind echt... Und keine Zecken...

 
Сергей Таболин:

Vladimir, ich habe bereits verstanden, dass ich versucht habe, vom linken Rand aus zu zeichnen. Der Test wird nun vom rechten Rand aus gezeichnet

Und die Candlestick-Preise sind echt... Und keine Zecken...

Nehmen Sie sich ein Beispiel an der Hilfe! Wie viele Male? Sie müssen nicht Ihre eigenen fiktiven Konstrukte verwenden, wenn Sie deren Bedeutung nicht verstehen. Verwenden Sie Standardkonstrukte - finden Sie heraus, wie sie funktionieren. Danach werfen Sie Ihre eigenen Konstrukte in den Papierkorb.


Und verwenden Sie den "MQL-Assistenten", um eine Vorlage zu erstellen.

Code

//+------------------------------------------------------------------+
//|                                                 Draw Candles.mq5 |
//|                        Copyright 2020, MetaQuotes Software Corp. |
//|                                             https://www.mql5.com |
//+------------------------------------------------------------------+
#property copyright "Copyright 2020, MetaQuotes Software Corp."
#property link      "https://www.mql5.com"
#property version   "1.00"
#property indicator_separate_window
#property indicator_buffers 4
#property indicator_plots   1
//--- plot USDJPY
#property indicator_label1  "USDJPY"
#property indicator_type1   DRAW_CANDLES
#property indicator_color1  clrRed
#property indicator_style1  STYLE_SOLID
#property indicator_width1  1
//--- input parameters
input int      Input1=9;
//--- indicator buffers
double   Buffer1[];
double   Buffer2[];
double   Buffer3[];
double   Buffer4[];
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int OnInit()
  {
//--- indicator buffers mapping
   SetIndexBuffer(0,Buffer1,INDICATOR_DATA);
   SetIndexBuffer(1,Buffer2,INDICATOR_DATA);
   SetIndexBuffer(2,Buffer3,INDICATOR_DATA);
   SetIndexBuffer(3,Buffer4,INDICATOR_DATA);
//---
   return(INIT_SUCCEEDED);
  }
//+------------------------------------------------------------------+
//| Custom indicator iteration function                              |
//+------------------------------------------------------------------+
int OnCalculate(const int rates_total,
                const int prev_calculated,
                const datetime &time[],
                const double &open[],
                const double &high[],
                const double &low[],
                const double &close[],
                const long &tick_volume[],
                const long &volume[],
                const int &spread[])
  {
//---
   int limit=prev_calculated-1;
   if(prev_calculated==0)
      limit=0;
   for(int i=limit; i<rates_total; i++)
     {
      Buffer1[i]=open[i];
      Buffer2[i]=high[i];
      Buffer3[i]=low[i];
      Buffer4[i]=close[i];
     }
//--- return value of prev_calculated for next call
   return(rates_total);
  }
//+------------------------------------------------------------------+

und das Ergebnis


Dateien:
Grund der Beschwerde: