ADX_HDSqz_mtf_v1





//+------------------------------------------------------------------+
//| ADX_HDSqueeze_mtf                                        ADX.mq4 |
//|                                      Copyright © 2006, Keris2112 |
//|DI levelShift; +DI-(-DI)Hist; MTF keris ki  www.forex-tsd.com 2007|
//+------------------------------------------------------------------+
#property copyright "Copyright © 2006, Keris2112"
#property link      "http://www.forex-tsd.com"

#property indicator_separate_window
#property indicator_buffers 6
#property indicator_color1 RoyalBlue
#property indicator_color2 ForestGreen
#property indicator_color3 Red
#property indicator_color4 LimeGreen
#property indicator_color5 Red
#property indicator_color6 Gold
#property indicator_width1 1
#property indicator_width2 2
#property indicator_width3 2

#property indicator_width5 1

#property indicator_level1  30
#property indicator_level2  20
#property indicator_level3 -20
#property indicator_levelcolor DarkSlateGray
#property indicator_levelstyle 4
//#property indicator_maximum 400
//#property indicator_minimum -400


//---- input parameters
/*************************************************************************
PERIOD_M1   1
PERIOD_M5   5
PERIOD_M15  15
PERIOD_M30  30 
PERIOD_H1   60
PERIOD_H4   240
PERIOD_D1   1440
PERIOD_W1   10080
PERIOD_MN1  43200
You must use the numeric value of the timeframe that you want to use
when you set the TimeFrame' value with the indicator inputs.
---------------------------------------
PRICE_CLOSE    0 Close price. 
PRICE_OPEN     1 Open price. 
PRICE_HIGH     2 High price. 
PRICE_LOW      3 Low price. 
PRICE_MEDIAN   4 Median price, (high+low)/2. 
PRICE_TYPICAL  5 Typical price, (high+low+close)/3. 
PRICE_WEIGHTED 6 Weighted close price, (high+low+close+close)/4. 
You must use the numeric value of the Applied Price that you want to use
when you set the 'applied_price' value with the indicator inputs.
**************************************************************************/
extern int TimeFrame=0;
extern int ADXperiod=14;
extern int DI_vertShift = 0;
extern int       BBsqueezArwShift=-15;
extern int       bolPrd=20;
extern double    bolDev=2.0;
extern int       keltPrd=20;
extern double    keltFactor=1.5;



extern int MaxBarsToCount   = 1500;
//extern string  note__MaMode_Price = "Price(OCHLMTF)ModeMa(SMA0,EMA1,SmmMA2,LWMA3";
extern string  note_TimeFrames = "M1;5,15,30,60H1;240H4;1440D1;10080W1;43200MN|0-CurrentTF";

double ExtMapBuffer1[];
double ExtMapBuffer2[];
double ExtMapBuffer3[];
double ExtMapBuffer4[];
double ExtMapBuffer5[];
double arrowBuffer[];
double DVertShift;
double diff,std,bbs;

//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int init()
  {

//---- indicator line
    SetIndexEmptyValue(0,EMPTY_VALUE);
    SetIndexEmptyValue(1,EMPTY_VALUE);
    SetIndexEmptyValue(2,EMPTY_VALUE);
    SetIndexEmptyValue(3,EMPTY_VALUE);
    SetIndexEmptyValue(4,EMPTY_VALUE);
 
   SetIndexBuffer(0,ExtMapBuffer1);
   SetIndexBuffer(1,ExtMapBuffer2);
   SetIndexBuffer(2,ExtMapBuffer3);
   
   SetIndexBuffer(3,ExtMapBuffer4);
   SetIndexBuffer(4,ExtMapBuffer5);


   SetIndexStyle(0,DRAW_LINE);
   SetIndexStyle(1,DRAW_HISTOGRAM);
   SetIndexStyle(2,DRAW_HISTOGRAM);
   SetIndexStyle(3,DRAW_LINE);
   SetIndexStyle(4,DRAW_LINE);
  
    SetIndexEmptyValue(5,EMPTY_VALUE);
    SetIndexBuffer    (5,arrowBuffer);
    SetIndexStyle     (5,DRAW_ARROW);
    SetIndexArrow     (5,158); //159

   SetIndexLabel(0,"ADX ("+ADXperiod+")["+TimeFrame+"]");
   SetIndexLabel(1,"");
   SetIndexLabel(2,"");
   SetIndexLabel(3,"ADX-DI ("+ADXperiod+")["+TimeFrame+"]");
   SetIndexLabel(4,"ADX-DI ("+ADXperiod+")["+TimeFrame+"]");
   SetIndexLabel(5,"BBsquise ("+ADXperiod+")["+TimeFrame+"]");

//---- name for DataWindow and indicator subwindow label
   switch(TimeFrame)
   {
      case 1: string TimeFrameStr ="M1";  break;
      case 5     :   TimeFrameStr ="M5";  break;
      case 15    :   TimeFrameStr ="M15"; break;
      case 30    :   TimeFrameStr ="M30"; break;
      case 60    :   TimeFrameStr ="H1";  break;
      case 240   :   TimeFrameStr ="H4";  break;
      case 1440  :   TimeFrameStr ="D1";  break;
      case 10080 :   TimeFrameStr ="W1";  break;
      case 43200 :   TimeFrameStr ="MN1"; break;
      default :  TimeFrameStr  =  "TF 0";
   }
   IndicatorShortName("ADX ("+ADXperiod+") ["+TimeFrameStr+"]");

  }
//----
   return(0);
 
//+------------------------------------------------------------------+
//| MTF                                                              |
//+------------------------------------------------------------------+
int start()
  {
   datetime TimeArray[];
   int    i,limit,y=0,counted_bars=IndicatorCounted();
 
// Plot defined time frame on to current time frame
   ArrayCopySeries(TimeArray,MODE_TIME,Symbol(),TimeFrame); 
   limit=Bars-counted_bars;
   limit=MathMax(limit,TimeFrame/Period());
   limit= MathMin(limit,MaxBarsToCount);

   for(i=0,y=0;i<limit;i++)
   {
   if (TimeFrame<Period()) TimeFrame=Period();
   if (Time[i]<TimeArray[y]) y++;
/***********************************************************   
   Add your main indicator loop below.  You can reference an existing
      indicator with its iName  or iCustom.
   Rule 1:  Add extern inputs above for all neccesary values   
   Rule 2:  Use 'TimeFrame' for the indicator time frame
   Rule 3:  Use 'y' for your indicator's shift value
 **********************************************************/  
   ExtMapBuffer2[i]= iADX(NULL,TimeFrame,ADXperiod,0,1,y)-iADX(NULL,TimeFrame,ADXperiod,0,2,y);
   ExtMapBuffer4[i]= iADX(NULL,TimeFrame,ADXperiod,0,1,y)-DI_vertShift ; 
   ExtMapBuffer5[i]= iADX(NULL,TimeFrame,ADXperiod,0,2,y)-DI_vertShift ; 
 
if (ExtMapBuffer2[i] <0) {ExtMapBuffer3[i]=ExtMapBuffer2[i]; ExtMapBuffer2[i]=EMPTY_VALUE;}
    ExtMapBuffer1[i]= iADX(NULL,TimeFrame,ADXperiod,0,0,y); 
  
      diff = iATR(NULL,TimeFrame,keltPrd,y)*keltFactor;
      std = iStdDev(NULL,TimeFrame,bolPrd,MODE_SMA,0,PRICE_CLOSE,y);
      bbs = bolDev * std / diff;

      if(bbs<1) {arrowBuffer[i] = BBsqueezArwShift; }

  
  
                          
   }  
 /*
 //----  Refresh buffers ++++++++++++++++++++++++++++++++   
   if (TimeFrame>Period()) {
     int PerINT=TimeFrame/Period()+1;
     datetime TimeArr[]; ArrayResize(TimeArr,PerINT);
     ArrayCopySeries(TimeArr,MODE_TIME,Symbol(),Period()); 
     for(i=0;i<PerINT+1;i++) {if (TimeArr[i]>=TimeArray[0]) {
 //********************************************************     
    Refresh buffers:         buffer[i] = buffer[0];
 //********************************************************  
   ExtMapBuffer1[i]=ExtMapBuffer1[0];
   ExtMapBuffer2[i]=ExtMapBuffer2[0];
   ExtMapBuffer3[i]=ExtMapBuffer3[0];
   ExtMapBuffer4[i]=ExtMapBuffer4[0];
   ExtMapBuffer5[i]=ExtMapBuffer5[0];


   } } }
   */
//+++++++++++++++++++++++++++++++++++++++++++++   Raff 
   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_LINE
Implements a curve of type DRAW_HISTOGRAM

Indicators Used:

Movement directional index
Indicator of the average true range
Standard Deviation indicator


Custom Indicators Used:

Order Management characteristics:

Other Features: