//+---------------------------------------------------------------------+ //| BWImp-T01_StDev.mq5 | //| Copyright © 2006, HomeSoft-Tartan Corp. | //| spiky@transkeino.ru - http:\\www.fxexpert.ru | //+---------------------------------------------------------------------+ //| Для работы индикатора следует положить файл SmoothAlgorithms.mqh | //| в папку (директорию): каталог_данных_терминала\\MQL5\Include | //+---------------------------------------------------------------------+ #property copyright "Copyright © 2006, HomeSoft-Tartan Corp." #property link "spiky@transkeino.ru - http:\\www.fxexpert.ru" //---- номер версии индикатора #property version "1.00" //---- отрисовка индикатора в отдельном окне #property indicator_separate_window //---- для расчёта и отрисовки индикатора использовано шесть буферов #property indicator_buffers 6 //---- использовано всего пять графических построений #property indicator_plots 5 //+----------------------------------------------+ //| Параметры отрисовки линии индикатора | //+----------------------------------------------+ //---- отрисовка индикатора в виде линии #property indicator_type1 DRAW_COLOR_LINE //---- в качестве цветов трёхцветной линии использованы #property indicator_color1 clrMagenta,clrGray,clrDodgerBlue //---- линия индикатора - непрерывная кривая #property indicator_style1 STYLE_SOLID //---- толщина линии индикатора равна 2 #property indicator_width1 2 //---- отображение метки индикатора #property indicator_label1 "BWImp-T01" //+----------------------------------------------+ //| Параметры отрисовки медвежьего индикатора | //+----------------------------------------------+ //---- отрисовка индикатора 2 в виде символа #property indicator_type2 DRAW_ARROW //---- в качестве цвета медвежьего индикатора использован красный цвет #property indicator_color2 clrRed //---- толщина линии индикатора 2 равна 2 #property indicator_width2 2 //---- отображение медвежьей метки индикатора #property indicator_label2 "Dn_Signal 1" //+----------------------------------------------+ //| Параметры отрисовки бычьго индикатора | //+----------------------------------------------+ //---- отрисовка индикатора 3 в виде символа #property indicator_type3 DRAW_ARROW //---- в качестве цвета бычьего индикатора использован салатовый цвет #property indicator_color3 clrLime //---- толщина линии индикатора 3 равна 2 #property indicator_width3 2 //---- отображение бычьей метки индикатора #property indicator_label3 "Up_Signal 1" //+----------------------------------------------+ //| Параметры отрисовки медвежьего индикатора | //+----------------------------------------------+ //---- отрисовка индикатора 4 в виде символа #property indicator_type4 DRAW_ARROW //---- в качестве цвета медвежьего индикатора использован красный цвет #property indicator_color4 clrRed //---- толщина линии индикатора 4 равна 4 #property indicator_width4 4 //---- отображение медвежьей метки индикатора #property indicator_label4 "Dn_Signal 2" //+----------------------------------------------+ //| Параметры отрисовки бычьго индикатора | //+----------------------------------------------+ //---- отрисовка индикатора 5 в виде символа #property indicator_type5 DRAW_ARROW //---- в качестве цвета бычьего индикатора использован салатовый цвет #property indicator_color5 clrLime //---- толщина линии индикатора 5 равна 4 #property indicator_width5 4 //---- отображение бычьей метки индикатора #property indicator_label5 "Up_Signal 2" //+----------------------------------------------+ //| Описание класса CXMA | //+----------------------------------------------+ #include //---- объявление переменных класса 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 uint Period1=96; // Период 1 input uint Period2=3; // Период 2 input Smooth_Method XMA_Method=MODE_T3; // Метод сглаживания input uint XLength=8; // Глубина сглаживания input int XPhase=70; // Параметр сглаживания // для JJMA изменяющийся в пределах -100 ... +100, влияет на качество переходного процесса; // для VIDIA это период CMO, для AMA это период медленной скользящей input double dK1=1.5; // Коэффициент 1 для квадратичного фильтра input double dK2=2.5; // Коэффициент 2 для квадратичного фильтра input uint std_period=9; // Период квадратичного фильтра input int Shift=0; // Сдвиг индикатора по горизонтали в барах //---- объявление динамических массивов, которые будут в //---- дальнейшем использованы в качестве индикаторных буферов double ExtLineBuffer[],ColorExtLineBuffer[]; double BearsBuffer1[],BullsBuffer1[]; double BearsBuffer2[],BullsBuffer2[]; double Point10; //---- объявление целых переменных начала отсчёта данных int min_rates_1,min_rates_2,min_rates_total; //---- объявление глобальных переменных int Count[]; double impr[],impb[],dBWImp[]; //+------------------------------------------------------------------+ //| Пересчет позиции самого нового элемента в массиве | //+------------------------------------------------------------------+ void Recount_ArrayZeroPos(int &CoArr[],// возврат по ссылке номера текущего значения ценового ряда int Size) { int numb,Max1,Max2; static int count=1; //--- Max2=Size; Max1=Max2-1; //--- count--; if(count<0) count=Max1; //--- for(int iii=0; iiiMax1) numb-=Max2; CoArr[iii]=numb; } } //+------------------------------------------------------------------+ //| Получение разницы значений ценовых таймсерий | //+------------------------------------------------------------------+ double Get_dPrice(const double &Price1[],const double &Price2[],int index) { return(Price1[index]-Price2[index]); } //+------------------------------------------------------------------+ //| Custom indicator initialization function | //+------------------------------------------------------------------+ void OnInit() { //---- инициализация переменных начала отсчёта данных min_rates_1=int(Period1+Period2); min_rates_2=min_rates_1+XMA1.GetStartBars(XMA_Method,XLength,XPhase); min_rates_total=min_rates_2+int(std_period); Point10=_Point/10; //---- установка алертов на недопустимые значения внешних переменных XMA1.XMALengthCheck("XLength",XLength); XMA1.XMAPhaseCheck("XPhase",XPhase,XMA_Method); //---- распределение памяти под массивы переменных ArrayResize(Count,Period2); ArrayResize(impr,Period2); ArrayResize(impb,Period2); ArrayResize(dBWImp,std_period); //--- ArrayInitialize(Count,0); ArrayInitialize(impr,0.0); ArrayInitialize(impb,0.0); //---- превращение динамического массива ExtLineBuffer в индикаторный буфер SetIndexBuffer(0,ExtLineBuffer,INDICATOR_DATA); //---- осуществление сдвига начала отсчёта отрисовки индикатора PlotIndexSetInteger(0,PLOT_DRAW_BEGIN,min_rates_total); //--- запрет на отрисовку индикатором пустых значений PlotIndexSetDouble(0,PLOT_EMPTY_VALUE,EMPTY_VALUE); //---- осуществление сдвига индикатора 2 по горизонтали PlotIndexSetInteger(0,PLOT_SHIFT,Shift); //---- превращение динамического массива в цветовой, индексный буфер SetIndexBuffer(1,ColorExtLineBuffer,INDICATOR_COLOR_INDEX); //---- превращение динамического массива BearsBuffer в индикаторный буфер SetIndexBuffer(2,BearsBuffer1,INDICATOR_DATA); //---- осуществление сдвига индикатора 2 по горизонтали PlotIndexSetInteger(1,PLOT_SHIFT,Shift); //---- осуществление сдвига начала отсчёта отрисовки индикатора PlotIndexSetInteger(1,PLOT_DRAW_BEGIN,min_rates_total); //---- выбор символа для отрисовки PlotIndexSetInteger(1,PLOT_ARROW,159); //---- запрет на отрисовку индикатором пустых значений PlotIndexSetDouble(1,PLOT_EMPTY_VALUE,EMPTY_VALUE); //---- превращение динамического массива BullsBuffer в индикаторный буфер SetIndexBuffer(3,BullsBuffer1,INDICATOR_DATA); //---- осуществление сдвига индикатора 3 по горизонтали PlotIndexSetInteger(2,PLOT_SHIFT,Shift); //---- осуществление сдвига начала отсчёта отрисовки индикатора PlotIndexSetInteger(2,PLOT_DRAW_BEGIN,min_rates_total); //---- выбор символа для отрисовки PlotIndexSetInteger(2,PLOT_ARROW,159); //---- запрет на отрисовку индикатором пустых значений PlotIndexSetDouble(2,PLOT_EMPTY_VALUE,EMPTY_VALUE); //---- превращение динамического массива BearsBuffer в индикаторный буфер SetIndexBuffer(4,BearsBuffer2,INDICATOR_DATA); //---- осуществление сдвига индикатора 2 по горизонтали PlotIndexSetInteger(3,PLOT_SHIFT,Shift); //---- осуществление сдвига начала отсчёта отрисовки индикатора PlotIndexSetInteger(3,PLOT_DRAW_BEGIN,min_rates_total); //---- выбор символа для отрисовки PlotIndexSetInteger(3,PLOT_ARROW,159); //---- запрет на отрисовку индикатором пустых значений PlotIndexSetDouble(3,PLOT_EMPTY_VALUE,EMPTY_VALUE); //---- превращение динамического массива BullsBuffer в индикаторный буфер SetIndexBuffer(5,BullsBuffer2,INDICATOR_DATA); //---- осуществление сдвига индикатора 3 по горизонтали PlotIndexSetInteger(4,PLOT_SHIFT,Shift); //---- осуществление сдвига начала отсчёта отрисовки индикатора PlotIndexSetInteger(4,PLOT_DRAW_BEGIN,min_rates_total); //---- выбор символа для отрисовки PlotIndexSetInteger(4,PLOT_ARROW,159); //---- запрет на отрисовку индикатором пустых значений PlotIndexSetDouble(4,PLOT_EMPTY_VALUE,EMPTY_VALUE); //---- инициализации переменной для короткого имени индикатора string shortname; string Smooth1=XMA1.GetString_MA_Method(XMA_Method); StringConcatenate(shortname,"BWImp-T01_StDev(",XLength,", ",Smooth1,")"); //--- создание имени для отображения в отдельном подокне и во всплывающей подсказке IndicatorSetString(INDICATOR_SHORTNAME,shortname); //--- определение точности отображения значений индикатора IndicatorSetInteger(INDICATOR_DIGITS,0); //---- завершение инициализации } //+------------------------------------------------------------------+ //| 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[]) { //---- проверка количества баров на достаточность для расчёта if(rates_totalrates_total || prev_calculated<=0) // проверка на первый старт расчёта индикатора first=int(Period1); // стартовый номер для расчёта всех баров else first=prev_calculated-1; // стартовый номер для расчёта новых баров //---- основной цикл расчёта индикатора for(bar=first; bar0) imppr+=diff; if(diff<0) imppb+=diff; } imppr=MathRound(imppr/_Point); imppb=MathRound(imppb/_Point); if(!imppr) imppr=Point10; if(!imppb) imppb=Point10; impr[Count[0]]=imppr; impb[Count[0]]=imppb; sipr=0; sipb=0; for(int kkk=0; kkkrates_total || prev_calculated<=0) // проверка на первый старт расчёта индикатора first++; //---- основной цикл раскраски сигнальной линии for(bar=first; barExtLineBuffer[bar]) clr=0; ColorExtLineBuffer[bar]=clr; } //---- пересчёт стартового номера first для цикла пересчёта баров if(prev_calculated>rates_total || prev_calculated<=0) // проверка на первый старт расчёта индикатора first=min_rates_total; //---- основной цикл расчёта индикатора стандартных отклонений for(bar=first; bar=-Filter2) BEARS1=Line; //есть нисходящий тренд if(dstd<-Filter2) BEARS2=Line; //есть нисходящий тренд if(dstd>+Filter1 && dstd<=+Filter2) BULLS1=Line; //есть восходящий тренд if(dstd>+Filter2) BULLS2=Line; //есть восходящий тренд //---- инициализация ячеек индикаторных буферов полученными значениями BullsBuffer1[bar]=BULLS1; BearsBuffer1[bar]=BEARS1; BullsBuffer2[bar]=BULLS2; BearsBuffer2[bar]=BEARS2; } //---- return(rates_total); } //+------------------------------------------------------------------+