//+------------------------------------------------------------------+ //| Exp_ColorJFatl_StDev.mq5 | //| Copyright © 2016, Nikolay Kositsin | //| Khabarovsk, farria@mail.redcom.ru | //+------------------------------------------------------------------+ #property copyright "Copyright © 2016, 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 SignalMode { POINT=0, //при появлении точечных сигналов (любая точка - сигнал) DIRECT, //при изменении направления движения индикатора WITHOUT //нет разрешения }; //+----------------------------------------------+ //| ОБЪЯВЛЕНИЕ ПЕРЕЧИСЛЕНИЙ | //+----------------------------------------------+ enum Applied_price_ //Тип константы { PRICE_CLOSE_ = 1, //Close PRICE_OPEN_, //Open PRICE_HIGH_, //High PRICE_LOW_, //Low PRICE_MEDIAN_, //Median Price (HL/2) PRICE_TYPICAL_, //Typical Price (HLC/3) PRICE_WEIGHTED_, //Weighted Close (HLCC/4) PRICE_SIMPL_, //Simpl Price (OC/2) PRICE_QUARTER_, //Quarted Price (HLOC/4) PRICE_TRENDFOLLOW0_, //TrendFollow_1 Price PRICE_TRENDFOLLOW1_, //TrendFollow_2 Price PRICE_DEMARK_ //Demark Price }; //+----------------------------------------------+ //| Входные параметры индикатора эксперта | //+----------------------------------------------+ input double MM=0.1; //Доля финансовых ресурсов от депозита в сделке input MarginMode MMMode=LOT; //способ определения размера лота input int StopLoss_=1000; //стоплосс в пунктах input int TakeProfit_=2000; //тейкпрофит в пунктах input int Deviation_=10; //макс. отклонение цены в пунктах input SignalMode BuyPosOpen=POINT; //Разрешение для входа в лонг input SignalMode SellPosOpen=POINT; //Разрешение для входа в шорт input SignalMode BuyPosClose=DIRECT; //Разрешение для выхода из лонгов input SignalMode SellPosClose=DIRECT; //Разрешение для выхода из шортов //+----------------------------------------------+ //| Входные параметры индикатора | //+----------------------------------------------+ input ENUM_TIMEFRAMES InpInd_Timeframe=PERIOD_H4; //таймфрейм индикатора input int JLength=5; // глубина JMA сглаживания input int JPhase=-100; // параметр JMA сглаживания, //изменяющийся в пределах -100 ... +100, //влияет на качество переходного процесса; input Applied_price_ IPC=PRICE_CLOSE_;//ценовая константа input int PriceShift=0; // cдвиг Фатла по вертикали в пунктах input double dK1=1.5; //коэффициент 1 для квадратичного фильтра input double dK2=2.5; //коэффициент 2 для квадратичного фильтра input uint std_period=9; //период квадратичного фильтра input uint SignalBar=1; //номер бара для получения сигнала входа //+----------------------------------------------+ //---- Объявление целых переменных для хранения периода графика в секундах int TimeShiftSec; //---- Объявление целых переменных для хендлов индикаторов int InpInd_Handle; //---- объявление целых переменных начала отсчета данных int min_rates_total; //+------------------------------------------------------------------+ //| Expert initialization function | //+------------------------------------------------------------------+ int OnInit() { //---- получение хендла индикатора ColorJFatl_StDev InpInd_Handle=iCustom(Symbol(),InpInd_Timeframe,"ColorJFatl_StDev",JLength,JPhase,IPC,PriceShift,dK1,dK2,std_period,0); if(InpInd_Handle==INVALID_HANDLE) { Print(" Не удалось получить хендл индикатора ColorJFatl_StDev"); return(INIT_FAILED); } //---- инициализация переменной для хранения периода графика в секундах TimeShiftSec=PeriodSeconds(InpInd_Timeframe); //---- Инициализация переменных начала отсчёта данных int FATLSize=39; min_rates_total=FATLSize+30+int(std_period); 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)Line[1] && Line[1]Line[2]) SELL_Open=true; break; } case WITHOUT: { break; } } switch(BuyPosClose) { case POINT: { //---- Объявление локальных переменных double Sign1[1],Sign2[1]; //---- копируем вновь появившиеся данные в массивы if(CopyBuffer(InpInd_Handle,2,SignalBar,1,Sign1)<=0) {Recount=true; return;} if(CopyBuffer(InpInd_Handle,4,SignalBar,1,Sign2)<=0) {Recount=true; return;} if((Sign1[0]!=EMPTY_VALUE) || (Sign2[0]!=EMPTY_VALUE)) BUY_Close=true; break; } case DIRECT: { //---- Объявление локальных переменных double Line[2]; if(CopyBuffer(InpInd_Handle,0,SignalBar,2,Line)<=0) {Recount=true; return;} if(Line[0]>Line[1]) BUY_Close=true; break; } case WITHOUT: { break; } } switch(SellPosClose) { case POINT: { //---- Объявление локальных переменных double Sign1[1],Sign2[1]; //---- копируем вновь появившиеся данные в массивы if(CopyBuffer(InpInd_Handle,3,SignalBar,1,Sign1)<=0) {Recount=true; return;} if(CopyBuffer(InpInd_Handle,5,SignalBar,1,Sign2)<=0) {Recount=true; return;} if((Sign1[0]!=EMPTY_VALUE) || (Sign2[0]!=EMPTY_VALUE)) SELL_Close=true; break; } case DIRECT: { //---- Объявление локальных переменных double Line[2]; if(CopyBuffer(InpInd_Handle,0,SignalBar,2,Line)<=0) {Recount=true; return;} if(Line[0]