客服热线:18391752892

想把RSI变成双线的,麻烦大神帮解决!谢谢!

   日期:2019-01-12     浏览:533    
马上注册,结交更多好友,下载更多资源

您需要 登录 才可以下载或查看,没有帐号?注册 //+------------------------------------------------------------------+
//|                                        RSI.mq4 |
//|              Copyright 2005-2014, metaQuotes Software Corp. |
//|                                http://www.mql4.com |
//+------------------------------------------------------------------+
#property copyright    2005-2014, metaQuotes Software Corp.
#property link      http://www.mql4.com
#property description Relative Strength Index
#property strict
#property indicator_separate_window
#property indicator_minimum    0
#property indicator_maximum    100
#property indicator_buffers    2
#property indicator_color1   DodgerBlue
#property indicator_color2   DarkOrange
#property indicator_level1   5.0
#property indicator_level2   95.0
#property indicator_level3   10.0
#property indicator_level4   90.0
#property indicator_levelcolor clrDimGray
#property indicator_levelstyle STYLE_DOT
//--- input parameters
input int InpRSIPeriod=4; // RSI Period
//--- buffers
double ExtRSIBuffer[];
double ExtPosBuffer[];
double ExtNegBuffer[];
//+------------------------------------------------------------------+
//| Custom indicator initialization function                  |
//+------------------------------------------------------------------+
int onInit(void)
   {
    string short_name;
//--- 2 additional buffers are used for counting.
    IndicatorBuffers(3);
    SetIndexBuffer(0,ExtRSIBuffer);
    SetIndexBuffer(1,ExtPosBuffer);
    SetIndexBuffer(2,ExtNegBuffer);
//--- indicator line
    SetIndexStyle(0,DRAW_LINE);
    SetIndexBuffer(0,ExtRSIBuffer);
//--- name for DataWindow and indicator subwindow label
    short_name= RSI( +string(InpRSIPeriod)+ )
    IndicatorShortName(short_name);
    SetIndexLabel(0,short_name);
//--- check for input
    if(InpRSIPeriod 2)
     {
      Print( Incorrect value for input variable InpRSIPeriod = ,InpRSIPeriod);
      return(INIT_FAILED);
     }
//---
    SetIndexDrawBegin(0,InpRSIPeriod);
//--- initialization done
    return(INIT_SUCCEEDED);
   }
//+------------------------------------------------------------------+
//| Relative Strength Index                             |
//+------------------------------------------------------------------+
int onCalculate(const int rates_total,
           const int prev_calculated,
           const datetime time[],
           const double open[],
           const double high[],
           const double low[],
           const double close[],
           const long tick_volume[],
           const long volume[],
           const int spread[])
   {
    int    i,pos;
    double diff;
//---
    if(Bars =InpRSIPeriod || InpRSIPeriod 2)
      return(0);
//--- counting from 0 to rates_total
    ArraySetAsSeries(ExtRSIBuffer,false);
    ArraySetAsSeries(ExtPosBuffer,false);
    ArraySetAsSeries(ExtNegBuffer,false);
    ArraySetAsSeries(close,false);
//--- preliminary calculations
    pos=prev_calculated-1;
    if(pos =InpRSIPeriod)
     {
      //--- first RSIPeriod values of the indicator are not calculated
      ExtRSIBuffer[0]=0.0;
      ExtPosBuffer[0]=0.0;
      ExtNegBuffer[0]=0.0;
      double sump=0.0;
      double sumn=0.0;
      for(i=1; i =InpRSIPeriod; i++)
       {
        ExtRSIBuffer=0.0;
        ExtPosBuffer=0.0;
        ExtNegBuffer=0.0;
        diff=close-close[i-1];
        if(diff 0)
          sump+=diff;
        else
          sumn-=diff;
       }
      //--- calculate first visible value
      ExtPosBuffer[InpRSIPeriod]=sump/InpRSIPeriod;
      ExtNegBuffer[InpRSIPeriod]=sumn/InpRSIPeriod;
      if(ExtNegBuffer[InpRSIPeriod]!=0.0)
        ExtRSIBuffer[InpRSIPeriod]=100.0-(100.0/(1.0+ExtPosBuffer[InpRSIPeriod]/ExtNegBuffer[InpRSIPeriod]));
      else
       {
        if(ExtPosBuffer[InpRSIPeriod]!=0.0)
          ExtRSIBuffer[InpRSIPeriod]=100.0;
        else
          ExtRSIBuffer[InpRSIPeriod]=50.0;
       }
      //--- prepare the position value for main calculation
      pos=InpRSIPeriod+1;
     }
//--- the main loop of calculations
    for(i=pos; i rates_total !IsStopped(); i++)
     {
      diff=close-close[i-1];
      ExtPosBuffer=(ExtPosBuffer[i-1]*(InpRSIPeriod-1)+(diff 0.0?diff:0.0))/InpRSIPeriod;
      ExtNegBuffer=(ExtNegBuffer[i-1]*(InpRSIPeriod-1)+(diff 0.0?-diff:0.0))/InpRSIPeriod;
      if(ExtNegBuffer!=0.0)
        ExtRSIBuffer=100.0-100.0/(1+ExtPosBuffer/ExtNegBuffer);
      else
       {
        if(ExtPosBuffer!=0.0)
          ExtRSIBuffer=100.0;
        else
          ExtRSIBuffer=50.0;
       }
     }
//---
    return(rates_total);
   }
//+------------------------------------------------------------------+

外汇交易有很大的风险性,本站所有资源均来自网络,请选择使用,如若出现亏损,本站不承担任何责任!


特别提示:本信息由相关企业自行提供,真实性未证实,仅供参考。请谨慎采用,风险自负。


0相关评论
相关行情
推荐行情
点击排行