//+------------------------------------------------------------------+ //| RSI_AC_Stochastic_Signal.mq5 | //| Copyright © 2011, Nikolay Kositsin | //| Khabarovsk, farria@mail.redcom.ru | //+------------------------------------------------------------------+ #property copyright "Copyright © 2011, Nikolay Kositsin" #property link "farria@mail.redcom.ru" //---- indicator version #property version "1.00" //---- drawing the indicator in a separate window #property indicator_separate_window //---- number of indicator buffers 4 #property indicator_buffers 4 //---- 2 plots are used #property indicator_plots 2 //+-----------------------------------+ //| Indicator drawing parameters | //+-----------------------------------+ //---- drawing the indicator as a colored cloud #property indicator_type1 DRAW_FILLING //---- the following colors are used for the indicator #property indicator_color1 Sienna,DarkGreen //---- displaying the indicator label #property indicator_label1 "RSI Signal" //+-----------------------------------+ //| Indicator drawing parameters | //+-----------------------------------+ //---- drawing the indicator as a color histogram #property indicator_type2 DRAW_COLOR_HISTOGRAM //---- the following colors are used for the indicator #property indicator_color2 Gray,Magenta,Lime //---- displaying the indicator label #property indicator_label2 "RSI Stochastic Signal" //---- indicator line width is equal to 5 #property indicator_width2 5 //+-----------------------------------+ //| Declaration of constants | //+-----------------------------------+ #define AC_DATA_LIMIT 37 // the constant for storing the minimum number of estimated bars for iAC #define RESET 0 // the constant for getting the command for the indicator recalculation back to the terminal //+-----------------------------------+ //| Indicator input parameters | //+-----------------------------------+ input int RSI_Period=9; // RSI period input ENUM_APPLIED_PRICE RSI_Price=PRICE_CLOSE; // RSI prices calculation method input int STO_Period=5; // Stochastic period input int STOD_Period=5; // Stochastic signal line period input int STO_Slowing=3; // Stochastic slowing period input ENUM_MA_METHOD STO_Method=MODE_SMA; // Stochastic smoothing method input ENUM_STO_PRICE STO_Price=STO_LOWHIGH; // Stochastic prices calculation method //+-----------------------------------+ //---- declaration of integer variables for the indicators handles int RSI_Handle,AC_Handle,STO_Handle; //---- declaration of the integer variables for the start of data calculation int min_rates_total; //---- declaration of dynamic arrays that //---- will be used as indicator buffers double ExtABuffer[]; double ExtBBuffer[]; double ExtCBuffer[]; double ExtColorCBuffer[]; //+------------------------------------------------------------------+ //| Custom indicator initialization function | //+------------------------------------------------------------------+ void OnInit() { //---- initialization of variables of the start of data calculation min_rates_total=int(MathMax(AC_DATA_LIMIT+1,MathMax(RSI_Period,STO_Period+STO_Slowing))); //---- getting handle of the MA indicator RSI_Handle=iRSI(NULL,0,RSI_Period,RSI_Price); if(RSI_Handle==INVALID_HANDLE) Print(" Failed to get handle of the RSI indicator"); //---- getting handle of the Stochastic indicator STO_Handle=iStochastic(NULL,0,STO_Period,STOD_Period,STO_Slowing,STO_Method,STO_Price); if(STO_Handle==INVALID_HANDLE) Print(" Failed to get handle of the Stochastic indicator"); //---- getting handle of the AC indicator AC_Handle=iAC(NULL,0); if(AC_Handle==INVALID_HANDLE) Print(" Failed to get handle of the AC indicator"); //---- set ExtABuffer[] dynamic array as an indicator buffer SetIndexBuffer(0,ExtABuffer,INDICATOR_DATA); //---- performing the shift of the beginning of the indicator drawing PlotIndexSetInteger(0,PLOT_DRAW_BEGIN,min_rates_total); //---- setting the indicator values that won't be visible on a chart PlotIndexSetDouble(0,PLOT_EMPTY_VALUE,EMPTY_VALUE); //---- indexing the elements in the buffer as timeseries ArraySetAsSeries(ExtABuffer,true); //---- set ExtBBuffer[] dynamic array as an indicator buffer SetIndexBuffer(1,ExtBBuffer,INDICATOR_DATA); //---- performing the shift of the beginning of the indicator drawing PlotIndexSetInteger(1,PLOT_DRAW_BEGIN,min_rates_total); //---- setting the indicator values that won't be visible on a chart PlotIndexSetDouble(1,PLOT_EMPTY_VALUE,EMPTY_VALUE); //---- indexing the elements in the buffer as timeseries ArraySetAsSeries(ExtBBuffer,true); //---- set ExtCBuffer[] dynamic array as an indicator buffer SetIndexBuffer(2,ExtCBuffer,INDICATOR_DATA); //---- performing the shift of the beginning of the indicator drawing PlotIndexSetInteger(2,PLOT_DRAW_BEGIN,min_rates_total); //---- setting the indicator values that won't be visible on a chart PlotIndexSetDouble(2,PLOT_EMPTY_VALUE,EMPTY_VALUE); //---- indexing the elements in the buffer as timeseries ArraySetAsSeries(ExtCBuffer,true); //---- set ExtColorCBuffer[] dynamic array as a color index buffer SetIndexBuffer(3,ExtColorCBuffer,INDICATOR_COLOR_INDEX); //---- performing the shift of the beginning of the indicator drawing PlotIndexSetInteger(3,PLOT_DRAW_BEGIN,min_rates_total); //---- indexing the elements in the buffer as timeseries ArraySetAsSeries(ExtColorCBuffer,true); //---- initializations of a variable for the indicator short name string shortname="RSI AC Stochastic_Signal"; //--- creation of the name to be displayed in a separate sub-window and in a tooltip IndicatorSetString(INDICATOR_SHORTNAME,shortname); //--- determination of accuracy of displaying the indicator values IndicatorSetInteger(INDICATOR_DIGITS,1); //---- initialization end } //+------------------------------------------------------------------+ //| Custom indicator iteration function | //+------------------------------------------------------------------+ int OnCalculate(const int rates_total, // number of bars in history at the current tick const int prev_calculated,// number of bars calculated at previous call const datetime &Time[], const double &Open[], const double &High[], const double &Low[], const double &Close[], const long &Tick_Volume[], const long &Volume[], const int &Spread[]) { //---- checking the number of bars to be enough for the calculation if(BarsCalculated(RSI_Handle)rates_total || prev_calculated<=0)// checking for the first start of the indicator calculation { limit=rates_total-min_rates_total-1; // starting index for calculation of all bars trend=0; } else limit=rates_total-prev_calculated; // starting index for calculation of new bars to_copy=limit+1; //---- copy newly appeared data in the arrays if(CopyBuffer(RSI_Handle,0,0,to_copy,RSI)<=0) return(RESET); if(CopyBuffer(STO_Handle,0,0,to_copy,STOM)<=0) return(RESET); if(CopyBuffer(STO_Handle,1,0,to_copy,STOS)<=0) return(RESET); to_copy++; if(CopyBuffer(AC_Handle,0,0,to_copy,AC)<=0) return(RESET); //---- indexing elements in arrays as time series ArraySetAsSeries(RSI,true); ArraySetAsSeries(STOM,true); ArraySetAsSeries(STOS,true); ArraySetAsSeries(AC,true); //---- main indicator calculation loop for(bar=limit; bar>=0 && !IsStopped(); bar--) { if(RSI[bar]>=50){ExtBBuffer[bar]=+1; ExtABuffer[bar]=0;} if(RSI[bar]< 50){ExtBBuffer[bar]=-1; ExtABuffer[bar]=0;} ExtCBuffer[bar]=0; ExtColorCBuffer[bar]=0; if(AC[bar]>AC[bar+1] && STOM[bar]>STOS[bar] && trend!=+1) { ExtCBuffer[bar]=+1; ExtColorCBuffer[bar]=2; if(bar) trend=+1; } if(AC[bar]