RSI_TrendRSI_Laguerre2SmzACS_MTF





//+------------------------------------------------------------------+
//|                                RSI_Trend_Laquerre2SmzACS_MTF     |
//|                                      Copyright © 2006, Keris2112 |
//|                             mtf: 2008www.forex-tsd.com       ki  |
//+------------------------------------------------------------------+
#property copyright "Copyright © 2006, Keris2112"
#property link      "http://www.forex-tsd.com"
//  TRSI  #property copyright "Copyright © 2005, TrendLaboratory Ltd."
//        #property link      "http://finance.groups.yahoo.com/group/TrendLaboratory"

#property indicator_separate_window
#property indicator_buffers 3
#property indicator_color1 DodgerBlue
#property indicator_color2 Lime
#property indicator_color3 OrangeRed


#property indicator_level1 85
#property indicator_level2 50
#property indicator_level3 15
#property indicator_levelcolor DarkGoldenrod
#property indicator_levelstyle 2

#property indicator_width1 2
#property indicator_width2 1
#property indicator_width3 2

#property indicator_maximum 105
#property indicator_minimum -5

//---- 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 RSIPeriod= 2;  //14
extern int EMAPeriod= 2;  //5
extern int ATRPeriod= 25; //14
extern double K=4.236;    //2.618

extern double gamma1=0.04; //0.6
extern double gamma2=0.06; //0.8
extern int MA1=2;
extern int MA2=2;
extern int MaxBars   = 1000;
extern int TimeFrame2 = 0;

extern string  TimeFrames = "M1;5,15,30,60H1;240H4;1440D1;10080W1;43200MN|0-CurrentTF";

double RSIindex[];
double Laguerre1[];
double Laguerre2[];


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

//---- indicator line
    IndicatorBuffers(3);
  
   SetIndexBuffer(0,RSIindex);
   SetIndexBuffer(1,Laguerre1);
   SetIndexBuffer(2,Laguerre2);
 //   SetIndexEmptyValue(0,EMPTY_VALUE);
 //   SetIndexEmptyValue(1,EMPTY_VALUE);
 //   SetIndexEmptyValue(2,EMPTY_VALUE);

   
   SetIndexStyle(0,DRAW_LINE);
   SetIndexStyle(1,DRAW_LINE);
   SetIndexStyle(2,DRAW_LINE);

 
   SetIndexLabel(0,"TRSI "+RSIPeriod+""); //
   SetIndexLabel(1,"Lgr "+gamma1+""); //
   SetIndexLabel(2,"Lgr "+gamma2+""); //
  
//---- 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= "CurrTF";
   }
   IndicatorShortName("Trend_RSI ("+RSIPeriod+","+EMAPeriod+","+ATRPeriod+","
                                 +DoubleToStr(K,3)+") Laguerre2ACS("+DoubleToStr(gamma1,2)+","+DoubleToStr(gamma2,2)+"|"+MA1+","+MA2+") ["+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+TimeFrame/Period();
limit= Bars-counted_bars;
limit= MathMax(limit,TimeFrame/Period());
limit= MathMin(limit,MaxBars);

   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
 **********************************************************/  

RSIindex[i] =iCustom(NULL,TimeFrame,"TrendRSI_v3",RSIPeriod,EMAPeriod,ATRPeriod,K,0,y); 
Laguerre1[i]=iCustom(NULL,TimeFrame,"Laguerre2-ACS1",gamma1,gamma2,MA1,MA2,MaxBars, TimeFrame2,0,y)*100; 
Laguerre2[i]=iCustom(NULL,TimeFrame,"Laguerre2-ACS1",gamma1,gamma2,MA1,MA2,MaxBars, TimeFrame2,1,y)*100; 

   }
 //++++++++++++++++++++++++++++++++++++++++++++++++++++++  
   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];

 
   } } }
//+++++++++++++++++++++++++++++++++++++++++++++   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

Indicators Used:




Custom Indicators Used:
TrendRSI_v3
Laguerre2-ACS1

Order Management characteristics:

Other Features: