_Turtle Channel Indicator





//+------------------------------------------------------------------+
//|                              Turtle Channel Method(Donchain).mq4 |
//|                                           djindyFX@sbcglobal.net |
//|      http://www.learncurrencytrading.com/fxforum/blogs/djindyfx/ |
//+------------------------------------------------------------------+
#property copyright "djindyFX@sbcglobal.com"
#property link      "http://www.learncurrencytrading.com/fxforum/blogs/djindyfx/"
/* - Original Donchain channel code posted here: http://codebase.mql4.com/ru/1317
      Periods: number of bars used for calculating the Donchian channels
               3 Seperate Channels are provided, Long term, Medium, and Short Term
      Extremes: 1 uses the highest high and the lowest low to create the Channel
                0 uses the open of the extremes bar -> the open point of a bar (as well as the close
                   are the points of maximum probability of concentration of the prices during the bar
                3 uses the median point most extreme open and lowest low or highest high
      Margins: is the percent of the channel subtrated from the channel border before printing it, negative values are allowed
      Advance: the numbers of bars ahead
*/


#property indicator_chart_window
#property indicator_buffers 6
#property indicator_color1 White
#property indicator_color2 White
#property indicator_color3 Yellow
#property indicator_color4 Yellow
#property indicator_color5 Red
#property indicator_color6 Red

//---- input parameters
extern int       LngPeriod=50;
extern int       MedPeriod=20;
extern int       ShtPeriod=10;
extern int       Extremes=1;
extern int       Margins=0; 
extern int       Advance=0;

// - Buffers
double Channel1[];
double Channel2[];
double Channel3[];
double Channel4[];
double Channel5[];
double Channel6[];

//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int init()
  {
  //Comment("Turtle Channel is running");
  string LngTop, LngBottom, MedTop, MedBottom, ShtTop, ShtBottom;
  
//---- indicators
   SetIndexStyle(0,DRAW_LINE,STYLE_DOT);
   SetIndexStyle(1,DRAW_LINE,STYLE_DOT);
   SetIndexStyle(2,DRAW_LINE,STYLE_DASH);
   SetIndexStyle(3,DRAW_LINE,STYLE_DASH);
   SetIndexStyle(4,DRAW_LINE,STYLE_DASHDOT);
   SetIndexStyle(5,DRAW_LINE,STYLE_DASHDOT);
   
   SetIndexBuffer(0,Channel1);
   SetIndexBuffer(1,Channel2);
   SetIndexBuffer(2,Channel3);
   SetIndexBuffer(3,Channel4);
   SetIndexBuffer(4,Channel5);
   SetIndexBuffer(5,Channel6);
   
   LngTop = "Long Top";
   LngBottom = "Long Bottom";
   MedTop = "Medium Top";
   MedBottom = "Medium Bottom";
   ShtTop = "Short Top";
   ShtBottom = "Short Bottom";
   
   IndicatorShortName(LngTop);
   IndicatorShortName(LngBottom);
   IndicatorShortName(MedTop);
   IndicatorShortName(MedBottom);
   IndicatorShortName(ShtTop);
   IndicatorShortName(ShtBottom);
   
   SetIndexLabel(0,LngTop);
   SetIndexLabel(1,LngBottom);
   SetIndexLabel(2,MedTop);
   SetIndexLabel(3,MedBottom);
   SetIndexLabel(4,ShtTop);
   SetIndexLabel(5,ShtBottom);

//----
   return(0);
  }
//+------------------------------------------------------------------+
//| Custom indicator deinitialization function                       |
//+------------------------------------------------------------------+
int deinit()
  {
//----
   
//----
   return(0);
  }
//+------------------------------------------------------------------+
//| Custom indicator iteration function                              |
//+------------------------------------------------------------------+
int start()
  {
   int   counted_bars=IndicatorCounted();
   int max_bars;
   
   if    (counted_bars < 0) return(-1);
   if    (counted_bars>0) counted_bars--;
   
   max_bars= Bars-1;
   
   double   sminl=0, smaxl=0, SsMinl=0, SsMaxl=0;
   double   sminm=0, smaxm=0, SsMinm=0, SsMaxm=0;
   double   smins=0, smaxs=0, SsMins=0, SsMaxs=0;

//----

   for(int shift = 0; shift< max_bars; shift++)
   { //begin for loop
      if(Extremes ==1)
      {
         SsMaxl = High[iHighest(NULL,0,MODE_HIGH,LngPeriod,shift)];
         SsMinl = Low[iLowest(NULL,0,MODE_LOW,LngPeriod,shift)];
         SsMaxm = High[iHighest(NULL,0,MODE_HIGH,MedPeriod,shift)];
         SsMinm = Low[iLowest(NULL,0,MODE_LOW,MedPeriod,shift)];
         SsMaxs = High[iHighest(NULL,0,MODE_HIGH,ShtPeriod,shift)];
         SsMins = Low[iLowest(NULL,0,MODE_LOW,ShtPeriod,shift)];
      }
      else if (Extremes ==3)
      {
         SsMaxl = (Open[iHighest(NULL,0,MODE_OPEN,LngPeriod,shift)]+High[iHighest(NULL,0,MODE_HIGH,LngPeriod,shift)])/2;
         SsMinl = (Open[iLowest(NULL,0,MODE_OPEN,LngPeriod,shift)]+Low[iLowest(NULL,0,MODE_LOW,LngPeriod,shift)])/2;
         SsMaxm = (Open[iHighest(NULL,0,MODE_OPEN,MedPeriod,shift)]+High[iHighest(NULL,0,MODE_HIGH,MedPeriod,shift)])/2;
         SsMinm = (Open[iLowest(NULL,0,MODE_OPEN,MedPeriod,shift)]+Low[iLowest(NULL,0,MODE_LOW,MedPeriod,shift)])/2;
         SsMaxs = (Open[iHighest(NULL,0,MODE_OPEN,ShtPeriod,shift)]+High[iHighest(NULL,0,MODE_HIGH,ShtPeriod,shift)])/2;
         SsMins = (Open[iLowest(NULL,0,MODE_OPEN,ShtPeriod,shift)]+Low[iLowest(NULL,0,MODE_LOW,ShtPeriod,shift)])/2;
      }
      else
      {
         SsMaxl = Open[iHighest(NULL,0,MODE_OPEN,LngPeriod,shift)];
         SsMinl = Open[iLowest(NULL,0,MODE_OPEN,LngPeriod,shift)];
         SsMaxm = Open[iHighest(NULL,0,MODE_OPEN,MedPeriod,shift)];
         SsMinm = Open[iLowest(NULL,0,MODE_OPEN,MedPeriod,shift)];
         SsMaxs = Open[iHighest(NULL,0,MODE_OPEN,ShtPeriod,shift)];
         SsMins = Open[iLowest(NULL,0,MODE_OPEN,ShtPeriod,shift)];
      }

     smaxl = SsMaxl-(SsMaxl-SsMinl)*Margins/100;
     sminl = SsMinl+(SsMaxl-SsMinl)*Margins/100;
     smaxm = SsMaxm-(SsMaxm-SsMinm)*Margins/100;
     sminm = SsMinm+(SsMaxm-SsMinm)*Margins/100;
     smaxs = SsMaxs-(SsMaxs-SsMins)*Margins/100;
     smins = SsMins+(SsMaxs-SsMins)*Margins/100;
     
     Channel1[shift-Advance]=smaxl;
     Channel2[shift-Advance]=sminl;
     Channel3[shift-Advance]=smaxm;
     Channel4[shift-Advance]=sminm;
     Channel5[shift-Advance]=smaxs;
     Channel6[shift-Advance]=smins;
   } //end for loop
   
   
//----
   return(0);
  }
//+------------------------------------------------------------------+



Sample





Analysis



Market Information Used:

Series array that contains the highest prices of each bar
Series array that contains the lowest prices of each bar
Series array that contains open prices of each bar


Indicator Curves created:

Implements a curve of type DRAW_LINE


Indicators Used:



Custom Indicators Used:

Order Management characteristics:

Other Features: