//+------------------------------------------------------------------+ //| Exp_i-CAiChannel_System_Digit.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.10" //+----------------------------------------------+ // Торговые алгоритмы | //+----------------------------------------------+ #include //+----------------------------------------------+ //| Перечисление для вариантов расчёта лота | //+----------------------------------------------+ /*enum MarginMode - перечисление объявлено в файле TradeAlgorithms.mqh { FREEMARGIN=0, //MM от свободных средств на счёте BALANCE, //MM от баланса средств на счёте LOSSFREEMARGIN, //MM по убыткам от свободных средств на счёте LOSSBALANCE, //MM по убыткам от баланса средств на счёте LOT //Лот без изменения }; */ //+----------------------------------------------+ //| Описание класса CXMA | //+----------------------------------------------+ #include //+----------------------------------------------+ //| объявление перечислений | //+----------------------------------------------+ 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 }; //+----------------------------------------------+ //| объявление перечислений | //+----------------------------------------------+ /*enum SmoothMethod - перечисление объявлено в файле 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 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; //Разрешение для выхода из шортов //+----------------------------------------------+ //| Входные параметры индикатора | //+----------------------------------------------+ input ENUM_TIMEFRAMES InpInd_Timeframe=PERIOD_H12;// таймфрейм индикатора i-CAiChannel_System_Digit input Smooth_Method XMA_Method=MODE_SMA_; //метод усреднения input uint XLength=12; //глубина сглаживания input int XPhase=15; //параметр сглаживания, //---- для JJMA изменяющийся в пределах -100 ... +100, влияет на качество переходного процесса; //---- Для VIDIA это период CMO, для AMA это период медленной скользящей input Applied_price_ IPC=PRICE_CLOSE_; //ценовая константа input uint Dev=1000; //половина ширины канала в пунктах input uint Digit=2; //количество разрядов округления input int Shift=2; //сдвиг канала по горизонтали в барах input uint SignalBar=1; // номер бара для получения сигнала входа //+----------------------------------------------+ int TimeShiftSec; //---- Объявление целых переменных для хендлов индикаторов int InpInd_Handle; //---- объявление целых переменных начала отсчета данных int min_rates_total; //+------------------------------------------------------------------+ //| Expert initialization function | //+------------------------------------------------------------------+ int OnInit() { //---- получение хендла индикатора i-CAiChannel_System_Digit InpInd_Handle=iCustom(Symbol(),InpInd_Timeframe,"i-CAiChannel_System_Digit","i-CAiChannel_System_Digit",XMA_Method,XLength,XPhase,IPC,Dev,Digit,Shift,false,0,0); if(InpInd_Handle==INVALID_HANDLE) { Print(" Не удалось получить хендл индикатора i-CAiChannel_System_Digit"); return(INIT_FAILED); } //---- инициализация переменной для хранения периода графика в секундах TimeShiftSec=PeriodSeconds(InpInd_Timeframe); //---- инициализация переменных начала отсчёта данных min_rates_total=GetStartBars(XMA_Method,XLength,XPhase)+Shift; 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)2) { if(BuyPosOpen && Col[0]<3) BUY_Open=true; if(SellPosClose)SELL_Close=true; UpSignalTime=datetime(SeriesInfoInteger(Symbol(),InpInd_Timeframe,SERIES_LASTBAR_DATE))+TimeShiftSec; } //---- Получим сигналы для продажи if(Col[1]<2) { if(SellPosOpen && Col[0]>1) SELL_Open=true; if(BuyPosClose) BUY_Close=true; DnSignalTime=datetime(SeriesInfoInteger(Symbol(),InpInd_Timeframe,SERIES_LASTBAR_DATE))+TimeShiftSec; } } //---- Совершение сделок //---- Закрываем лонг BuyPositionClose(BUY_Close,Symbol(),Deviation_); //---- Закрываем шорт SellPositionClose(SELL_Close,Symbol(),Deviation_); //---- Открываем лонг BuyPositionOpen(BUY_Open,Symbol(),UpSignalTime,MM,MMMode,Deviation_,StopLoss_,TakeProfit_); //---- Открываем шорт SellPositionOpen(SELL_Open,Symbol(),DnSignalTime,MM,MMMode,Deviation_,StopLoss_,TakeProfit_); //---- } //+------------------------------------------------------------------+