MQL4、MQL5に関する初心者からの質問、アルゴリズムやコードに関するヘルプ、ディスカッションなど。 - ページ 1025

 

適切なジグザグをアドバイスしてください...というのも、今まで使っていたものが、時々すごくグラグラしてしまうので...。


 

教えてください、私はかなり理解していない - テスターのチャートでは、すべてのティックがM1であり、預金5000を開始したが、ドローダウンは62%(3325)を示し、それは明らかにチャート上にありません。齟齬?

モデリングの質でしょうか。テスターはこのドローダウンをどのように計算しているのでしょうか?計算するのであれば、なぜエクイティカーブで見ることができないのでしょうか?



 
Aleksey Mavrin:

計算するのであれば、なぜエクイティカーブに表示しないのでしょうか?

MT4では、1つの注文が決済されるまで、緑のエクイティラインが表示されません。

アレクセイ・マヴリン

ドローダウン率は62%(3325)を示していますが、チャートには明らかに表示されていません。不一致?

テスターは資本に応じてドローダウンを計算しますが、最大ドローダウンの注文に相対しています。つまり、テスターにオープンオーダーがあり、それを平均化すると、総資産はプラスになっているかもしれませんが、最も損失の大きい注文はテストのある瞬間に大きなドローダウンになっていました。


HH:モデリングの質が非常に低く、すべてのティックでTSをテストしているが、テストには非常に大きなTFが選ばれているhttps://www.mql5.com/ru/articles/1486

 
Igor Makanu:

MT4では、1つの注文が決済されるまで緑のエクイティラインが表示されず、決済されるとすぐに緑のラインが表示されます(MT5にはこの欠点はありません)。

テスターは、資本のドローダウンを考慮しますが、最大のドローダウンを持つ順序に相対的に、つまり、あなたがテスターでオープンオーダーを持っていたかもしれないし、あなたが平均している、あなたの総資産は、+にあったかもしれないが、最も損失の大きい順序は、テストの特定の瞬間に大きな赤字にあった


ZS: シミュレーションの質が非常に低く、全てのティックでTSをテストしているが、テストには非常に大きなTFが選ばれているhttps://www.mql5.com/ru/articles/1486

そうです、アベレージャーです。スッキリしました!ありがとうございました。エクイティラインだけは

私は彼の取引チャート(ビジュアライザーのことです)のグリッド平均をそのまま分析しました。つまり、彼は非常に頻繁にドローダウンをしており、チャート上のエクイティラインはこれを反映していません。例えば、次のようなものです。

trade 2018 December 04.トレード1238、チャート上では、これはトレード番号が1251である下の端から2番目の垂直破線に近いです。そこにある緑のエクイティラインには、ドローダウンの気配はない。

すなわち、どのように描画されるかはまだ不明だが、信用することは不可能であり、MT5で行うべきという結論になる)

R.S. シミュレーションの品質がなぜ悪いのかわからない、TFはM1、全ティックです。


 
Aleksey Mavrin:

そうです、アベレージャーです。これでより納得です!ありがとうございました。エクイティラインだけは

私は彼の取引チャート(ビジュアライザーのことです)のグリッド平均をそのまま分析しました。つまり、彼は非常に頻繁にドローダウンをしており、チャート上のエクイティラインはこれを反映していません。例えば、次のようなものです。

trade 2018 December 04.トレード1238、チャート上では、これはトレード番号が1251である下の端から2番目の垂直破線に近いです。そこにある緑のエクイティラインには、ドローダウンの気配はない。

すなわち、どのように描画されるかはまだ不明だが、信用することは不可能であり、MT5で行うべきという結論になる)

R.S. シミュレーションの品質がなぜ悪いのかわからない、TFはM1、全ティックです。


MetaTrader 4のテスターは、MetaTrader 5のテスターに比べると非常に見劣りします。何かが決済されるまで資金を表示することはできません。利益や損失を出した瞬間にのみ表示されます。写真では、すべてのショートポジションが一度に決済されているため、レポートにはオープニングとクローズの間にエクイティラインがありません。スクリーンショットのポジションを開いてから閉じるまでの 間に、少なくとも1つのポジションを決済していれば、決済時に持っていたエクイティドローダウンがレポートに反映されるはずです。つまり、レポートには2つのドローダウンが表示されます。1つのポジションを損失で決済したことによる貸借対照表上のドローダウンと、すべてのオープンポジションの資金に対する現在のフローティングロスのため、現在の資金のドローダウンによるものです。

 
Aleksey Mavrin:

つまり、どのように描かれているかはまだ不明だが、どう考えても信用できないので、MT5のせいにしておこうという結論になるのである)

信頼できますが、テスターレポートを すべて読む必要があります。

ドローダウンの推定値をコードに追加し、OnDeinit()でログに表示する。最大ドローダウンの計算でテスターをチェックする方法ということであれば、次のようなものです。

double minOrderProfit = 0.0;

int OnInit()
  {
   return(INIT_SUCCEEDED);
  }
//+------------------------------------------------------------------+
void OnDeinit(const int reason)
  {
   Print("minOrderProfit = ",minOrderProfit);
  }
//+------------------------------------------------------------------+
void OnTick()
  {
   for(int i=0;i<OrdersTotal();i++)
   {
      if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)) minOrderProfit = fmin(minOrderProfit,OrderProfit());
   }

// основной код

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


ZS: チェックしていませんが、動作するはずです。

 
Igor Makanu:

信頼できるが、テスターレポートを全部読む必要がある。

ドローダウンの見積もりをコードに追加し、OnDeinit()でログに出力する。最大ドローダウンの計算でテスターをチェックする方法ということであれば、次のようなものです。


ZS: チェックしていませんが、動作するはずです。

了解です、ありがとうございます。自分のEAでもテスター・オプティマイザー全般でも、シャープ係数など、ボラティリティやDDなど、毎日、毎月、合計、もちろん、できる限りの統計をとっているのですが。

これはMarketのロボットで実験したものですが、このようなカーブチャートは、このようなメガプロフィットでは存在し得ないことが分かっているので、チェックのために入れています。と確信したのは、つまりMT4でのエクイティカーブの表示方法のせいです

私は正しいことを確認しました、MT4で株式曲線がプロットされる方法のために、間違った評価は、製品の能力(あなたが貿易のチャートを見れば)、チャートがすべての市場でありながら、あなたはメッセージを取得しますか? :) s.s. 彼らは人々にクソを売って いる。

 

こんにちは。

インジケータを書きましたが、間違いがあることに気づきました。赤い水平線への質問(日中立会の始まりから)。

なんとなく使ってみたのですが、エキスパートアドバイザーでは正しく 動作せず、うまくいかなかったようです。そして、EAでのエントリーに誓うのです。

(2019.12.19 11:25:31.532 セッションデイ (EURUSDrfd,H1) 「セッションデイ.mq5」の配列が範囲外 (144,41)

ホールからのヘルプ...

事前に情報をありがとうございました


追記

RED LINEの方向(セッション開始)は、今日から昨日まで、RIGHT!!!!!!!

//+------------------------------------------------------------------+
//|                                                  Session Day.mq5 |
//|                        Copyright 2019, MetaQuotes Software Corp. |
//|                                             https://www.mql5.com |
//+------------------------------------------------------------------+
#property copyright "Copyright 2019, MetaQuotes Software Corp."
#property link      "https://www.mql5.com"
#property version   "1.00"
#property indicator_chart_window
#property indicator_buffers 5
#property indicator_plots   2
//---- plot ColorCandles
#property indicator_type1   DRAW_CANDLES
#property indicator_color1  White,Blue,Red
#property indicator_style1  STYLE_SOLID
#property indicator_width1  1
#property indicator_label1  "Open;High;Low;Close"
//----
#property indicator_type2   DRAW_LINE
#property indicator_color2  Red
#property indicator_style2  STYLE_SOLID
#property indicator_width2  3
#property indicator_label2  "Line open session"
//-----
input int     StartCandle = 100;         //Кол-во свечек для расчета средней
input int     StartBarDay = 0;           //Час начала торгового дня
input int     BarSession1 = 10;          //Чвс Открытия дневной сессии
input int     BarSession2 = 19;          //Чвс Закрытия дневной сессии
input bool    LevelOpenSession = true;   //Уровень открытия сессии дня
//---
double ExtOpenBuffer[];
double ExtHighBuffer[];
double ExtLowBuffer[];
double ExtCloseBuffer[];
double ExtBuffer[];
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
void OnInit()
  {
//--- indicator buffers mapping
   SetIndexBuffer(0,ExtOpenBuffer,INDICATOR_DATA);
   SetIndexBuffer(1,ExtHighBuffer,INDICATOR_DATA);
   SetIndexBuffer(2,ExtLowBuffer,INDICATOR_DATA);
   SetIndexBuffer(3,ExtCloseBuffer,INDICATOR_DATA);
   SetIndexBuffer(4,ExtBuffer,INDICATOR_DATA);
//--- установим цвет контура и теней
   PlotIndexSetInteger(0,PLOT_LINE_COLOR,0,clrWhite);
//--- установим цвет тела для бычьей свечи
   PlotIndexSetInteger(0,PLOT_LINE_COLOR,1,clrBlue);
//--- установим цвет тела для медвежьей свечи
   PlotIndexSetInteger(0,PLOT_LINE_COLOR,2,clrRed);
//--- set accuracy
   IndicatorSetInteger(INDICATOR_DIGITS,_Digits);
   if(Period()<PERIOD_H4)
      IndicatorSetString(INDICATOR_SHORTNAME,"Session Day \nOpen session: "+string(BarSession1)+" hour \nClose session: "+string(BarSession2)+" hour");
   else
      IndicatorSetString(INDICATOR_SHORTNAME,"Session Day");
   int bars=iBars(NULL,_Period);
   for(int b=0; b<5; b++)
      PlotIndexSetInteger(b,PLOT_DRAW_BEGIN,bars-StartCandle);
  }
//+------------------------------------------------------------------+
//| 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 i;
   if(rates_total<24)
      return(0);
   MqlDateTime tm;
//----
   if(prev_calculated==0)
     {
      ArrayInitialize(ExtOpenBuffer,EMPTY_VALUE);
      ArrayInitialize(ExtHighBuffer,EMPTY_VALUE);
      ArrayInitialize(ExtLowBuffer,EMPTY_VALUE);
      ArrayInitialize(ExtCloseBuffer,EMPTY_VALUE);
      ArrayInitialize(ExtBuffer,EMPTY_VALUE);
      i=0;
     }
   else
      i=prev_calculated-1;
//----
   while(i<rates_total && !IsStopped())
     {
      TimeToStruct(time[i],tm);
      if(Period()==PERIOD_MN1 && (tm.mon==4 || tm.mon==8 || tm.mon==12))
        {
         ExtOpenBuffer[i]=open[i];
         ExtHighBuffer[i]=high[i];
         ExtLowBuffer[i]=low[i];
         ExtCloseBuffer[i]=close[i];
        }
      if(Period()==PERIOD_W1 && tm.mon>=1 && tm.mon<=12 && tm.day>=1 && tm.day<8)
        {
         ExtOpenBuffer[i]=open[i];
         ExtHighBuffer[i]=high[i];
         ExtLowBuffer[i]=low[i];
         ExtCloseBuffer[i]=close[i];
        }
      if(Period()==PERIOD_D1 && tm.day_of_week==1)
        {
         ExtOpenBuffer[i]=open[i];
         ExtHighBuffer[i]=high[i];
         ExtLowBuffer[i]=low[i];
         ExtCloseBuffer[i]=close[i];
        }
      if(Period()==PERIOD_H4 && tm.hour==StartBarDay && tm.min==0)
        {
         ExtOpenBuffer[i]=open[i];
         ExtHighBuffer[i]=high[i];
         ExtLowBuffer[i]=low[i];
         ExtCloseBuffer[i]=close[i];
        }
      if(Period()<=PERIOD_H1 && tm.hour==BarSession1 && tm.min==0)
        {
         ExtOpenBuffer[i]=open[i];
         ExtHighBuffer[i]=high[i];
         ExtLowBuffer[i]=low[i];
         ExtCloseBuffer[i]=close[i];
        }
      if(Period()<=PERIOD_H1 && tm.hour==BarSession2 && tm.min==0)
        {
         ExtOpenBuffer[i]=open[i];
         ExtHighBuffer[i]=high[i];
         ExtLowBuffer[i]=low[i];
         ExtCloseBuffer[i]=close[i];
        }


                     ПРОБЛЕМА !!!!!
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
      if(LevelOpenSession==true && Period()==PERIOD_H1 && tm.hour==BarSession1 && tm.min==0)
         for(int j=0; j<24; j++)
           {
            ExtBuffer[i-j]=open[i];
            if(ExtBuffer[i-j]!=ExtBuffer[i-j-1])
               ExtBuffer[i-j-1]=EMPTY_VALUE;
           }
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
      //---
      i++;
     }
//--- return value of prev_calculated for next call
   return(rates_total);
  }
//+------------------------------------------------------------------+




 
kopeyka2:

こんにちは。

インジケータを書きましたが、間違いがあることに気づきました。赤い水平線への質問(日中立会の始まりから)。

なんとなく使ってみたのですが、エキスパートアドバイザーでは正しく 動作せず、うまくいかなかったようです。そして、EAでのエントリーに誓うのです。

(2019.12.19 11:25:31.532 セッションデイ (EURUSDrfd,H1) 「セッションデイ.mq5」の配列が範囲外 (144,41)


 ExtBuffer[i-j]=open[i];
            if(ExtBuffer[i-j]!=ExtBuffer[i-j-1])
               ExtBuffer[i-j-1]=EMPTY_VALUE;

このとき,ある時点で負の配列インデックスにアクセスする. i, j のすべての境界条件を設定し,チェックする.

 
Artyom Trishkin:

MetaTrader 4のテスターはMetaTrader 5に比べるとかなり劣る。何かが決済されるまで資金を表示することはできません。利益/損失が発生した瞬間にのみ表示されます。写真では、すべてのショートポジションが一度に決済されているため、レポートにはオープニングとクローズの間にエクイティラインがありません。スクリーンショットのポジションを開いてから閉じるまでの 間に、少なくとも1つのポジションを決済していれば、決済時に持っていたエクイティドローダウンがレポートに反映されるはずです。つまり、レポートには2つのドローダウンが表示されます。1つのポジションを損失で決済したことによるバランスシート上と、すべてのオープンポジションの資金に対する現在の浮動損失による現在の資金のドローダウンが表示されるのです。

なかなか分かりやすい説明ですね、ありがとうございます。最初、なぜか投稿に気づきませんでした(

そして質問) - AccountEquityなどのアカウントステータスに関する情報をテスター機能内部で要求すること。- というのは、ある位置が閉じていてもいなくても、正しい画像が表示されるのでしょうか?

例えば、長期間の取引を行い、株式のドローダウンが毎日記録されていれば、テスターは不正行為を行わないのでしょうか?