任何菜鸟问题,为了不给论坛添乱。专业人士,不要路过。没有你就无处可去 - 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);
}

因此,该函数检查前两个条形图的值,如果它们太大,则返回TRUE。问题是如何很好地改进它,使这个功能在更多的蜡烛上寻找大蜡烛。例如24。

 
satorifx :
下午好。你知道在mql4中是否有可能即时改变指标参数?
这个想法很简单:ZigZag指标被安装在图表上。脚本应该写好,热键应该附在上面。 只要我一按,图表上的ZigZag参数就会改变。
有这样一种可能性。
 

我做了一个自制的专家顾问来测试交易,但我搞不清楚一件事。

使用最大和最小的MAs打开Bay/sell

//打开 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 ),但如何满足第二根开口蜡烛的条件。


如果你能用代码回答,这个例子就会更清楚。
 
Zhunko :
有这样一种可能性。

谢谢你令人难以置信的详细答复。

你真的要成为一个聪明人才能明白,如果一个新人带着问题 来到论坛,他们需要一个具体的解决方案或类似的链接,而不是一个 "一切皆有可能 "的愚蠢借口?

 
satorifx :

谢谢你令人难以置信的详细答复。

你真的要成为一个聪明人才能明白,如果一个新人带着问题 来到论坛,他们需要一个具体的解决方案或类似的链接,而不是一个 "一切皆有可能 "的愚蠢借口?

试图自己做一些事情的人在这里得到帮助。他们引导你走正确的方向,解释等等......。

你问了一个问题,你得到了一个答案。你是否尝试过自己开始写东西?

当以某种格式提出问题时,首先要想一想你会得到什么样的答案,问题的格式是什么?