HMA_cd_2c_mtf





//+------------------------------------------------------------------+
//|                                                    HMA histo.mq4 |
//|                                                           mladen |
//+------------------------------------------------------------------+
//mod2009fxtsd macd
#property copyright "mladen"
#property link ""

#property indicator_separate_window
#property indicator_buffers 3
#property indicator_color1  DarkViolet
#property indicator_color2  Orange
#property indicator_color3  Red
#property indicator_width1  1
#property indicator_width2  1
#property indicator_width3  1

//
//
//
//
//

extern int  HMA_Period1    = 21;
extern int  HMA_Period2    = 34;

extern int  HMA_Method1    = MODE_LWMA;
extern int  HMA_Method2    = MODE_LWMA;
extern int  HMA_PriceType1 =  0;
extern int  HMA_PriceType2 =  0;

extern int  smzPeriod    = 5;
extern int  smzMethod    = 1;

extern int TimeFrame = 0;

extern string  note_TimeFrames = "M1;5,15,30,60H1;240H4;1440D1;10080W1;43200MN|0-CurrentTF";
extern string  MA_Method_Price = "SMA0 EMA1 SMMA2 LWMA3||0O,1C 2H3L,4Md 5Tp 6WghC: Md(HL/2)4,Tp(HLC/3)5,Wgh(HLCC/4)6";
string IndicatorFileName;

//
//
//
//
//

double ind_buffer1[];
double ind_buffer2[];
double sig_buffer[];
double buffer0[];
double buffer1[];
double buffer2[];


//+------------------------------------------------------------------
//|                                                                 |
//+------------------------------------------------------------------

int init()
{
   
   //
   //
   //
   //
   //
   TimeFrame=MathMax(TimeFrame, Period());
   
   IndicatorShortName("HMA CD ("+HMA_Period1+","+HMA_Period2+","+smzPeriod+") M"+TimeFrame);
   
   IndicatorBuffers(6);
   SetIndexBuffer(0,ind_buffer1);
   SetIndexBuffer(1,ind_buffer2);
   SetIndexBuffer(2,sig_buffer);
   SetIndexBuffer(3,buffer0);
   SetIndexBuffer(4,buffer1);
   SetIndexBuffer(5,buffer2);
   SetIndexStyle(0,DRAW_HISTOGRAM);
   SetIndexStyle(1,DRAW_HISTOGRAM);
   SetIndexStyle(2,DRAW_LINE);
   
   int draw_begin=smzPeriod+HMA_Period1+HMA_Period2;
   for (int i = 0; i < indicator_buffers; i++)
   {
         SetIndexDrawBegin(i,draw_begin);
         SetIndexLabel(i,"Hull Moving Average");
   }         
   
   IndicatorFileName = WindowExpertName();

   return(0);
}


//+------------------------------------------------------------------+
//|                                                                  |
//+------------------------------------------------------------------+

int start()
{
   int HalfPeriod1   = MathFloor(HMA_Period1/2);
   int HullPeriod1   = MathFloor(MathSqrt(HMA_Period1));

   int HalfPeriod2   = MathFloor(HMA_Period2/2);
   int HullPeriod2   = MathFloor(MathSqrt(HMA_Period2));
   
   
   int counted_bars = IndicatorCounted();
   int limit,i;
   

   if(counted_bars<0) return(-1);
   if(counted_bars>0) counted_bars--;
      limit=Bars-counted_bars;



   if (TimeFrame != Period())
      {
         limit = MathMax(limit,TimeFrame/Period());
           
          for(i=limit; i>=0; i--)
          {
            int y = iBarShift(NULL,TimeFrame,Time[i]);
            ind_buffer1[i] = iCustom(NULL,TimeFrame,IndicatorFileName,HMA_Period1,HMA_Period2,HMA_Method1,HMA_Method2,HMA_PriceType1,HMA_PriceType2,smzPeriod,smzMethod,0,y);
            ind_buffer2[i] = iCustom(NULL,TimeFrame,IndicatorFileName,HMA_Period1,HMA_Period2,HMA_Method1,HMA_Method2,HMA_PriceType1,HMA_PriceType2,smzPeriod,smzMethod,1,y);
            sig_buffer[i]  = iCustom(NULL,TimeFrame,IndicatorFileName,HMA_Period1,HMA_Period2,HMA_Method1,HMA_Method2,HMA_PriceType1,HMA_PriceType2,smzPeriod,smzMethod,2,y);
     
          
          }

         return(0);         
      }

   
   
   
   for(i=limit; i>=0; i--)
   {
         buffer1[i]=iMA(NULL,0,HalfPeriod1,0,HMA_Method1,HMA_PriceType1,i)*2-
                    iMA(NULL,0,HMA_Period1,0,HMA_Method1,HMA_PriceType1,i);

         buffer2[i]=iMA(NULL,0,HalfPeriod2,0,HMA_Method2,HMA_PriceType2,i)*2-
                    iMA(NULL,0,HMA_Period2,0,HMA_Method2,HMA_PriceType2,i);
   }


   for(i=limit; i>=0; i--)
   
         buffer0[i] =  iMAOnArray(buffer1,0,HullPeriod1,0,HMA_Method1,i)-
                       iMAOnArray(buffer2,0,HullPeriod2,0,HMA_Method2,i);

   for(i=limit; i>=0; i--)
   {
      sig_buffer[i]  =  iMAOnArray(buffer0,0,smzPeriod,0,smzMethod,i);

               
               
               
               
               ind_buffer1[i]=EMPTY_VALUE;   ind_buffer1[i]=EMPTY_VALUE;
      
      
      if (buffer0[i]>buffer0[i+1])  ind_buffer1[i]=buffer0[i];
      else     
      if (buffer0[i]<buffer0[i+1])  ind_buffer2[i]=buffer0[i];
      else                      {          
                                    ind_buffer1[i]=buffer1[i+1];
                                    ind_buffer2[i]=buffer2[i+1];
                                 }              
                                          
                                          
   }                                       
                                           
      //
      //
      //
      //
      //
            
   
   return(0);
}



Sample





Analysis



Market Information Used:

Series array that contains open time of each bar


Indicator Curves created:


Implements a curve of type DRAW_HISTOGRAM
Implements a curve of type DRAW_LINE

Indicators Used:


Moving average indicator


Custom Indicators Used:
IndicatorFileName

Order Management characteristics:

Other Features: