//+------------------------------------------------------------------+ //| MM Short_LINES v2.mq4 | //| Copyright © 2006, MetaQuotes Software Corp. | //| http://www.metaquotes.net | //+------------------------------------------------------------------+ #property copyright "Copyright © 2006, MetaQuotes Software Corp." #property link "http://www.metaquotes.net" #property link " Modified by cja" //+------------------------------------------------------------------+ //| Murrey_Math_MT_VG.mq4 | //| Copyright © 2004, Vladislav Goshkov (VG). | //| 4vg@mail.ru | //+------------------------------------------------------------------+ #property copyright "Vladislav Goshkov (VG)." #property link "4vg@mail.ru" #property indicator_chart_window #property indicator_buffers 13 double buffer[]; extern int P = 64; extern int MMPeriod = 0; extern int NumBars = 500; extern int SHIFT = 23; extern color mml_clr_m_2_8 = SteelBlue; // [-2]/8 extern color mml_clr_m_1_8 = Crimson; // [-1]/8 extern color mml_clr_0_8 = DodgerBlue; // [0]/8 extern color mml_clr_1_8 = Yellow; // [1]/8 extern color mml_clr_2_8 = Red; // [2]/8 extern color mml_clr_3_8 = LimeGreen; // [3]/8 extern color mml_clr_4_8 = Blue; // [4]/8 extern color mml_clr_5_8 = LimeGreen; // [5]/8 extern color mml_clr_6_8 = Red; // [6]/8 extern color mml_clr_7_8 = Yellow; // [7]/8 extern color mml_clr_8_8 = DodgerBlue; // [8]/8 extern color mml_clr_p_1_8 = Crimson; // [+1]/8 extern color mml_clr_p_2_8 = SteelBlue; // [+2]/8 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[13], aa; string ln_txt[13], buff_str = "", buff_str2 = ""; int bn_v1 = 0, bn_v2 = 0, OctLinesCnt = 13, mml_thk = 8, mml_clr[13], mml_wdth[13], mml_shft = 35, nTime = 0, CurPeriod = 0, nDigits = 0, i = 0; int NewPeriod=0; //+------------------------------------------------------------------+ //| Custom indicator initialization function | //+------------------------------------------------------------------+ int init() { for(int i=0;i0) { NewPeriod = P*MathCeil(MMPeriod/Period()); } else { NewPeriod = P; } 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] ln_txt[8] = " ````````````````````````` [6/8] ``````````````````````";// "Pivot, Reverse - major [6/8]";// [6/8] ln_txt[9] = " ````````````````````````` [7/8] ``````````````````````";// "Weak, Stall and Reverse - [7/8]";// [7/8] ln_txt[10] = " ````````````````````````` [8/8] ``````````````````````";// "Ultimate Resistance - extremely overbought [8/8]";// [8/8] ln_txt[11] = " ````````````````````````` [+1/8] ```````````````````````";// "overshoot [+1/8]";// [+1/8] ln_txt[12] = " ````````````````````````` [+2/8] ```````````````````````";// "extremely overshoot [+2/8]";// [+2/8] mml_thk = 3; mml_clr[0] = mml_clr_m_2_8; mml_clr[1] = mml_clr_m_1_8; mml_clr[2] = mml_clr_0_8; mml_clr[3] = mml_clr_1_8; mml_clr[4] = mml_clr_2_8; mml_clr[5] = mml_clr_3_8; mml_clr[6] = mml_clr_4_8; mml_clr[7] = mml_clr_5_8; mml_clr[8] = mml_clr_6_8; mml_clr[9] = mml_clr_7_8; mml_clr[10] = mml_clr_8_8; mml_clr[11] = mml_clr_p_1_8; mml_clr[12] = mml_clr_p_2_8; //---- return(0); } //+------------------------------------------------------------------+ //| Custor indicator deinitialization function | //+------------------------------------------------------------------+ int deinit() { for(int i=0;i=0) { if( (nTime != Time[pos]) || (CurPeriod != Period()) ) { //price bn_v1 = iLowest(Symbol(),0,MODE_LOW,NewPeriod+pos,pos); bn_v2 = iHighest(Symbol(),0,MODE_HIGH,NewPeriod+pos,pos); 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