0
Views
0
Downloads
0
Favorites
fractalchannel_v1
//+------------------------------------------------------------------+
//| FractalChannel.mq5 |
//| Copyright © 2005, TrendLaboratory Ltd. |
//| E-mail: igorad2004@list.ru |
//+------------------------------------------------------------------+
#property copyright "Copyright © 2005, TrendLaboratory Ltd."
#property link "E-mail: igorad2004@list.ru"
//---- íîìåð âåðñèè èíäèêàòîðà
#property version "1.00"
//---- îòðèñîâêà èíäèêàòîðà â ãëàâíîì îêíå
#property indicator_chart_window
//---- êîëè÷åñòâî èíäèêàòîðíûõ áóôåðîâ
#property indicator_buffers 3
//---- èñïîëüçîâàíî òðè ãðàôè÷åñêèõ ïîñòðîåíèÿ
#property indicator_plots 3
//+-----------------------------------+
//| Ïàðàìåòðû îòðèñîâêè èíäèêàòîðà 1 |
//+-----------------------------------+
//---- îòðèñîâêà èíäèêàòîðà â âèäå ëèíèè
#property indicator_type1 DRAW_LINE
//---- â êà÷åñòâå öâåòà ëèíèè èíäèêàòîðà èñïîëüçîâàí çåëåíûé öâåò
#property indicator_color1 clrSeaGreen
//---- ëèíèÿ èíäèêàòîðà - øòðèõ-ïóíêòèð
#property indicator_style1 STYLE_DASHDOTDOT
//---- òîëùèíà ëèíèè èíäèêàòîðà ðàâíà 1
#property indicator_width1 1
//---- îòîáðàæåíèå ìåòêè èíäèêàòîðà
#property indicator_label1 "Upper FractalChannel"
//+-----------------------------------+
//| Ïàðàìåòðû îòðèñîâêè èíäèêàòîðà 2 |
//+-----------------------------------+
//---- îòðèñîâêà èíäèêàòîðà â âèäå ëèíèè
#property indicator_type2 DRAW_LINE
//---- â êà÷åñòâå öâåòà ëèíèè èíäèêàòîðà èñïîëüçîâàí ñåðûé öâåò
#property indicator_color2 clrGray
//---- ëèíèÿ èíäèêàòîðà - øòðèõ-ïóíêòèð
#property indicator_style2 STYLE_DASHDOTDOT
//---- òîëùèíà ëèíèè èíäèêàòîðà ðàâíà 1
#property indicator_width2 1
//---- îòîáðàæåíèå ìåòêè èíäèêàòîðà
#property indicator_label2 "Middle FractalChannel"
//+-----------------------------------+
//| Ïàðàìåòðû îòðèñîâêè èíäèêàòîðà 3 |
//+-----------------------------------+
//---- îòðèñîâêà èíäèêàòîðà â âèäå ëèíèè
#property indicator_type3 DRAW_LINE
//---- â êà÷åñòâå öâåòà ëèíèè èíäèêàòîðà èñïîëüçîâàí êðàñíûé öâåò
#property indicator_color3 clrRed
//---- ëèíèÿ èíäèêàòîðà - øòðèõ-ïóíêòèð
#property indicator_style3 STYLE_DASHDOTDOT
//---- òîëùèíà ëèíèè èíäèêàòîðà ðàâíà 1
#property indicator_width3 1
//---- îòîáðàæåíèå ìåòêè èíäèêàòîðà
#property indicator_label3 "Lower FractalChannel"
//+-----------------------------------+
//| Îáúÿâëåíèå ïåðå÷èñëåíèé |
//+-----------------------------------+
enum Type //òèï êîíñòàíòû
{
Type_1 = 1, //Type_1
Type_2, //Type_2
Type_3 //Type_3
};
//+-----------------------------------+
enum PriceType //òèï êîíñòàíòû
{
OpenClose,//OpenClose
LowHigh //LowHigh
};
//+-----------------------------------+
//| Âõîäíûå ïàðàìåòðû èíäèêàòîðà |
//+-----------------------------------+
input Type ChannelType=Type_1;
input double Margins=0;
input double Advance=0;
input PriceType Prices=OpenClose;
input int Shift=0; // Ñäâèã èíäèêàòîðà ïî ãîðèçîíòàëè â áàðàõ
//+-----------------------------------+
//---- èíäèêàòîðíûå áóôåðû
double UpperBuffer[];
double MiddleBuffer[];
double LowerBuffer[];
//---- îáúÿâëåíèå öåëî÷èñëåííûõ ïåðåìåííûõ íà÷àëà îòñ÷åòà äàííûõ
int min_rates_total=7;
//+------------------------------------------------------------------+
//| FractalChannel initialization function |
//+------------------------------------------------------------------+
void OnInit()
{
//---- ïðåâðàùåíèå äèíàìè÷åñêîãî ìàññèâà â èíäèêàòîðíûé áóôåð
SetIndexBuffer(0,UpperBuffer,INDICATOR_DATA);
//---- îñóùåñòâëåíèå ñäâèãà èíäèêàòîðà 1 ïî ãîðèçîíòàëè íà AroonShift
PlotIndexSetInteger(0,PLOT_SHIFT,Shift);
//---- îñóùåñòâëåíèå ñäâèãà íà÷àëà îòñ÷åòà îòðèñîâêè èíäèêàòîðà 1
PlotIndexSetInteger(0,PLOT_DRAW_BEGIN,min_rates_total);
//--- ñîçäàíèå ìåòêè äëÿ îòîáðàæåíèÿ â DataWindow
PlotIndexSetString(0,PLOT_LABEL,"Upper FractalChannel");
//---- óñòàíîâêà çíà÷åíèé èíäèêàòîðà, êîòîðûå íå áóäóò âèäèìû íà ãðàôèêå
PlotIndexSetDouble(0,PLOT_EMPTY_VALUE,EMPTY_VALUE);
//---- èíäåêñàöèÿ ýëåìåíòîâ â áóôåðå êàê â òàéìñåðèè
ArraySetAsSeries(UpperBuffer,true);
//---- ïðåâðàùåíèå äèíàìè÷åñêîãî ìàññèâà â èíäèêàòîðíûé áóôåð
SetIndexBuffer(1,MiddleBuffer,INDICATOR_DATA);
//---- îñóùåñòâëåíèå ñäâèãà èíäèêàòîðà 2 ïî ãîðèçîíòàëè
PlotIndexSetInteger(1,PLOT_SHIFT,Shift);
//---- îñóùåñòâëåíèå ñäâèãà íà÷àëà îòñ÷åòà îòðèñîâêè èíäèêàòîðà 2
PlotIndexSetInteger(1,PLOT_DRAW_BEGIN,min_rates_total);
//--- ñîçäàíèå ìåòêè äëÿ îòîáðàæåíèÿ â DataWindow
PlotIndexSetString(1,PLOT_LABEL,"Middle FractalChannel");
//---- óñòàíîâêà çíà÷åíèé èíäèêàòîðà, êîòîðûå íå áóäóò âèäèìû íà ãðàôèêå
PlotIndexSetDouble(1,PLOT_EMPTY_VALUE,EMPTY_VALUE);
//---- èíäåêñàöèÿ ýëåìåíòîâ â áóôåðå êàê â òàéìñåðèè
ArraySetAsSeries(MiddleBuffer,true);
//---- ïðåâðàùåíèå äèíàìè÷åñêîãî ìàññèâà â èíäèêàòîðíûé áóôåð
SetIndexBuffer(2,LowerBuffer,INDICATOR_DATA);
//---- îñóùåñòâëåíèå ñäâèãà èíäèêàòîðà 3 ïî ãîðèçîíòàëè
PlotIndexSetInteger(2,PLOT_SHIFT,Shift);
//---- îñóùåñòâëåíèå ñäâèãà íà÷àëà îòñ÷åòà îòðèñîâêè èíäèêàòîðà 3
PlotIndexSetInteger(2,PLOT_DRAW_BEGIN,min_rates_total);
//--- ñîçäàíèå ìåòêè äëÿ îòîáðàæåíèÿ â DataWindow
PlotIndexSetString(2,PLOT_LABEL,"Lower FractalChannel");
//---- óñòàíîâêà çíà÷åíèé èíäèêàòîðà, êîòîðûå íå áóäóò âèäèìû íà ãðàôèêå
PlotIndexSetDouble(2,PLOT_EMPTY_VALUE,EMPTY_VALUE);
//---- èíäåêñàöèÿ ýëåìåíòîâ â áóôåðå êàê â òàéìñåðèè
ArraySetAsSeries(LowerBuffer,true);
//---- èíèöèàëèçàöèÿ ïåðåìåííîé äëÿ êîðîòêîãî èìåíè èíäèêàòîðà
string shortname;
StringConcatenate(shortname,"FractalChannel( ChannelType = ",ChannelType,
", Prices = ",Prices,")");
//--- ñîçäàíèå èìåíè äëÿ îòîáðàæåíèÿ â îòäåëüíîì ïîäîêíå è âî âñïëûâàþùåé ïîäñêàçêå
IndicatorSetString(INDICATOR_SHORTNAME,shortname);
//--- îïðåäåëåíèå òî÷íîñòè îòîáðàæåíèÿ çíà÷åíèé èíäèêàòîðà
IndicatorSetInteger(INDICATOR_DIGITS,_Digits+1);
//---- çàâåðøåíèå èíèöèàëèçàöèè
}
//+------------------------------------------------------------------+
//| FractalChannel 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[])
{
//---- ïðîâåðêà êîëè÷åñòâà áàðîâ íà äîñòàòî÷íîñòü äëÿ ðàñ÷åòà
if(rates_total<min_rates_total) return(0);
//---- èíäåêñàöèÿ ýëåìåíòîâ â ìàññèâàõ êàê â òàéìñåðèÿõ
ArraySetAsSeries(open,true);
ArraySetAsSeries(high,true);
ArraySetAsSeries(low,true);
ArraySetAsSeries(close,true);
//---- îáúÿâëåíèå ïåðåìåííûõ ñ ïëàâàþùåé òî÷êîé
double smax,smin,Low0,Low1,Low2,Low3,Low4,Low5,Low6;
double High0,High1,High2,High3,High4,High5,High6,v1,v2;
//---- îáúÿâëåíèå öåëî÷èñëåííûõ ïåðåìåííûõ
int limit,bar;
//---- îáúÿâëåíèå ñòàòè÷åñêèõ ïåðåìåííûõ
static double smax_,smin_;
//---- ðàñ÷åòû ñòàðòîâîãî íîìåðà limit äëÿ öèêëà ïåðåñ÷åòà áàðîâ
if(prev_calculated>rates_total || prev_calculated<=0)// ïðîâåðêà íà ïåðâûé ñòàðò ðàñ÷åòà èíäèêàòîðà
{
limit=rates_total-min_rates_total; // ñòàðòîâûé íîìåð äëÿ ðàñ÷åòà âñåõ áàðîâ
smax_ = 0;
smin_ = 1000000000000;
}
else
{
limit=rates_total-prev_calculated; // ñòàðòîâûé íîìåð äëÿ ðàñ÷åòà íîâûõ áàðîâ
}
//---- âîññòàíàâëèâàåì çíà÷åíèÿ ïåðåìåííûõ
smax = smax_;
smin = smin_;
//---- îñíîâíîé öèêë ðàñ÷åòà èíäèêàòîðà
for(bar=limit; bar>=0; bar--)
{
//---- çàïîìèíàåì çíà÷åíèÿ ïåðåìåííûõ ïåðåä ïðîãîíàìè íà òåêóùåì áàðå
if(rates_total!=prev_calculated && bar==rates_total-1)
{
smax_ = smax;
smin_ = smin;
}
//----
v1=-1;
v2=-1;
//----
switch(Prices)
{
case OpenClose:
High0=high[bar+0];
High1=high[bar+1];
High2=high[bar+2];
High3=high[bar+3];
High4=high[bar+4];
High5=high[bar+5];
High6=high[bar+6];
Low0=low[bar+0];
Low1=low[bar+1];
Low2=low[bar+2];
Low3=low[bar+3];
Low4=low[bar+4];
Low5=low[bar+5];
Low6=low[bar+6];
break;
//----
case LowHigh:
High0=MathMax(close[bar+0],open[bar+1]);
High1=MathMax(close[bar+1],open[bar+1]);
High2=MathMax(close[bar+2],open[bar+2]);
High3=MathMax(close[bar+3],open[bar+3]);
High4=MathMax(close[bar+4],open[bar+4]);
High5=MathMax(close[bar+5],open[bar+5]);
High6=MathMax(close[bar+6],open[bar+6]);
//----
Low0=MathMin(close[bar+0],open[bar+1]);
Low1=MathMin(close[bar+1],open[bar+1]);
Low2=MathMin(close[bar+2],open[bar+2]);
Low3=MathMin(close[bar+3],open[bar+3]);
Low4=MathMin(close[bar+4],open[bar+4]);
Low5=MathMin(close[bar+5],open[bar+5]);
Low6=MathMin(close[bar+6],open[bar+6]);
break;
//----
default:
High0=high[bar+0];
High1=high[bar+1];
High2=high[bar+2];
High3=high[bar+3];
High4=high[bar+4];
High5=high[bar+5];
High6=high[bar+6];
//----
Low0=low[bar+0];
Low1=low[bar+1];
Low2=low[bar+2];
Low3=low[bar+3];
Low4=low[bar+4];
Low5=low[bar+5];
Low6=low[bar+6];
}
//----
switch(ChannelType)
{
case Type_1:
{
if(High2<=High1 && High0<High1) v1=High1;
if(Low2 >= Low1 && Low0 > Low1) v2=Low1;
}
break;
//----
case Type_2:
{
if(High4<=High2 && High3<=High2 && High0<High2 && High1<High2) v1=High2;
if(Low4 >= Low2 && Low3 >= Low2 && Low0 > Low2 && Low1 > Low2) v2=Low2;
}
break;
//----
case Type_3:
{
if(High6<=High3 && High5<=High3 && High4<=High3 && High0<High3 && High1<High3 && High2<High3) v1=High3;
if(Low6 >= Low3 && Low5 >= Low3 && Low4 >= Low3 && Low0 > Low3 && Low1 > Low3 && Low2 > Low3) v2=Low3;
}
break;
//----
default:
{
if(High2<=High1 && High0<High1) v1=High1;
if(Low2 >= Low1 && Low0 > Low1) v2=Low1;
}
}
//----
if(v1>0) smax=v1;
if(High0>smax) smax=High0;
//----
if(v2>0) smin=v2;
if(Low0<smin) smin=Low0;
//----
UpperBuffer[bar]=smax-(smax-smin)*Margins;
LowerBuffer[bar]=smin+(smax-smin)*Margins;
MiddleBuffer[bar]=(UpperBuffer[bar]+LowerBuffer[bar])/2;
}
//----
return(rates_total);
}
//+------------------------------------------------------------------+
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
---