どんな新人の質問でも、フォーラムを乱雑にしないように。プロフェッショナルは、通り過ぎないでください。Nowhere without you - 6. - ページ 167

 
現在のチャートではなく、現在のタイム フレームのOpen[]を取得するには?
 

みなさん、こんにちは。

利他主義が価値を失った昨今、時間を惜しまず新人を助けてくれる皆さんに感謝します。

フォーラムのユーザーに助けを求め、Igorのスレッドをすべて読みましたが、私が必要とするものが見つからなかったので、ここに書き込むことにしました。

難しいことではなく、すでにどこかにあるのではないかと思われる機能ですが...。

MINUTE(5,15,30,60, ...)BACK の現在(前, ...)の日次(週次, ...)の最大/最小を計算するにはどうしたらいいですか?

利他的なプロフェッショナルの方々には、とても感謝しています。

 
KAVrus:

みなさん、こんにちは。

利他主義が価値を失った昨今、時間を惜しまず新人を助けてくれる皆さんに感謝します。

私はフォーラムのユーザーに助けを求める、私は全体のスレッドIgorを読みましたが、私は私が必要とするものを見つけていないので、私はここに書き込むことにしました。

複雑な機能ではなく、すでにどこかに存在しているのではないかと思うのですが......。

MINUTE(5,15,30,60, ...)BACKの 現在(前、...)の日次(週次、...)の最大/最小をどのように計算するのでしょうか?

利他的なプロフェッショナルの方々には、とても感謝しています。


:)))面白いですね。

読んでみて ください。面白いことがたくさんありますよ。:)))

 
boing9267:
現在のチャートではなく、現在のタイム フレームのOpen[]を取得するには?
iOpen() です。
 
TarasBY:

:))))))))))))))))))))))))))))))))笑っちゃいましたよ。

読んでみて ください。面白いことがたくさんありますよ。:)))


笑うのは罪だ・・・・・・)))


読んだよ..."他の時間軸のボリュームはモデル化されていない"

では、質問のポイントを間違えていたようだ...。簡略化してみる。

現在のローソクの1分後の 最大値/最小値は、どのように計算するのですか?

 
TarasBY:
iOpen() です。


ありがとうございました。
 
KAVrus:

笑うのは罪だ・・・・・・)))


読む..."他の時間軸のボリュームはシミュレートされない"

では、質問のポイントを間違えていたようだ...。簡略化してみる。

現在の日足ロウソクの1分後の 最大値/最小値は、どのように計算するのですか?

読むより(ましてや "掘り下げる "より)笑う方が簡単なんです...。:)))

コードで解決してみましょう。

    //---- Находим последний расчётный бар на нужном нам тамфрейме
    int li_Shift = iBarShift (Symbol(), PERIOD_M1, iTime (Sumbol(), PERIOD_D1, 0)),
        //---- Ищем на нужном промежутке номер бара с High
        li_Bar = iHighest (Symbol(), PERIOD_M1, MODE_HIGH, li_Shift, 1);
    //---- Получаем значение High
    double ld_HIGH = iHigh (Symbol(), PERIOD_M1, li_Bar);

最小限のイメージと類似性で、対応できるのか!;)

追伸:価格履歴は最小1分単位の離散性を持っているので、「1分前」ではなく「直前1分を数えない」という表現が正しいです。

 
TarasBY:

笑うことは読むこと(ましてや「入り込む」こと)よりも簡単なのです...。:)))

コードで解決しようとする。

あなたのイメージでは、最低限で対応できるのでしょうか!;)

追伸:価格履歴には最小1分という離散性があるので、「1分前」ではなく「直近1分を数えない」という表現が正しいです。


ありがとうございます!!!
 
こんにちは、みんな、インジケータsAccelerator.mq4で助けて ください。 私は0ラインが交差したときにアラートを作りたい、と削除する着色アラート、それは動作しませんし、mqlで率直に言って、私は理解していないです。
//+------------------------------------------------------------------+
//|                                                 sAccelerator.mq4 |
//|                      Copyright © 2005, MetaQuotes Software Corp. |
//|                                       http://www.metaquotes.net/ |
//+------------------------------------------------------------------+
#property  copyright "Copyright © 2005, MetaQuotes Software Corp."
#property  link      "http://www.metaquotes.net/"
//---- indicator settings
#property  indicator_separate_window
#property  indicator_buffers 3
#property  indicator_color1  Black
#property  indicator_color2  Lime
#property  indicator_color3  Red
//---- indicator buffers
double ExtBuffer0[];
double ExtBuffer1[];
double ExtBuffer2[];
double ExtBuffer3[];
double ExtBuffer4[];
// Номер бара, по которому будет искаться сигнал
#define SIGNAL_BAR 1
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int init()
  {
//---- 2 additional buffers are used for counting.
   IndicatorBuffers(5);
//---- drawing settings
   SetIndexStyle(0, DRAW_NONE);
   SetIndexStyle(1, DRAW_HISTOGRAM);
   SetIndexStyle(2, DRAW_HISTOGRAM);
   IndicatorDigits(Digits + 2);
   SetIndexDrawBegin(0, 38);
   SetIndexDrawBegin(1, 38);
   SetIndexDrawBegin(2, 38);
//---- 4 indicator buffers mapping
   SetIndexBuffer(0, ExtBuffer0);
   SetIndexBuffer(1, ExtBuffer1);
   SetIndexBuffer(2, ExtBuffer2);
   SetIndexBuffer(3, ExtBuffer3);
   SetIndexBuffer(4, ExtBuffer4);
//---- name for DataWindow and indicator subwindow label
   IndicatorShortName("sAC");
   SetIndexLabel(1, NULL);
   SetIndexLabel(2, NULL);
//---- initialization done
   return(0);
  }
//+------------------------------------------------------------------+
//| Accelerator/Decelerator Oscillator                               |
//+------------------------------------------------------------------+
int start()
  {
   int    limit;
   int    counted_bars = IndicatorCounted();
   double prev, current;
//---- last counted bar will be recounted
   if(counted_bars > 0) 
       counted_bars--;
   limit = Bars - counted_bars;
//---- macd counted in the 1-st additional buffer
   for(int i = 0; i < limit; i++)
       ExtBuffer3[i] = iMA(NULL, 0, 5, 0, MODE_SMA, PRICE_MEDIAN, i) - 
                       iMA(NULL, 0, 34, 0, MODE_SMA, PRICE_MEDIAN, i);
//---- signal line counted in the 2-nd additional buffer
   for(i = 0; i < limit; i++)
       ExtBuffer4[i] = iMAOnArray(ExtBuffer3, Bars, 5, 0, MODE_SMA, i);
//---- dispatch values between 2 buffers
   bool up = true;
   for(i = limit - 1; i >= 0; i--)
     {
       current = ExtBuffer3[i] - ExtBuffer4[i];
       prev = ExtBuffer3[i+1] - ExtBuffer4[i+1];
       if(current > prev) 
           up = true;
       if(current < prev) 
           up = false;
       if(!up)
         {
           ExtBuffer2[i] = current;
           ExtBuffer1[i] = 0.0;
         }
       else
         {
           ExtBuffer1[i] = current;
           ExtBuffer2[i] = 0.0;
         }
       ExtBuffer0[i] = current;
     }
//---- done
    //---- Статические переменные, в которых хранятся
    //---- время последнего бара и направление последнего сигнала
    static int PrevSignal = 0, PrevTime = 0;
 
    //---- Если баром для анализа выбран не 0-й, нам нет смысла проверять сигнал
    //---- несколько раз. Если не начался новый бар, выходим.
    if(SIGNAL_BAR > 0 && Time[0] <= PrevTime ) 
        return(0);
    //---- Отмечаем, что этот бар проверен
    PrevTime = Time[0];
          if(PrevSignal <= 0)
      {
        if(MainBuffer[SIGNAL_BAR] - 0.0 > 0 && 
           0.0 - MainBuffer[SIGNAL_BAR+1] >= 0)
          {
            PrevSignal = 1;
            Alert("sAC (", Symbol(), ", ", Period(), ")  -  BUY!!!");
          }
      }
    if(PrevSignal >= 0)
      {
        if(0.0 - MainBuffer[SIGNAL_BAR] > 0 && 
           MainBuffer[SIGNAL_BAR+1] - 0.0 >= 0)
          {
            PrevSignal = -1;
            Alert("sAC (", Symbol(), ", ", Period(), ")  -  SELL!!!");
          }
      } 
   return(0);
  }
//+------------------------------------------------------------------+

 

皆さん、バーの平均ティックの求め方をアドバイスしてください。次のように想定しています。

Average[i] = (bar[i] のティックの総量)/Volume[i]; 目的のバーのティックの総量を求めるにはどうしたらいいですか?