Stochastic_3

Author: Copyright � 2009, Vladimir Hlystov
Stochastic_3
Indicators Used
Stochastic oscillator
Miscellaneous
Implements a curve of type %1
2 Views
0 Downloads
0 Favorites
Stochastic_3
//+------------------------------------------------------------------+
//|                                                  Stochastic3.mq4 |
//|                               Copyright © 2009, Vladimir Hlystov |
//|            Stochastic ïîêàçûâàåò ãðàôèêè 3 ïåðèîäîâ â îäíîì îêíå |
//+------------------------------------------------------------------+
#property copyright "Copyright © 2009, Vladimir Hlystov"
#property link      "cmillion@narod.ru"

#property indicator_separate_window
#property indicator_minimum 0
#property indicator_maximum 100
#property indicator_level1	20
#property indicator_level3	50
#property indicator_level2	80
#property indicator_levelcolor	Silver//	öâåò ãîðèçîíòàëüíûõ óðîâíåé èíäèêàòîðà
#property indicator_levelwidth	0//	òîëùèíà ãîðèçîíòàëüíûõ óðîâíåé èíäèêàòîðà
#property indicator_levelstyle	2//	ñòèëü ãîðèçîíòàëüíûõ óðîâíåé èíäèêàòîðà
#property indicator_buffers 4
#property indicator_color1 Maroon
#property indicator_style1 2
#property indicator_color2 DarkGreen
#property indicator_style2 2
#property indicator_color3 Navy
#property indicator_style3 2
#property indicator_color4 Yellow
#property indicator_width4 2
//---- buffers
double SignalBuffer[];
double BUFFER_1[];
double BUFFER_2[];
double BUFFER_3[];
   int per1;
   int per2;
   int per3;
   int n=3;
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int init()
  {
   IndicatorBuffers(4);
   IndicatorDigits(0);
//---- indicator lines
   SetIndexStyle(0,DRAW_LINE);
   SetIndexBuffer(0, BUFFER_1);
   SetIndexStyle(1,DRAW_LINE);
   SetIndexBuffer(1, BUFFER_2);
   SetIndexStyle(2,DRAW_LINE);
   SetIndexBuffer(2, BUFFER_3);
   SetIndexStyle(3,DRAW_LINE);
   SetIndexBuffer(3, SignalBuffer);
//---- name for DataWindow and indicator subwindow label
   per1=Period();
   per2 = next_period(per1+1);
   if (per2==0) n=1;
   per3 = next_period(per2+1);
   if (per3==0&&per2!=0) n=2;
   SetIndexLabel(0, string_ïåð(per1));
   SetIndexLabel(1, string_ïåð(per2));
   SetIndexLabel(2, string_ïåð(per3));
   SetIndexLabel(3, "Ñðåäíåå");
   IndicatorShortName("Stochastic ("+string_ïåð(per1)+""+string_ïåð(per2)+""+string_ïåð(per3)+")");
   return(0);
  }
//+------------------------------------------------------------------+
//| Stochastic oscillator                                            |
//+------------------------------------------------------------------+
int start()
{
   int    counted_bars=IndicatorCounted();
   if(counted_bars>0) counted_bars--;
   int limit=Bars-counted_bars;
   for(int i=0; i<limit; i++)
   {
      BUFFER_1[i]  = iStochastic(NULL,per1    ,5,3,3,MODE_SMA,0,MODE_MAIN,iBarShift(NULL,per1    ,Time[i],false));
      if (n>1) BUFFER_2[i]  = iStochastic(NULL,per2    ,5,3,3,MODE_SMA,0,MODE_MAIN,iBarShift(NULL,per2    ,Time[i],false));
      if (n>2) BUFFER_3[i] = iStochastic(NULL,per3   ,5,3,3,MODE_SMA,0,MODE_MAIN,iBarShift(NULL,per3   ,Time[i],false));
      if (n==3) SignalBuffer[i]  = (BUFFER_1[i]+BUFFER_2[i]+BUFFER_3[i])/n;
      if (n==2) SignalBuffer[i]  = (BUFFER_1[i]+BUFFER_2[i])/n;
      if (n==1) SignalBuffer[i]  = BUFFER_1[i];
   }
   return(0);
}
//+------------------------------------------------------------------+
int next_period(int per)
{
   if (per > 43200)  return(0); 
   if (per > 10080)  return(43200); 
   if (per > 1440)   return(10080); 
   if (per > 240)    return(1440); 
   if (per > 60)     return(240); 
   if (per > 30)     return(60);
   if (per > 15)     return(30); 
   if (per > 5)      return(15); 
   if (per > 1)      return(5);   
}
//+------------------------------------------------------------------+
string string_ïåð(int per)
{
   if (per == 1)     return(" M1  ");   //1 ìèíóòà
   if (per == 5)     return(" M5  ");   //5 ìèíóò 
   if (per == 15)    return(" M15 ");  //15 ìèíóò
   if (per == 30)    return(" M30 ");  //30 ìèíóò
   if (per == 60)    return(" H1  ");   //1 ÷àñ
   if (per == 240)   return(" H4  ");   //4 ÷àñà
   if (per == 1440)  return(" D1  ");   //1 äåíü
   if (per == 10080) return(" W1  ");   //1 íåäåëÿ
   if (per == 43200) return(" MN1 ");  //1 ìåñÿö
return("îøèáêà ïåðèîäà");
}
//+------------------------------------------------------------------+

Comments

Markdown supported. Formatting help

Markdown Formatting Guide

Element Markdown Syntax
Heading # H1
## H2
### H3
Bold **bold text**
Italic *italicized text*
Link [title](https://www.example.com)
Image ![alt text](image.jpg)
Code `code`
Code Block ```
code block
```
Quote > blockquote
Unordered List - Item 1
- Item 2
Ordered List 1. First item
2. Second item
Horizontal Rule ---