//+------------------------------------------------------------------+ //| Exp_DigVariation.mq5 | //| Copyright © 2015, Nikolay Kositsin | //| Khabarovsk, farria@mail.redcom.ru | //+------------------------------------------------------------------+ #property copyright "Copyright © 2015, Nikolay Kositsin" #property link "farria@mail.redcom.ru" #property version "1.00" //+----------------------------------------------+ //| Торговые алгоритмы | //+----------------------------------------------+ #include //+----------------------------------------------+ //| Перечисление для вариантов расчета лота | //+----------------------------------------------+ /*enum MarginMode - перечисление объявлено в файле TradeAlgorithms.mqh { FREEMARGIN=0, //MM от свободных средств на счете BALANCE, //MM от баланса средств на счете LOSSFREEMARGIN, //MM по убыткам от свободных средств на счете LOSSBALANCE, //MM по убыткам от баланса средств на счете LOT //Лот без изменения }; */ //+----------------------------------------------+ //| Объявление перечислений | //+----------------------------------------------+ enum Smooth //тип константы { dig_0=0,//0 dig_1, //1 dig_2, //2 dig_3, //3 dig_4, //4 dig_5, //5 dig_6, //6 dig_7, //7 dig_8, //8 dig_9, //9 dig_10 //10 }; //+----------------------------------------------+ //| Входные параметры эксперта | //+----------------------------------------------+ input double MM=0.1; // Доля финансовых ресурсов от депозита в сделке input MarginMode MMMode=LOT; // Способ определения размера лота input int StopLoss_=1000; // Стоплосс в пунктах input int TakeProfit_=2000; // Тейкпрофит в пунктах input int Deviation_=10; // Макс. отклонение цены в пунктах input bool BuyPosOpen=true; // Разрешение для входа в длинные позиции input bool SellPosOpen=true; // Разрешение для входа в короткие позиции input bool BuyPosClose=true; // Разрешение для выхода из длинных позиций input bool SellPosClose=true; // Разрешение для выхода из коротких позиций //+----------------------------------------------+ //| Входные параметры индикатора DigVariation | //+----------------------------------------------+ input ENUM_TIMEFRAMES InpInd_Timeframe=PERIOD_H8; // Таймфрейм индикатора input uint Period_=12; // Период усреднения input ENUM_MA_METHOD MA_Method_=MODE_SMA; // Метод усреднения input Smooth SmoothPower=dig_1; // Степень сглаживания сигнала input uint SignalBar=1; // Номер бара для получения сигнала входа //+----------------------------------------------+ //---- объявление целочисленных переменных для хранения периода графика в секундах int TimeShiftSec; //---- объявление целочисленных переменных для хендлов индикаторов int InpInd_Handle; //---- объявление целочисленных переменных начала отсчета данных int min_rates_total; //+------------------------------------------------------------------+ //| Описание класса Moving_Average | //+------------------------------------------------------------------+ #include //+------------------------------------------------------------------+ //| Expert initialization function | //+------------------------------------------------------------------+ int OnInit() { //---- получение хендла индикатора DigVariation InpInd_Handle=iCustom(Symbol(),InpInd_Timeframe,"DigVariation",Period_,MA_Method_,SmoothPower,0); if(InpInd_Handle==INVALID_HANDLE) { Print(" Не удалось получить хендл индикатора DigVariation"); return(INIT_FAILED); } //---- инициализация переменной для хранения периода графика в секундах TimeShiftSec=PeriodSeconds(InpInd_Timeframe); //---- инициализация переменных начала отсчета данных min_rates_total=GetStartBars(Smooth_Method(MA_Method_),Period_,0)*2+52; min_rates_total+=int(3+SignalBar); //---- завершение инициализации return(INIT_SUCCEEDED); } //+------------------------------------------------------------------+ //| Expert deinitialization function | //+------------------------------------------------------------------+ void OnDeinit(const int reason) { //---- GlobalVariableDel_(Symbol()); } //+------------------------------------------------------------------+ //| Expert tick function | //+------------------------------------------------------------------+ void OnTick() { //---- проверка количества баров на достаточность для расчета if(BarsCalculated(InpInd_Handle)Value[1]) BUY_Open=true; if(SellPosClose) SELL_Close=true; UpSignalTime=datetime(SeriesInfoInteger(Symbol(),InpInd_Timeframe,SERIES_LASTBAR_DATE))+TimeShiftSec; } //---- получим сигналы для продажи if(Value[1]>Value[2]) { if(SellPosOpen && Value[0]