//+------------------------------------------------------------------+ //| Exp_ColorZerolagTriXOSMA.mq5 | //| Copyright © 2015, Nikolay Kositsin | //| Khabarovsk, farria@mail.redcom.ru | //+------------------------------------------------------------------+ #property copyright "Copyright © 2012, 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 //Лот без изменения }; */ //+----------------------------------------------+ //| Входные параметры эксперта | //+----------------------------------------------+ 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_H4; // Таймфрейм индикатора input uint smoothing1=15; input uint smoothing2=7; input ENUM_APPLIED_PRICE IPC=PRICE_CLOSE; // Ценовая константа //---- input double Factor1=0.05; input uint TriX_period1=8; //---- input double Factor2=0.10; input uint TriX_period2=21; //---- input double Factor3=0.16; input uint TriX_period3=34; //---- input double Factor4=0.26; input int TriX_period4=55; //---- input double Factor5=0.43; input uint TriX_period5=89; input uint SignalBar=1; // Номер бара для получения сигнала входа //+----------------------------------------------+ //---- объявление целочисленных переменных для хранения периода графика в секундах int TimeShiftSec; //---- объявление целочисленных переменных для хендлов индикаторов int InpInd_Handle; //---- объявление целочисленных переменных начала отсчета данных int min_rates_total; //+------------------------------------------------------------------+ //| Expert initialization function | //+------------------------------------------------------------------+ int OnInit() { //---- получение хендла индикатора ColorZerolagTriXOSMA InpInd_Handle=iCustom(Symbol(),InpInd_Timeframe,"ColorZerolagTriXOSMA",smoothing1,smoothing2,IPC,Factor1,TriX_period1,Factor2,TriX_period2, Factor3,TriX_period3,Factor4,TriX_period4,Factor5,TriX_period5); if(InpInd_Handle==INVALID_HANDLE) { Print(" Не удалось получить хендл индикатора ColorZerolagTriXOSMA"); return(INIT_FAILED); } //---- инициализация переменной для хранения периода графика в секундах TimeShiftSec=PeriodSeconds(InpInd_Timeframe); uint PeriodBuffer[5]; //---- расчет стартового бара PeriodBuffer[0] = TriX_period1; PeriodBuffer[1] = TriX_period2; PeriodBuffer[2] = TriX_period3; PeriodBuffer[3] = TriX_period4; PeriodBuffer[4] = TriX_period5; //---- //---- инициализация переменных начала отсчета данных min_rates_total=int(3*PeriodBuffer[ArrayMaximum(PeriodBuffer,0,WHOLE_ARRAY)])+2; 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]