0
Views
0
Downloads
0
Favorites
BrakeExp
//+------------------------------------------------------------------+
//| BrakeExp.mq5 |
//| Copyright © 2012, Ivan Kornilov |
//| excelf@gmail.com |
//+------------------------------------------------------------------+
#property copyright "Copyright © 2012, Ivan Kornilov"
#property link "excelf@gmail.com"
#property description ""
//---- indicator version number
#property version "1.10"
//---- drawing the indicator in the main window
#property indicator_chart_window
//----four buffers are used for calculation of drawing of the indicator
#property indicator_buffers 4
//---- four plots are used in total
#property indicator_plots 4
//+----------------------------------------------+
//| Indicator drawing parameters |
//+----------------------------------------------+
//---- drawing the indicator 1 as a symbol
#property indicator_type1 DRAW_ARROW
//---- LimeGreen color is used for the indicator
#property indicator_color1 LimeGreen
//---- indicator 1 width is equal to 1
#property indicator_width1 1
//---- displaying of the bullish label of the indicator
#property indicator_label1 "Lower BrakeExp"
//+----------------------------------------------+
//| Indicator drawing parameters |
//+----------------------------------------------+
//---- drawing the indicator 2 as a line
#property indicator_type2 DRAW_ARROW
//---- DeepPink color is used for the indicator
#property indicator_color2 DeepPink
//---- indicator 2 width is equal to 1
#property indicator_width2 1
//---- displaying of the bearish label of the indicator
#property indicator_label2 "Upper BrakeExp"
//+----------------------------------------------+
//| Indicator drawing parameters |
//+----------------------------------------------+
//---- drawing the indicator 3 as a symbol
#property indicator_type3 DRAW_ARROW
//---- LimeGreen color is used for the indicator
#property indicator_color3 LimeGreen
//---- indicator 3 width is equal to 4
#property indicator_width3 4
//---- displaying of the bullish label of the indicator
#property indicator_label3 "BrakeExp Buy"
//+----------------------------------------------+
//| Indicator drawing parameters |
//+----------------------------------------------+
//---- drawing the indicator 4 as a symbol
#property indicator_type4 DRAW_ARROW
//---- DeepPink color is used for the indicator
#property indicator_color4 DeepPink
//---- indicator 4 width is equal to 4
#property indicator_width4 4
//---- displaying of the bearish label of the indicator
#property indicator_label4 "BrakeExp Sell"
//+-----------------------------------+
//| Declaration of constants |
//+-----------------------------------+
#define RESET 0 // the constant for getting the command for the indicator recalculation back to the terminal
//+----------------------------------------------+
//| Indicator input parameters |
//+----------------------------------------------+
input double A = 3;
input double B = 1;
//+----------------------------------------------+
double a,b;
double maxPrice_,minPrice_,beginPrice_;
bool isLong_;
int beginBar_;
//---- declaration of dynamic arrays that further
//---- will be used as indicator buffers
double BuyBuffer[],SellBuffer[];
double UpBuffer[],DnBuffer[];
//---- declaration of the integer variables for the start of data calculation
int min_rates_total;
//+------------------------------------------------------------------+
//| Custom indicator initialization function |
//+------------------------------------------------------------------+
void OnInit()
{
//---- Initialization of variables
min_rates_total=2;
b = B * _Point;
a = A * 0.1;
//---- set dynamic array as an indicator buffer
SetIndexBuffer(0,UpBuffer,INDICATOR_DATA);
//---- shifting the start of drawing of the indicator 1
PlotIndexSetInteger(0,PLOT_DRAW_BEGIN,min_rates_total);
//---- indicator symbol
PlotIndexSetInteger(0,PLOT_ARROW,158);
//---- indexing elements in the buffer as in timeseries
ArraySetAsSeries(UpBuffer,true);
//---- setting the indicator values that won't be visible on a chart
PlotIndexSetDouble(0,PLOT_EMPTY_VALUE,0);
//---- set dynamic array as an indicator buffer
SetIndexBuffer(1,DnBuffer,INDICATOR_DATA);
//---- shifting the beginning of drawing of the indicator 2
PlotIndexSetInteger(1,PLOT_DRAW_BEGIN,min_rates_total);
//---- indicator symbol
PlotIndexSetInteger(1,PLOT_ARROW,158);
//---- indexing elements in the buffer as in timeseries
ArraySetAsSeries(DnBuffer,true);
//---- setting the indicator values that won't be visible on a chart
PlotIndexSetDouble(1,PLOT_EMPTY_VALUE,0);
//---- set dynamic array as an indicator buffer
SetIndexBuffer(2,SellBuffer,INDICATOR_DATA);
//---- shifting the beginning of drawing of the indicator 3
PlotIndexSetInteger(2,PLOT_DRAW_BEGIN,min_rates_total);
//---- indicator symbol
PlotIndexSetInteger(2,PLOT_ARROW,174);
//---- indexing elements in the buffer as in timeseries
ArraySetAsSeries(SellBuffer,true);
//---- setting the indicator values that won't be visible on a chart
PlotIndexSetDouble(2,PLOT_EMPTY_VALUE,0);
//---- set dynamic array as an indicator buffer
SetIndexBuffer(3,BuyBuffer,INDICATOR_DATA);
//---- shifting the beginning of drawing of the indicator 4
PlotIndexSetInteger(3,PLOT_DRAW_BEGIN,min_rates_total);
//---- indicator symbol
PlotIndexSetInteger(3,PLOT_ARROW,174);
//---- indexing elements in the buffer as in timeseries
ArraySetAsSeries(BuyBuffer,true);
//---- setting the indicator values that won't be visible on a chart
PlotIndexSetDouble(3,PLOT_EMPTY_VALUE,0);
//---- setting the format of accuracy of displaying the indicator
IndicatorSetInteger(INDICATOR_DIGITS,_Digits);
//---- name for the data window and the label for sub-windows
string short_name="BrakeExp";
short_name="BrakeExp ("+DoubleToString(A,2)+","+DoubleToString(B,2)+" )";
IndicatorSetString(INDICATOR_SHORTNAME,short_name);
//----
}
//+------------------------------------------------------------------+
//| Custom indicator iteration function |
//+------------------------------------------------------------------+
int OnCalculate
(const int rates_total,
const int prev_calculated,
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 calculation
if(rates_total<min_rates_total) return(RESET);
//---- declaration of local variables
int limit,bar,maxbar;
double maxPrice,minPrice,beginPrice;
bool isLong;
int beginBar;
maxbar=rates_total-min_rates_total-1;
//---- indexing elements in arrays as timeseries
ArraySetAsSeries(High,true);
ArraySetAsSeries(Low,true);
//---- Calculate the "limit" starting number for loop of bars recalculation
if(prev_calculated>rates_total || prev_calculated<=0)// checking for the first start of calculation of an indicator
{
limit=maxbar; // starting index for calculation of all bars
maxPrice_=-999999;
minPrice_=+999999;
beginBar_=0;
beginPrice_=Low[limit];
isLong_=true;
}
else limit=rates_total-prev_calculated; // starting index for calculation of new bars
//----
beginBar=beginBar_+limit;
if(beginBar>maxbar)
{
limit=maxbar; // starting index for calculation of all bars
maxPrice_=-999999;
minPrice_=+999999;
beginBar_=0;
beginPrice_=Low[limit];
isLong_=true;
}
//----
isLong=isLong_;
maxPrice=maxPrice_;
minPrice=minPrice_;
beginPrice=beginPrice_;
//---- first indicator calculation loop
for(bar=limit; bar>=0 && !IsStopped(); bar--)
{
if(maxPrice < High[bar]) maxPrice = High[bar];
if(minPrice > Low[bar]) minPrice = Low[bar];
double value;
double exp_=(MathExp((beginBar-bar)*a)-1)*b;
if(isLong) value=beginPrice+exp_;
else value=beginPrice-exp_;
if(isLong && value>Low[bar])
{
isLong=false;
beginPrice=maxPrice;
value=beginPrice;
beginBar=bar;
maxPrice = -999999;
minPrice = +999999;
}
else
if(!isLong && value<High[bar])
{
isLong=true;
beginPrice=minPrice;
value=beginPrice;
beginBar=bar;
maxPrice = -999999;
minPrice = +999999;
}
if(isLong)
{
UpBuffer[bar]=value;
DnBuffer[bar]=0;
}
else
{
UpBuffer[bar]=0;
DnBuffer[bar]=value;
}
if(bar==1)
{
isLong_=isLong;
maxPrice_=maxPrice;
minPrice_=minPrice;
beginPrice_=beginPrice;
beginBar_=beginBar;
}
}
//---- recalculation of the starting index for calculation of all bars
if(prev_calculated>rates_total || prev_calculated<=0)// checking for the first start of calculation of an indicator
limit--;
//---- the second indicator calculation loop
for(bar=limit; bar>=0 && !IsStopped(); bar--)
{
//---- zero out the contents of the indicator buffers for calculation
BuyBuffer[bar]=0.0;
SellBuffer[bar]=0.0;
if(UpBuffer[bar+1]>0.0&&DnBuffer[bar]>0.0) BuyBuffer [bar]=DnBuffer[bar];
if(DnBuffer[bar+1]>0.0&&UpBuffer[bar]>0.0) SellBuffer[bar]=UpBuffer[bar];
}
//----
return(rates_total);
}
//+------------------------------------------------------------------+
//| iBarShift() function |
//+------------------------------------------------------------------+
int iBarShift(string symbol,ENUM_TIMEFRAMES timeframe,datetime time)
// iBarShift(symbol, timeframe, time)
//+ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -+
{
//----+
if(time<0) return(-1);
datetime Arr[],time1;
time1=(datetime) SeriesInfoInteger(symbol,timeframe,SERIES_LASTBAR_DATE);
if(time>=time1) return(0);
if(CopyTime(symbol,timeframe,time,time1,Arr)>0)
{
int size=ArraySize(Arr);
return(size-1);
}
else return(-1);
//----+
}
//+------------------------------------------------------------------+
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
---