Indicators Used
Miscellaneous
0
Views
0
Downloads
0
Favorites
Vortex Oscillator
//+------------------------------------------------------------------+
//|Vortex Oscillator.mq4 |
//|An adaptation of the Vortex Indicator described in the |
//|January 2010 issue of Technical Analysis of Stocks & Commodities |
//|This version plots the difference of VI+ - VI- to create an |
//|oscillator indicator, as suggested by Michael Moses. |
//+------------------------------------------------------------------+
#property copyright "Copyright 2009 under Creative Commons BY-SA License by Neil D. Rosenthal & Michael Moses"
#property link "http://creativecommons.org/licenses/by-sa/3.0/"
#property indicator_separate_window
#property indicator_buffers 1
#property indicator_color1 Blue
#property indicator_level1 0
#property indicator_levelcolor Black
#property indicator_levelstyle STYLE_DOT
//---- Input parameters
extern int VI_Length=14;
//---- Buffers
double VortexOsc[]; //The Vortex Oscialltor - the difference betweeen VI+ and VI-
double PlusVI[]; //VI+ : + Vortex Indicator buffer
double MinusVI[]; //VI- : - Vortex Indicator buffer
double PlusVM[]; //VM+ : + Vortex Movement buffer
double MinusVM[]; //VM- : - Vorext Movement buffer
double SumPlusVM[]; //Sum of VI_Length PlusVM values
double SumMinusVM[]; //Sum of VI_Length MinusVM values
double SumTR[]; //True Range buffer
//+------------------------------------------------------------------+
//| Custom indicator initialization function |
//+------------------------------------------------------------------+
int init()
{
//----
IndicatorBuffers(8);
IndicatorDigits(Digits);
//---- Set visible buffer properties
SetIndexBuffer(0,VortexOsc);
SetIndexStyle(0,DRAW_HISTOGRAM);
SetIndexLabel(0,"Vortex Osc(" + VI_Length + ")");
SetIndexDrawBegin(0,VI_Length);
//---- Set indices of caching buffers
SetIndexBuffer(1,PlusVI);
SetIndexBuffer(2,MinusVI);
SetIndexBuffer(3,PlusVM);
SetIndexBuffer(4,MinusVM);
SetIndexBuffer(5,SumPlusVM);
SetIndexBuffer(6,SumMinusVM);
SetIndexBuffer(7,SumTR);
//----
return(0);
}
//+------------------------------------------------------------------+
//| Custom indicator deinitialization function |
//+------------------------------------------------------------------+
int deinit()
{
//----
//----
return(0);
}
//+------------------------------------------------------------------+
//| Custom indicator iteration function |
//+------------------------------------------------------------------+
int start()
{
int Limit;
int CountedBars = IndicatorCounted();
//---- Check for possible errors
if(CountedBars < 0) return(-1);
//---- Last counted bar will be recounted
if(CountedBars > 0) CountedBars--;
Limit = Bars - CountedBars;
//---- Clear caching buffers
for(int i = 0; i < Limit; i++)
{
SumPlusVM[i] = 0;
SumMinusVM[i] = 0;
SumTR[i]= 0;
}
//---- Store the values of PlusVM and MinusVM
for(i = 0; i < Limit; i++)
{
//PlusVM = |Today's High - Yesterday's Low|
PlusVM[i] = MathAbs(High[i] - Low[i + 1]);
//MinusVM = |Today's Low - Yesterday's High|
MinusVM[i] = MathAbs(Low[i] - High[i +1]);
}
//---- Sum VI_Length values of PlusVM, MinusVM and the True Range
for(i = 0; i < Limit; i++)
{
for(int j = 0; j <= VI_Length - 1; j++)
{
SumPlusVM[i] += PlusVM[i + j];
SumMinusVM[i] += MinusVM[i + j];
SumTR[i] += iATR(NULL,0,1,i + j); //Sum VI_Length values of the True Range by using a 1-period ATR
}
}
//---- Draw the indicator
for(i = 0; i < Limit; i++)
{
PlusVI[i] = SumPlusVM[i] / SumTR[i];
MinusVI[i] = SumMinusVM[i] / SumTR[i];
VortexOsc[i] = PlusVI[i] - MinusVI[i];
}
//----
return(0);
}
//+------------------------------------------------------------------+
Comments
Markdown Formatting Guide
# H1
## H2
### H3
**bold text**
*italicized text*
[title](https://www.example.com)

`code`
```
code block
```
> blockquote
- Item 1
- Item 2
1. First item
2. Second item
---