0
Views
0
Downloads
0
Favorites
2pbidealxosma_v2
//+---------------------------------------------------------------------+
//| 2pbIdealXOSMA.mq5 |
//| Copyright © 2012, Nikolay Kositsin |
//| Khabarovsk, farria@mail.redcom.ru |
//+---------------------------------------------------------------------+
//| Äëÿ ðàáîòû èíäèêàòîðà ñëåäóåò ïîëîæèòü ôàéë SmoothAlgorithms.mqh |
//| â ïàïêó (äèðåêòîðèþ): êàòàëîã_äàííûõ_òåðìèíàëà\\MQL5\Include |
//+---------------------------------------------------------------------+
#property copyright "Copyright © 2012, Nikolay Kositsin"
#property link "farria@mail.redcom.ru"
//--- íîìåð âåðñèè èíäèêàòîðà
#property version "1.02"
//--- îòðèñîâêà èíäèêàòîðà â îòäåëüíîì îêíå
#property indicator_separate_window
//--- êîëè÷åñòâî èíäèêàòîðíûõ áóôåðîâ 2
#property indicator_buffers 2
//--- èñïîëüçîâàíî âñåãî îäíî ãðàôè÷åñêîå ïîñòðîåíèå
#property indicator_plots 1
//+-----------------------------------+
//| Ïàðàìåòðû îòðèñîâêè èíäèêàòîðà |
//+-----------------------------------+
//--- îòðèñîâêà èíäèêàòîðà â âèäå ÷åòûðåõöâåòíîé ãèñòîãðàììû
#property indicator_type1 DRAW_COLOR_HISTOGRAM
//--- â êà÷åñòâå öâåòîâ ÷åòûðåõöâåòíîé ãèñòîãðàììû èñïîëüçîâàíû
#property indicator_color1 clrGray,clrOliveDrab,clrDodgerBlue,clrDeepPink,clrMagenta
//--- ëèíèÿ èíäèêàòîðà - ñïëîøíàÿ
#property indicator_style1 STYLE_SOLID
//--- òîëùèíà ëèíèè èíäèêàòîðà ðàâíà 2
#property indicator_width1 2
//--- îòîáðàæåíèå ìåòêè èíäèêàòîðà
#property indicator_label1 "2pbIdealXOSMA"
//+-----------------------------------+
//| Îïèñàíèå êëàññîâ óñðåäíåíèé |
//+-----------------------------------+
#include <SmoothAlgorithms.mqh>
//+-----------------------------------+
//--- îáúÿâëåíèå ïåðåìåííûõ êëàññà CXMA èç ôàéëà SmoothAlgorithms.mqh
CXMA XMA1;
//+-----------------------------------+
//| îáúÿâëåíèå ïåðå÷èñëåíèé |
//+-----------------------------------+
/*enum Smooth_Method - ïåðå÷èñëåíèå îáúÿâëåíî â ôàéëå SmoothAlgorithms.mqh
{
MODE_SMA_, //SMA
MODE_EMA_, //EMA
MODE_SMMA_, //SMMA
MODE_LWMA_, //LWMA
MODE_JJMA, //JJMA
MODE_JurX, //JurX
MODE_ParMA, //ParMA
MODE_T3, //T3
MODE_VIDYA, //VIDYA
MODE_AMA, //AMA
}; */
//+-----------------------------------+
//| Âõîäíûå ïàðàìåòðû èíäèêàòîðà |
//+-----------------------------------+
input int Period1 = 10; // Ãðóáîå óñðåäíåíèå
input int Period2 = 10; // Óòî÷íÿþùåå óñðåäíåíèå
input int PeriodX1 = 10; // Ïåðâîå ãðóáîå óñðåäíåíèå
input int PeriodX2 = 10; // Ïåðâîå óòî÷íÿþùåå óñðåäíåíèå
input int PeriodY1 = 10; // Âòîðîå ãðóáîå óñðåäíåíèå
input int PeriodY2 = 10; // Âòîðîå óòî÷íÿþùåå óñðåäíåíèå
input int PeriodZ1 = 10; // Òðåòüå ãðóáîå óñðåäíåíèå
input int PeriodZ2 = 10; // Òðåòüå óòî÷íÿþùåå óñðåäíåíèå
input Smooth_Method SmoothMethod=MODE_JJMA; // Ìåòîä ñãëàæèâàíèÿ
input int Smooth_XMA=9; // Ïåðèîä ñãëàæèâàíèÿ
input int Smooth_Phase=100; // Ïàðàìåòð óñðåäíåíèÿ
//--- Smooth_Phase: äëÿ JJMA èçìåíÿþùèéñÿ â ïðåäåëàõ -100 ... +100, âëèÿåò íà êà÷åñòâî ïåðåõîäíîãî ïðîöåññà;
//--- Smooth_Phase: äëÿ VIDIA ýòî ïåðèîä CMO, äëÿ AMA ýòî ïåðèîä ìåäëåííîé ñêîëüçÿùåé
//+-----------------------------------+
//--- îáúÿâëåíèå öåëî÷èñëåííûõ ïåðåìåííûõ íà÷àëà îòñ÷åòà äàííûõ
int min_rates_total;
//--- îáúÿâëåíèå äèíàìè÷åñêèõ ìàññèâîâ, êîòîðûå â äàëüíåéøåì
//--- áóäóò èñïîëüçîâàíû â êà÷åñòâå èíäèêàòîðíûõ áóôåðîâ
double IndBuffer[],ColorIndBuffer[];
//--- îáúÿâëåíèÿ ïåðåìåííûõ äëÿ ñãëàæèâàþùèõ êîíñòàíò
double w1,w2,wX1,wX2,wY1,wY2,wZ1,wZ2;
//--- îáúÿâëåíèÿ ïåðåìåííûõ äëÿ õðàíåíèÿ ðåçóëüòàòîâ óñðåäíåíèÿ
double Moving0_,Moving01_,Moving11_,Moving21_;
//+------------------------------------------------------------------+
//| Îïèñàíèå ôóíêöèè iPriceSeries |
//| Îïèñàíèå êëàññà Moving_Average |
//+------------------------------------------------------------------+
#include <SmoothAlgorithms.mqh>
//+------------------------------------------------------------------+
//| Óñðåäíåíèå îò Neutron |
//+------------------------------------------------------------------+
double GetIdealMASmooth(double W1_, //ïåðâàÿ ñãëàæèâàþùàÿ êîíñòàíòà
double W2_, //âòîðàÿ ñãëàæèâàþùàÿ êîíñòàíòà
double Series1, //çíà÷åíèå òàìñåðèè ñ òåêóùåãî áàðà
double Series0, //çíà÷åíèå òàìñåðèè ñ ïðåäûäóùåãî áàðà
double Result1) //çíà÷åíèå ìóâèíãà ñ ïðåäûäóùåãî áàðà
{
//---
double Result0,dSeries,dSeries2;
dSeries=Series0-Series1;
dSeries2=dSeries*dSeries-1.0;
//---
Result0=(W1_ *(Series0-Result1)+
Result1+W2_*Result1*dSeries2)
/(1.0+W2_*dSeries2);
//---
return(Result0);
}
//+------------------------------------------------------------------+
//| 2pbIdealXOSMA indicator initialization function |
//+------------------------------------------------------------------+
void OnInit()
{
//--- èíèöèàëèçàöèÿ ïåðåìåííûõ íà÷àëà îòñ÷åòà äàííûõ
min_rates_total=2+XMA1.GetStartBars(SmoothMethod,Smooth_XMA,Smooth_Phase);
//--- èíèöèàëèçàöèè ïåðåìåííûõ
w1=1.0/Period1;
w2=1.0/Period2;
wX1=1.0/PeriodX1;
wX2=1.0/PeriodX2;
wY1=1.0/PeriodY1;
wY2=1.0/PeriodY2;
wZ1=1.0/PeriodZ1;
wZ2=1.0/PeriodZ2;
//--- ïðåâðàùåíèå äèíàìè÷åñêîãî ìàññèâà IndBuffer â èíäèêàòîðíûé áóôåð
SetIndexBuffer(0,IndBuffer,INDICATOR_DATA);
//--- îñóùåñòâëåíèå ñäâèãà íà÷àëà îòñ÷åòà îòðèñîâêè èíäèêàòîðà
PlotIndexSetInteger(0,PLOT_DRAW_BEGIN,min_rates_total);
//--- ñîçäàíèå ìåòêè äëÿ îòîáðàæåíèÿ â DataWindow
PlotIndexSetString(0,PLOT_LABEL,"Ind");
//--- óñòàíîâêà çíà÷åíèé èíäèêàòîðà, êîòîðûå íå áóäóò âèäèìû íà ãðàôèêå
PlotIndexSetDouble(0,PLOT_EMPTY_VALUE,0.0);
//--- ïðåâðàùåíèå äèíàìè÷åñêîãî ìàññèâà â öâåòîâîé, èíäåêñíûé áóôåð
SetIndexBuffer(1,ColorIndBuffer,INDICATOR_COLOR_INDEX);
//--- óñòàíîâêà àëåðòîâ íà íåäîïóñòèìûå çíà÷åíèÿ âíåøíèõ ïåðåìåííûõ
XMA1.XMALengthCheck("Smooth_XMA",Smooth_XMA);
//--- óñòàíîâêà àëåðòîâ íà íåäîïóñòèìûå çíà÷åíèÿ âíåøíèõ ïåðåìåííûõ
XMA1.XMAPhaseCheck("Smooth_Phase",Smooth_Phase,SmoothMethod);
//--- ñîçäàíèå èìåíè äëÿ îòîáðàæåíèÿ â îòäåëüíîì ïîäîêíå è âî âñïëûâàþùåé ïîäñêàçêå
IndicatorSetString(INDICATOR_SHORTNAME,"2pbIdealXOSMA");
//--- îïðåäåëåíèå òî÷íîñòè îòîáðàæåíèÿ çíà÷åíèé èíäèêàòîðà
IndicatorSetInteger(INDICATOR_DIGITS,_Digits+1);
//--- çàâåðøåíèå èíèöèàëèçàöèè
}
//+------------------------------------------------------------------+
//| 2pbIdealXOSMA iteration function |
//+------------------------------------------------------------------+
int OnCalculate(const int rates_total, // êîëè÷åñòâî èñòîðèè â áàðàõ íà òåêóùåì òèêå
const int prev_calculated, // êîëè÷åñòâî èñòîðèè â áàðàõ íà ïðåäûäóùåì òèêå
const int begin, // íîìåð íà÷àëà äîñòîâåðíîãî îòñ÷åòà áàðîâ
const double &price[]) // öåíîâîé ìàññèâ äëÿ ðàñ÷åòà èíäèêàòîðà
{
//--- ïðîâåðêà êîëè÷åñòâà áàðîâ íà äîñòàòî÷íîñòü äëÿ ðàñ÷åòà
if(rates_total<min_rates_total+begin) return(0);
///--- îáúÿâëåíèÿ ëîêàëüíûõ ïåðåìåííûõ
int first,bar;
double Moving0,SlowMA,FastMA,macd;
double Moving00,Moving10,Moving20;
double Moving01,Moving11,Moving21;
//--- ðàñ÷åò ñòàðòîâîãî íîìåðà first äëÿ öèêëà ïåðåñ÷åòà áàðîâ
if(prev_calculated>rates_total || prev_calculated<=0) // ïðîâåðêà íà ïåðâûé ñòàðò ðàñ÷åòà èíäèêàòîðà
{
first=1+begin; // ñòàðòîâûé íîìåð äëÿ ðàñ÷åòà âñåõ áàðîâ
//--- óâåëè÷èì ïîçèöèþ íà÷àëà äàííûõ íà begin áàðîâ, âñëåäñòâèå ðàñ÷åòîâ íà äàííûõ äðóãîãî èíäèêàòîðà
if(begin>0) PlotIndexSetInteger(0,PLOT_DRAW_BEGIN,min_rates_total+begin);
//--- ñòàðòîâàÿ èíèöèàëèçàöèÿ
Moving0_=price[begin];
Moving01_=price[begin];
Moving11_=price[begin];
Moving21_=price[begin];
}
else first=prev_calculated-1; // ñòàðòîâûé íîìåð äëÿ ðàñ÷åòà íîâûõ áàðîâ
//--- âîññòàíàâëèâàåì çíà÷åíèÿ ïåðåìåííûõ
Moving0=Moving0_;
Moving01=Moving01_;
Moving11=Moving11_;
Moving21=Moving21_;
//--- îñíîâíîé öèêë ðàñ÷åòà èíäèêàòîðà
for(bar=first; bar<rates_total; bar++)
{
Moving0=GetIdealMASmooth(w1,w2,price[bar-1],price[bar],Moving0);
Moving00=GetIdealMASmooth(wX1,wX2,price[bar-1],price[bar],Moving01);
Moving10=GetIdealMASmooth(wY1,wY2,Moving01, Moving00, Moving11);
Moving20=GetIdealMASmooth(wZ1,wZ2,Moving11, Moving10, Moving21);
//---
Moving01 = Moving00;
Moving11 = Moving10;
Moving21 = Moving20;
//---
SlowMA=Moving20;
FastMA=Moving0;
macd=FastMA-SlowMA;
IndBuffer[bar]=XMA1.XMASeries(1+begin,prev_calculated,rates_total,SmoothMethod,Smooth_Phase,Smooth_XMA,macd,bar,false);
//---
if(bar==rates_total-2)
{
Moving0_=Moving0;
Moving01_=Moving01;
Moving11_=Moving11;
Moving21_=Moving21;
}
}
if(prev_calculated>rates_total || prev_calculated<=0) first++;
//--- îñíîâíîé öèêë ðàñêðàñêè èíäèêàòîðà Ind
for(bar=first; bar<rates_total; bar++)
{
ColorIndBuffer[bar]=0;
//---
if(IndBuffer[bar]>0)
{
if(IndBuffer[bar]>IndBuffer[bar-1]) ColorIndBuffer[bar]=1;
if(IndBuffer[bar]<IndBuffer[bar-1]) ColorIndBuffer[bar]=2;
}
//---
if(IndBuffer[bar]<0)
{
if(IndBuffer[bar]<IndBuffer[bar-1]) ColorIndBuffer[bar]=3;
if(IndBuffer[bar]>IndBuffer[bar-1]) ColorIndBuffer[bar]=4;
}
}
//---
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
---