Navigation:Home > Content >

Murrey_Math2.mq4

Time: 2017-02-22 | Download file:Murrey_Math2.mq4

//+------------------------------------------------------------------+
//|                                            Murrey_Math_MT_VG.mq4 |
//|                      Copyright © 2004, MetaQuotes Software Corp. |
//|                                        http://www.metaquotes.net |
//+------------------------------------------------------------------+
#property copyright "Vladislav Goshkov (VG)."
#property link      "[email protected]"

#property indicator_chart_window
#property indicator_buffers 8
#property indicator_color1  Red
#property indicator_color2  OrangeRed
#property indicator_color3  Blue
#property indicator_color4  Yellow
#property indicator_color5  SteelBlue
#property indicator_color6  ForestGreen
#property indicator_color7  Blue
#property indicator_color8  ForestGreen

#property indicator_width1 2
#property indicator_width2 2
#property indicator_width3 2
#property indicator_width4 2
#property indicator_width5 2
#property indicator_width6 2
#property indicator_width7 2
#property indicator_width8 2

// ============================================================================================
// * Линии 8/8 и 0/8 (Окончательное сопротивление).
// * Эти линии самые сильные и оказывают сильнейшие сопротивления и поддержку.
// ============================================================================================
//* Линия 7/8  (Слабая, место для остановки и разворота). Weak, Stall and Reverse
//* Эта линия слаба. Если цена зашла слишком далеко и слишком быстро и если она остановилась около этой линии, 
//* значит она развернется быстро вниз. Если цена не остановилась около этой линии, она продолжит движение вверх к 8/8.
// ============================================================================================
//* Линия 1/8  (Слабая, место для остановки и разворота). Weak, Stall and Reverse
//* Эта линия слаба. Если цена зашла слишком далеко и слишком быстро и если она остановилась около этой линии, 
//* значит она развернется быстро вверх. Если цена не остановилась около этой линии, она продолжит движение вниз к 0/8.
// ============================================================================================
//* Линии 6/8 и 2/8 (Вращение, разворот). Pivot, Reverse
//* Эти две линии уступают в своей силе только 4/8 в своей способности полностью развернуть ценовое движение.
// ============================================================================================
//* Линия 5/8 (Верх торгового диапазона). Top of Trading Range
//* Цены всех рынков тратят 40% времени, на движение между 5/8 и 3/8 линиями. 
//* Если цена двигается около линии 5/8 и остается около нее в течении 10-12 дней, рынок сказал что следует 
//* продавать в этой «премиальной зоне», что и делают некоторые люди, но если цена сохраняет тенденцию оставаться 
//* выше 5/8, то она и останется выше нее. Если, однако, цена падает ниже 5/8, то она скорее всего продолжит 
//* падать далее до следующего уровня сопротивления.
// ============================================================================================
//* Линия 3/8 (Дно торгового диапазона). Bottom of Trading Range
//* Если цены ниже этой лини и двигаются вверх, то цене будет сложно пробить этот уровень. 
//* Если пробивают вверх эту линию и остаются выше нее в течении 10-12 дней, значит цены останутся выше этой линии 
//* и потратят 40% времени двигаясь между этой линией и 5/8 линией.
// ============================================================================================
//* Линия 4/8 (Главная линия сопротивления/поддержки). Major Support/Resistance
//* Эта линия обеспечивает наибольшее сопротивление/поддержку. Этот уровень является лучшим для новой покупки или продажи. 
//* Если цена находится выше 4/8, то это сильный уровень поддержки. Если цена находится ниже 4/8, то это прекрасный уровень 
//* сопротивления.
// ============================================================================================
extern int P = 64;
extern int TextShift=0;
extern int code=158;

double  dmml = 0,
        dvtl = 0,
        sum  = 0,
        v1 = 0,
        v2 = 0,
        mn = 0,
        mx = 0,
        x1 = 0,
        x2 = 0,
        x3 = 0,
        x4 = 0,
        x5 = 0,
        x6 = 0,
        y1 = 0,
        y2 = 0,
        y3 = 0,
        y4 = 0,
        y5 = 0,
        y6 = 0,
        octave = 0,
        fractal = 0,
        range   = 0,
        finalH  = 0,
        finalL  = 0,
        mml[8];

string  ln_txt[8],        
        buff_str = "";
        
int     
        bn_v1   = 0,
        bn_v2   = 0,
        OctLinesCnt = 8,
        mml_thk = 8,
        mml_clr[8],
        mml_shft = 3,
        nTime = 0,
        CurPeriod = 0,
        nDigits = 0,
        i = 0;
double Buffer_1[];
double Buffer_2[];
double Buffer_3[];
double Buffer_4[];
double Buffer_5[];
double Buffer_6[];
double Buffer_7[];
double Buffer_8[];
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int init() 
  {
//---- indicators
   SetIndexStyle(0,DRAW_ARROW);
   SetIndexBuffer(0,Buffer_1);
   SetIndexArrow(0,code);
   SetIndexDrawBegin(0,P+1);
   SetIndexEmptyValue(0,0.0);
//----   
   SetIndexStyle(1,DRAW_ARROW);
   SetIndexBuffer(1,Buffer_2);
   SetIndexArrow(1,code);
   SetIndexDrawBegin(1,P+1);
   SetIndexEmptyValue(1,0.0);
//----   
   SetIndexStyle(2,DRAW_ARROW);
   SetIndexBuffer(2,Buffer_3);
   SetIndexArrow(2,code);
   SetIndexDrawBegin(2,P+1);
   SetIndexEmptyValue(2,0.0);
//----   
   SetIndexStyle(3,DRAW_ARROW);
   SetIndexBuffer(3,Buffer_4);
   SetIndexArrow(3,code);
   SetIndexDrawBegin(3,P+1);
   SetIndexEmptyValue(3,0.0);
//----   
   SetIndexStyle(4,DRAW_ARROW);
   SetIndexBuffer(4,Buffer_5);
   SetIndexArrow(4,code);
   SetIndexDrawBegin(4,P+1);
   SetIndexEmptyValue(4,0.0);
//----   
   SetIndexStyle(5,DRAW_ARROW);
   SetIndexBuffer(5,Buffer_6);
   SetIndexArrow(5,code);
   SetIndexDrawBegin(5,P+1);
   SetIndexEmptyValue(5,0.0);
//----   
   SetIndexStyle(6,DRAW_ARROW);
   SetIndexBuffer(6,Buffer_7);
   SetIndexArrow(6,code);
   SetIndexDrawBegin(6,P+1);
   SetIndexEmptyValue(6,0.0);
//----   
   SetIndexStyle(7,DRAW_ARROW);
   SetIndexBuffer(7,Buffer_8);
   SetIndexArrow(7,code);
   SetIndexDrawBegin(7,P+1);
   SetIndexEmptyValue(7,0.0);
//----   
   SetIndexLabel(0,"[-2/8]P");
   SetIndexLabel(1,"[-1/8]P");
   SetIndexLabel(2,"ПОДДЕРЖКА [0/8]");
   SetIndexLabel(3,"ОСТАНОВКА_РАЗВОРОТ [1/8]");
   SetIndexLabel(4,"ВРАЩЕНИЕ_РАЗВОРОТ [2/8]");
   SetIndexLabel(5,"ДНО_КАНАЛА [3/8]");
   SetIndexLabel(6,"СОПРОТИВЛЕНИЕ_ПОДДЕРЖКА [4/8]");
   SetIndexLabel(7,"ВЕРХ_КАНАЛА [5/8]");
   
   ln_txt[0]  = "                                     -2/8";// "extremely overshoot [-2/8]";// [-2/8]
   ln_txt[1]  = "                                     -1/8";// "overshoot [-1/8]";// [-1/8]
   ln_txt[2]  = "                                     0/8";// "Ultimate Support - extremely oversold [0/8]";// [0/8]
   ln_txt[3]  = "                                     1/8";// "Weak, Stall and Reverse - [1/8]";// [1/8]
   ln_txt[4]  = "                                     2/8";// "Pivot, Reverse - major [2/8]";// [2/8]
   ln_txt[5]  = "                                     3/8";// "Bottom of Trading Range - [3/8], if 10-12 bars then 40% Time. BUY Premium Zone";//[3/8]
   ln_txt[6]  = "                                     4/8";// "Major Support/Resistance Pivotal Point [4/8]- Best New BUY or SELL level";// [4/8]
   ln_txt[7]  = "                                     5/8";// "Top of Trading Range - [5/8], if 10-12 bars then 40% Time. SELL Premium Zone";//[5/8]
   

   mml_shft = TextShift;
   mml_thk  = 3;

   // Начальная установка цветов уровней октав 
   mml_clr[0]  = Red;     // [-2]/8
   mml_clr[1]  = OrangeRed;        // [-1]/8
   mml_clr[2]  = Blue;        //  [0]/8
   mml_clr[3]  = Yellow;      //  [1]/8
   mml_clr[4]  = SteelBlue;         //  [2]/8
   mml_clr[5]  = ForestGreen;   //  [3]/8
   mml_clr[6]  = Blue;        //  [4]/8
   mml_clr[7]  = ForestGreen;   //  [5]/8
   
//----
   return(0);
  }

//+------------------------------------------------------------------+
//| Custor indicator deinitialization function                       |
//+------------------------------------------------------------------+
int deinit() 
  {
//----
    for(i=0;i0) counted_bars--;
 limit=Bars-counted_bars;
//---- TODO: add your code here

//if( (nTime != Time[0]) || (CurPeriod != Period()) ) 
//{
 for(int shift=limit-1; shift>=0; shift--)
  {  
  //price
   bn_v1 = iLowest(NULL,0,MODE_LOW,P,shift);
   bn_v2 = iHighest(NULL,0,MODE_HIGH,P,shift);

   v1 = Low[bn_v1];
   v2 = High[bn_v2];

//determine fractal.....
   if( v2<=250000 && v2>25000 )
   fractal=100000;
   else
     if( v2<=25000 && v2>2500 )
     fractal=10000;
     else
       if( v2<=2500 && v2>250 )
       fractal=1000;
       else
         if( v2<=250 && v2>25 )
         fractal=100;
         else
           if( v2<=25 && v2>12.5 )
           fractal=12.5;
           else
             if( v2<=12.5 && v2>6.25)
             fractal=12.5;
             else
               if( v2<=6.25 && v2>3.125 )
               fractal=6.25;
               else
                 if( v2<=3.125 && v2>1.5625 )
                 fractal=3.125;
                 else
                   if( v2<=1.5625 && v2>0.390625 )
                   fractal=1.5625;
                   else
                     if( v2<=0.390625 && v2>0)
                     fractal=0.1953125;
      
   range=(v2-v1);
   sum=MathFloor(MathLog(fractal/range)/MathLog(2));
   octave=fractal*(MathPow(0.5,sum));
   mn=MathFloor(v1/octave)*octave;
   if( (mn+octave)>v2 )
   mx=mn+octave; 
   else
     mx=mn+(2*octave);


// calculating xx
//x2
    if( (v1>=(3*(mx-mn)/16+mn)) && (v2<=(9*(mx-mn)/16+mn)) )
    x2=mn+(mx-mn)/2; 
    else x2=0;
//x1
    if( (v1>=(mn-(mx-mn)/8))&& (v2<=(5*(mx-mn)/8+mn)) && (x2==0) )
    x1=mn+(mx-mn)/2; 
    else x1=0;

//x4
    if( (v1>=(mn+7*(mx-mn)/16))&& (v2<=(13*(mx-mn)/16+mn)) )
    x4=mn+3*(mx-mn)/4; 
    else x4=0;

//x5
    if( (v1>=(mn+3*(mx-mn)/8))&& (v2<=(9*(mx-mn)/8+mn))&& (x4==0) )
    x5=mx; 
    else  x5=0;

//x3
    if( (v1>=(mn+(mx-mn)/8))&& (v2<=(7*(mx-mn)/8+mn))&& (x1==0) && (x2==0) && (x4==0) && (x5==0) )
    x3=mn+3*(mx-mn)/4; 
    else x3=0;

//x6
    if( (x1+x2+x3+x4+x5) ==0 )
    x6=mx; 
    else x6=0;

     finalH = x1+x2+x3+x4+x5+x6;
// calculating yy
//y1
    if( x1>0 )
    y1=mn; 
    else y1=0;

//y2
    if( x2>0 )
    y2=mn+(mx-mn)/4; 
    else y2=0;

//y3
    if( x3>0 )
    y3=mn+(mx-mn)/4; 
    else y3=0;

//y4
    if( x4>0 )
    y4=mn+(mx-mn)/2; 
    else y4=0;

//y5
    if( x5>0 )
    y5=mn+(mx-mn)/2; 
    else y5=0;

//y6
    if( (finalH>0) && ((y1+y2+y3+y4+y5)==0) )
    y6=mn; 
    else y6=0;

    finalL = y1+y2+y3+y4+y5+y6;

    for( i=0; i        

Recommend