//+------------------------------------------------------------------+ //| Stochastic333.mq4 | //| Copyright © 2017 Ariff | //+------------------------------------------------------------------+ #property copyright "Copyright © 2017, Ariff" #property indicator_separate_window #property indicator_minimum 0 #property indicator_maximum 100 #property indicator_buffers 2 #property indicator_color1 LightSeaGreen #property indicator_color2 SeaGreen #property indicator_color3 DeepPink #property indicator_color4 HotPink #property indicator_color5 DarkViolet #property indicator_color6 BlueViolet //---- input parameters extern int KPeriod=30; extern int DPeriod=3; extern int Slowing=3; extern double Level1= 5; extern double Level2= 95; extern double Level3= 0; extern double Level4= 0; extern string AlertFile1= "alert.wav"; extern string AlertFile2= "alert.wav"; extern string AlertFile3= ""; extern string AlertFile4= ""; #property indicator_separate_window #property indicator_minimum 0 #property indicator_maximum 100 #property indicator_buffers 2 #property indicator_color1 LightSeaGreen #property indicator_color2 SeaGreen extern int KPeriod=65; extern int DPeriod=3; extern int Slowing=3; extern double Level1= 5; extern double Level2= 95; extern double Level3= 0; extern double Level4= 0; extern string AlertFile1= "alert.wav"; extern string AlertFile2= "alert.wav"; extern string AlertFile3= ""; extern string AlertFile4= ""; #property indicator_separate_window #property indicator_minimum 0 #property indicator_maximum 100 #property indicator_buffers 2 #property indicator_color3 DeepPink #property indicator_color4 HotPink extern int KPeriod=100; extern int DPeriod=3; extern int Slowing=3; extern double Level1= 5; extern double Level2= 95; extern double Level3= 0; extern double Level4= 0; extern string AlertFile1= "alert.wav"; extern string AlertFile2= "alert.wav"; extern string AlertFile3= ""; extern string AlertFile4= ""; #property indicator_separate_window #property indicator_minimum 0 #property indicator_maximum 100 #property indicator_buffers 2 #property indicator_color5 DarkViolet #property indicator_color6 BlueViolet //---- buffers double MainBuffer[]; double SignalBuffer[]; double HighesBuffer[]; double LowesBuffer[]; //---- int draw_begin1=0; int draw_begin2=0; double lastBid; datetime alert[4]; bool bFirstTick; //+------------------------------------------------------------------+ //| Custom indicator initialization function | //+------------------------------------------------------------------+ int init() { string short_name; //---- 2 additional buffers are used for counting. IndicatorBuffers(4); SetIndexBuffer(2, HighesBuffer); SetIndexBuffer(3, LowesBuffer); //---- indicator lines SetIndexStyle(0,DRAW_LINE); SetIndexBuffer(0, MainBuffer); SetIndexStyle(1,DRAW_LINE); SetIndexBuffer(1, SignalBuffer); //---- name for DataWindow and indicator subwindow label short_name="Sto("+KPeriod+","+DPeriod+","+Slowing+")"; IndicatorShortName(short_name); SetIndexLabel(0,short_name); SetIndexLabel(1,"Signal"); //---- draw_begin1=KPeriod+Slowing; draw_begin2=draw_begin1+DPeriod; SetIndexDrawBegin(0,draw_begin1); SetIndexDrawBegin(1,draw_begin2); bFirstTick= false; alert[0]= 0; alert[1]= 0; alert[2]= 0; alert[3]= 0; //---- return(0); } //+------------------------------------------------------------------+ //| Stochastic oscillators | //+------------------------------------------------------------------+ int start() { int i,k; int counted_bars=IndicatorCounted(); double price; //---- if(Bars<=draw_begin2) return(0); //---- initial zero if(counted_bars<1) { for(i=1;i<=draw_begin1;i++) MainBuffer[Bars-i]=0; for(i=1;i<=draw_begin2;i++) SignalBuffer[Bars-i]=0; } //---- minimums counting i=Bars-KPeriod; if(counted_bars>KPeriod) i=Bars-counted_bars-1; while(i>=0) { double min=1000000; k=i+KPeriod-1; while(k>=i) { price=Low[k]; if(min>price) min=price; k--; } LowesBuffer[i]=min; i--; } //---- maximums counting i=Bars-KPeriod; if(counted_bars>KPeriod) i=Bars-counted_bars-1; while(i>=0) { double max=-1000000; k=i+KPeriod-1; while(k>=i) { price=High[k]; if(maxdraw_begin1) i=Bars-counted_bars-1; while(i>=0) { double sumlow=0.0; double sumhigh=0.0; for(k=(i+Slowing-1);k>=i;k--) { sumlow+=Close[k]-LowesBuffer[k]; sumhigh+=HighesBuffer[k]-LowesBuffer[k]; } if(sumhigh==0.0) MainBuffer[i]=100.0; else MainBuffer[i]=sumlow/sumhigh*100; i--; } //---- last counted bar will be recounted if(counted_bars>0) counted_bars--; int limit=Bars-counted_bars; //---- signal line is simple movimg average for(i=0; i=level && price2level)) rc= true; return(rc); }