//+------------------------------------------------------------------+ //| AMA.mq5 | //| Copyright 2009, MetaQuotes Software Corp. | //| http://www.mql5.com | //+------------------------------------------------------------------+ #property copyright "2009, MetaQuotes Software Corp." #property link "http://www.mql5.com" #property version "1.00" #property description "Adaptive Moving Average" #property indicator_chart_window #property indicator_buffers 1 #property indicator_plots 1 //---- plot ExtAMABuffer #property indicator_label1 "AMA" #property indicator_type1 DRAW_LINE #property indicator_color1 Red #property indicator_style1 STYLE_SOLID #property indicator_width1 1 //--- default applied price #property indicator_applied_price PRICE_OPEN //--- input parameters input int InpPeriodAMA=10; // AMA period input int InpFastPeriodEMA=2; // Fast EMA period input int InpSlowPeriodEMA=30; // Slow EMA period input int InpShiftAMA=0; // AMA shift //--- indicator buffers double ExtAMABuffer[]; //--- global variables double ExtFastSC; double ExtSlowSC; int ExtPeriodAMA; int ExtSlowPeriodEMA; int ExtFastPeriodEMA; //+------------------------------------------------------------------+ //| AMA initialization function | //+------------------------------------------------------------------+ int OnInit() { //--- check for input values if(InpPeriodAMA<=0) { ExtPeriodAMA=10; printf("Input parameter InpPeriodAMA has incorrect value (%d). Indicator will use value %d for calculations.", InpPeriodAMA,ExtPeriodAMA); } else ExtPeriodAMA=InpPeriodAMA; if(InpSlowPeriodEMA<=0) { ExtSlowPeriodEMA=30; printf("Input parameter InpSlowPeriodEMA has incorrect value (%d). Indicator will use value %d for calculations.", InpSlowPeriodEMA,ExtSlowPeriodEMA); } else ExtSlowPeriodEMA=InpSlowPeriodEMA; if(InpFastPeriodEMA<=0) { ExtFastPeriodEMA=2; printf("Input parameter InpFastPeriodEMA has incorrect value (%d). Indicator will use value %d for calculations.", InpFastPeriodEMA,ExtFastPeriodEMA); } else ExtFastPeriodEMA=InpFastPeriodEMA; //--- indicator buffers mapping SetIndexBuffer(0,ExtAMABuffer,INDICATOR_DATA); //--- set shortname and change label string short_name="AMA("+IntegerToString(ExtPeriodAMA)+","+ IntegerToString(ExtFastPeriodEMA)+","+ IntegerToString(ExtSlowPeriodEMA)+")"; IndicatorSetString(INDICATOR_SHORTNAME,short_name); PlotIndexSetString(0,PLOT_LABEL,short_name); //--- set accuracy IndicatorSetInteger(INDICATOR_DIGITS,_Digits+1); //--- sets first bar from what index will be drawn PlotIndexSetInteger(0,PLOT_DRAW_BEGIN,ExtPeriodAMA); //--- set index shift PlotIndexSetInteger(0,PLOT_SHIFT,InpShiftAMA); //--- calculate ExtFastSC & ExtSlowSC ExtFastSC=2.0/(ExtFastPeriodEMA+1.0); ExtSlowSC=2.0/(ExtSlowPeriodEMA+1.0); //--- OnInit done return(INIT_SUCCEEDED); } //+------------------------------------------------------------------+ //| AMA iteration function | //+------------------------------------------------------------------+ int OnCalculate(const int rates_total, const int prev_calculated, const int begin, const double &price[]) { int i; //--- check for rates count if(rates_total