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

 

だから、うまくいけば、関数の最終形ができる。

double ATR_Max() {
int i;
double m;
datetime tim;
iATR_H1_PER = 15;// период
if ( tim != Time[0] ) {  
while( i < WindowBarsPerChart() ) {
double a = iATR( NULL, 0, iATR_H1_PER, i );
   if ( m < a ) {
   m = a;
   }
   i++;
   tim = Time[0];
  }
}
Alert( " Максимальное значение ATR для видимого количества баров равно - ", m );
return(m);
} 
 
dr.Vasgenich :

だから、うまくいけば、関数の最終形ができる。

Dr.Vasgenich :

だから、うまくいけば、関数の最終形ができる。

私はtim = Time[0]はループの後に置いた方が良いと思います...なぜならTime[0]を尋ねることはすべての可視バーで 行われます - それは合理的ではありません。
 
Boeing747 :
私はtim = Time[0]はループの後に置いた方が良いと思います...なぜならTime[0]を求めることは可視バーのすべての数に対して行われるからです - それは合理的ではありません。
訂正ありがとうございます。夜間はエラーの数が指数関数的に 増える)))
 
dr.Vasgenich :
訂正ありがとうございます。夜間はエラーの数が指数関数的に増える)))
指数関数的に))。しかし、私もそろそろ寝ます。何か必要なものがあれば言ってください))
 
こんにちは。mql4でインジケーターのパラメーターをその場で変更することが可能かどうかご存知ですか?
考え方は簡単で、チャート上にZigZagインジケータを設置します。スクリプトを書き、そのスクリプトにホットキーを付けます。 これを押すと、チャート上でジグザグのパラメータが変更されます。
 

高揮発性フィルターを探すという現在のトピックの続きです。以下は、WSRの既存のフィルタのコードです。

extern string ____ = "Фильтр волатильности";
extern bool VolatilityFilter              = FALSE;
extern int VolaFilter                     = 25; //--- (15 1 30)
double pp;
double pd;

int init()

   if (Digits < 4) {
      pp = 0.01;
      pd = 2;
   } else {
      pp = 0.0001;
      pd = 4;
   }

以下、機能そのものを紹介します。

bool CheckVolatility() {
   double HeightFilter_a = NormalizeDouble(VolaFilter * pp, pd);
   bool restrict = false;
   if (NormalizeDouble(iHigh(NULL, PERIOD_M5, 1) - iLow(NULL, PERIOD_M5, 1), pd) > HeightFilter_a) restrict = true;
   if (NormalizeDouble(iHigh(NULL, PERIOD_M5, 2) - iLow(NULL, PERIOD_M5, 2), pd) > HeightFilter_a) restrict = true;
   return (restrict);
}

したがって、この関数は、前の2つのバーの値をチェックし、大きすぎる場合は、TRUEを返します。問題は、それをうまく改良して、より多くのキャンドルに大きなキャンドルを探させる方法です。例えば24。

 
satorifx :
こんにちは。mql4でインジケーターのパラメーターをその場で変更することが可能かどうかご存知ですか?
考え方は簡単で、チャート上にZigZagインジケータを設置します。スクリプトを書き、それにホットキーを付ける。 それを押すとすぐにZigZagのパラメータがチャート上で変化するようにする。
そんな可能性もあるのです。
 

自作のExpert Advisorを作って取引のテストをしているのですが、ひとつだけわからないことがあります...。

最大・最小MAを使ってベイ/セルをオープン

// BUYポジションをオープン する条件
if(MA_L1<MA_L0&&Ask<)=MA_L0&MA_0>MA_1&&HA_up>HA_dw)

// 売りポジションを建てるための条件
if(MA_H1>MA_H0&&Bid>=MA_H0&MA_0<MA_1&HA_up<HA_dw)

#include <b-Lots.mqh>
extern double TrailingStop = 30;
extern double Sploss = 15;
//+------------------------------------------------------------------+
//| |
//+------------------------------------------------------------------+
int start() {
   double HA_up,HA_dw;
   double MA_H0,MA_H1,MA_L0,MA_L1,MA_0,MA_1;
   int i, cnt, ticket, total;
   bool flag=true;

   if(Bars<100) {
      Print("bars less than 100");
      return(0); 
   }
// Проверяем стоит ли открываться
   
   cnt=OrdersHistoryTotal()-1;
   for(i=cnt;i>=0;i--) {
      if(!OrderSelect(i, SELECT_BY_POS, MODE_HISTORY )) continue;
      if(OrderOpenTime()>=Time[0]) { // Time[0] - если позиция открывается на нулевом баре текущего символа
         flag=false;
         break;
      }
   }
   cnt=OrdersTotal()-1;
   for(i=cnt;i>=0;i--) {
      if(!OrderSelect(i, SELECT_BY_POS, MODE_TRADES)) continue;
      if(OrderOpenTime()>=Time[0]) { // Time[0] - если позиция открывается на нулевом баре текущего символа
         flag=false;
         break;
      }
   }
   if(!flag) return(0); 
//-----------------------------------------------
   MA_H0=iMA(0,0,3,0,MODE_SMA,PRICE_HIGH,0);
   MA_H1=iMA(0,0,3,0,MODE_SMA,PRICE_HIGH,1);
   MA_0=iMA(0,0,3,0,MODE_EMA,PRICE_MEDIAN,0);
   MA_1=iMA(0,0,3,0,MODE_EMA,PRICE_MEDIAN,1);
   MA_L0=iMA(0,0,3,0,MODE_SMA,PRICE_LOW,0);
   MA_L1=iMA(0,0,3,0,MODE_SMA,PRICE_LOW,1);
   HA_up=iCustom(0,0,"Heiken Ashi",3,0);
   HA_dw=iCustom(0,0,"Heiken Ashi",2,0);

//задали все данные 

   total=OrdersTotal();
   if(total<1) 
     {
      // Проверка свободной маржи
      if(AccountFreeMargin()<(1000*Lots))
        {
         Print("We have no money. Free Margin = ", AccountFreeMargin());
         return(0);  
        }
      // Условие открытие позиции BUY
      if(MA_L1<MA_L0&&Ask<=MA_L0&&MA_0>MA_1&&HA_up>HA_dw)
        {
         Lots=GetSizeLot();
         ticket=OrderSend(Symbol(),OP_BUY,Lots,Ask,5,Bid-Sploss*Point,0,"",16384,0,Green);
         if(ticket>0)
           {
            if(OrderSelect(ticket,SELECT_BY_TICKET,MODE_TRADES)) Print("BUY order opened : ",OrderOpenPrice());
           }
         else Print("Error opening BUY order : ",GetLastError()); 
         return(0); 
        }
      // Условие открытие позиции SELL
      if(MA_H1>MA_H0&&Bid>=MA_H0&&MA_0<MA_1&&HA_up<HA_dw)
        {
         Lots=GetSizeLot();
         ticket=OrderSend(Symbol(),OP_SELL,Lots,Bid,5,Ask+Sploss*Point,0,"",16384,0,Red);
         if(ticket>0)
           {
            if(OrderSelect(ticket,SELECT_BY_TICKET,MODE_TRADES)) Print("SELL order opened : ",OrderOpenPrice());
           }
         else Print("Error opening SELL order : ",GetLastError()); 
         return(0); 
        }
      return(0);
     }
    
   for(cnt=0;cnt<total;cnt++)
     {
      OrderSelect(cnt, SELECT_BY_POS, MODE_TRADES);
      if(OrderType()<=OP_SELL &&   
         OrderSymbol()==Symbol())  
        {
         if(OrderType()==OP_BUY)   // длинная позиция открыта
           {
           if(NormalizeDouble (MathAbs(MA_H0-Bid),Digits)<Point)
                {
                 OrderClose(OrderTicket(),OrderLots(),Bid,3,Violet); 
                 return(0); 
                }
            // трейлинг-стоп для длинной позиции
            if(TrailingStop>0)  
              {                 
               if(Bid-OrderOpenPrice()>Point*TrailingStop)
                 {
                  if(OrderStopLoss()<Bid-Point*TrailingStop)
                    {
                     OrderModify(OrderTicket(),OrderOpenPrice(),Bid-Point*TrailingStop,OrderTakeProfit(),0,Green);
                     return(0);
                    }
                 }
              }
           }
         else 
           {
           if(NormalizeDouble (MathAbs(MA_L0-Ask),Digits)<Point)
              {
               OrderClose(OrderTicket(),OrderLots(),Ask,3,Violet); 
               return(0); 
              }
            // трейлинг-стоп для короткой позиции
            if(TrailingStop>0)  
              {                 
               if((OrderOpenPrice()-Ask)>(Point*TrailingStop))
                 {
                  if((OrderStopLoss()>(Ask+Point*TrailingStop)) || (OrderStopLoss()==0))
                    {
                     OrderModify(OrderTicket(),OrderOpenPrice(),Ask+Point*TrailingStop,OrderTakeProfit(),0,Red);
                     return(0);
                    }
                 }
              }
           }
        }
     }
   return(0);
  }
質問:現在のローソク足のポジションがクローズしていない(条件が来ていない)場合、MA_0= iMA ( 0, 0, 3, 0, MODE_EMA, PRICE_MEDIAN, 0 );

クローズ条件:現在のローソクの高値または安値を越えるが、ポジションを開いた後、次のローソクで閉じることが必要である。

if ( NormalizeDouble ( MathAbs (MA_0-Ask), Digits )< Point ) と書けばいいのですが、2本目のオープンローソクの条件をどう満たすかです。


コードで答えられると、例題が明確になります。
 
Zhunko :
そんな可能性もあるのです。

信じられないほど詳細な回答ありがとうございます。

新しい人が質問しに フォーラムに来たら、「何でもあり」という間抜けな言い訳ではなく、具体的な解決策や類似のものへのリンクが必要だということが、本当に頭の悪い人でないと理解できないのでしょうか?

 
satorifx :

信じられないほど詳細な回答ありがとうございます。

新しい人が質問しに フォーラムに来たら、「何でもあり」という間抜けな言い訳ではなく、具体的な解決策や類似のものへのリンクが必要だということが、本当に頭の悪い人でないと理解できないのでしょうか?

自分で何かをしようとする人は、ここで助けてもらう。正しい方向に導いてくれる、説明してくれる、などなど.

質問して、答えが返ってきた。自分で何かを書き始めようとしたことはありますか?

ある形式で質問をする場合、まず、質問の形式に対してどのような答えが返ってくるかを考え...