الدعم وا.afl
上传用户:shiqiang
上传日期:2009-06-12
资源大小:1289k
文件大小:5k
源码类别:

金融证券系统

开发平台:

Others

  1. //------------------------------------------------------------------------------
  2. //
  3. //  Formula Name:    الدعم وا
  4. //  Author/Uploader: nmralarb 
  5. //  E-mail:          nmralarb@hotmail.com
  6. //  Date/Time Added: 2006-10-08 19:25:11
  7. //  Origin:          
  8. //  Keywords:        
  9. //  Level:           basic
  10. //  Flags:           system
  11. //  Formula URL:     http://www.amibroker.com/library/formula.php?id=736
  12. //  Details URL:     http://www.amibroker.com/library/detail.php?id=736
  13. //
  14. //------------------------------------------------------------------------------
  15. //
  16. //  الدعم
  17. //  والمقاومة
  18. //  التاريخية
  19. //
  20. //------------------------------------------------------------------------------
  21. _SECTION_BEGIN("MURREY MATH LINES Formula");
  22. /* MURREY MATH HORIZONTAL LINES Formula for Amibroker
  23. based on Excel spreadsheet by Jacek */
  24. GraphXSpace=1; MaxGraph=15;
  25. Period=Param("MM_Period", 70, 4, 256, 1) ;
  26. Graph1Color=6; Graph2Color=6; Graph3Color=6; Graph4Color=6;
  27. Graph5Color=6; Graph6Color=6; Graph7Color=6; Graph8Color=6;
  28. Graph9Color=6; Graph10Color=6; Graph11Color=6;Graph12Color=6;
  29. Graph13Color=6;
  30. Graph0=Close; Graph0Color=1; Graph0Style=64;
  31. Graph1Style=1; Graph2Style=1; Graph3Style=1; Graph4Style=1;
  32. Graph5Style=1; Graph6Style=1; Graph7Style=1; Graph8Style=1;
  33. Graph9Style=1; Graph10Style=1; Graph11Style=4; Graph12Style=1;
  34. Graph12Style=1;
  35. PER = Period;
  36. BarNR = LastValue(Cum(1)) ;
  37. TimeFrame = BarNR - PER ;
  38. TF = TimeFrame ;
  39. Lo = LastValue(ValueWhen(Cross(Cum(1), TF), LLV(Min(H,L),PER),1)) ;
  40. Hi = LastValue(ValueWhen(Cross(Cum(1), TF), HHV(Max(H,L),PER),1)) ;
  41. Lo = LastValue( LLV(Min(H,L),PER ),1) ;
  42. Hi = LastValue( HHV(Max(H,L),PER ),1) ;
  43. Fractal = IIf(Hi<=250,100, IIf(Hi<=2500,1000, IIf(Hi<=25000,10000, IIf(Hi<=250000,100000, 0 )))) ;
  44. int_Log = int( log(Fractal/(Hi-Lo))/log(2) ) ;
  45. Oct = Fractal * ( exp(ln(1/2)* int_Log ) ) ;
  46. Min_1 = int( Lo / Oct ) * Oct ;
  47. Max_1 = IIf( (Min_1 + Oct) > Hi, Min_1 + Oct, Min_1 + 2*Oct ) ;
  48. Min_2 = IIf( (Min_1 + 1/8*(Max_1-Min_1)) <= Lo AND Hi <= (Max_1 - 1/8*(Max_1-Min_1)) ,
  49. (Min_1 + 1/4*(Max_1-Min_1)) , Min_1 ) ;
  50. Max_2 = IIf( (Min_1 + 1/8*(Max_1-Min_1)) <= Lo AND Hi <= (Max_1 - 1/8*(Max_1-Min_1)) ,
  51. (Max_1 - 1/4*(Max_1-Min_1)) , Max_1 ) ;
  52. /******************************/
  53. Diff = Max_2 - Min_2 ;
  54. H1 = IIf( (Min_2 + 3/16*Diff) <= Lo AND Hi <= (9/16*Diff + Min_2) ,
  55. Min_2 + 1/2*Diff, 0) ;
  56. H2 = IIf( (Min_2 - 1/8*Diff) <= Lo AND Hi <= (5/8*Diff + Min_2) AND H1==0,
  57. Min_2 + 1/2*Diff, 0) ;
  58. H3 = IIf( (Min_2 + 7/16*Diff) <= Lo AND Hi <= (Min_2 + 13/16*Diff), Min_2 + 3/4*Diff, 0 ) ;
  59. H4 = IIf( (Min_2 + 3/8*Diff) <= Lo AND Hi <= (Min_2 + 9/8*Diff) AND H3==0,
  60. Max_2, 0 ) ;
  61. H5 = IIf( (Min_2 + 1/8*Diff)<=Lo AND Hi <= (Min_2 + 7/8*Diff) AND H1==0 AND H2==0 AND H3==0 AND H4==0,
  62. Min_2 + 3/4*Diff , 0 ) ;
  63. H6 = IIf( ( H1 + H2 + H3 + H4 + H5 ) == 0, Max_2, 0 ) ;
  64. /**************************/
  65. L1 = IIf(H1>0, Min_2 + 1/4*Diff, 0) ;
  66. L2 = IIf(H2>0, Min_2, 0) ;
  67. L3 = IIf(H3>0, Min_2 + 1/2*Diff, 0) ;
  68. L4 = IIf(H4>0, Min_2 + 1/2*Diff, 0) ;
  69. L5 = IIf(H5>0, Min_2 + 1/4*Diff, 0) ;
  70. L6 = IIf(H6>0, Min_2, 0 ) ;
  71. M_8 = ( H1 + H2 + H3 + H4 + H5 + H6 ) ;
  72. M_0 = ( L1 + L2 + L3 + L4 + L5 + L6 ) ;
  73. /**************************************/
  74. Graph1 = ValueWhen(Cum(1) >= TF, M_0 );
  75. Graph2 = ValueWhen(Cum(1) >= TF, M_0 + (1*(0.175*(M_8-M_0))));
  76. Graph3 = ValueWhen(Cum(1) >= TF, M_0 + (2*(0.175*(M_8-M_0))));
  77. Graph4 = ValueWhen(Cum(1) >= TF, M_0 + (3*(0.175*(M_8-M_0))));
  78. Graph5 = ValueWhen(Cum(1) >= TF, M_0 + (4*(0.175*(M_8-M_0))));
  79. Graph6 = ValueWhen(Cum(1) >= TF, M_0 + (5*(0.175*(M_8-M_0))));
  80. Graph7 = ValueWhen(Cum(1) >= TF, M_0 + (6*(0.175*(M_8-M_0))));
  81. Graph8 = ValueWhen(Cum(1) >= TF, M_0 + (7*(0.175*(M_8-M_0))));
  82. Graph9 = ValueWhen(Cum(1) >= TF, M_0  + (8*(0.175*(M_8-M_0))));
  83. Graph10 = ValueWhen(Cum(1) >= TF, M_0 + (9*(0.175*(M_8-M_0))));
  84. Graph11 = ValueWhen(Cum(1) >= TF, M_0 - (1*(0.175*(M_8-M_0))));
  85. Graph12 = ValueWhen(Cum(1) >= TF, M_0 - (2*(0.175*(M_8-M_0))));
  86. Graph13 = ValueWhen(Cum(1) >= TF, M_0 - (3*(0.175*(M_8-M_0))));
  87. /************************************************** ************/
  88. Title = Name()
  89. + "=" + WriteIf( round(C)== C, NumToStr(C,1) , WriteVal(C) ) + " " + "\c17"
  90. + WriteIf( Interval()==86400, "Daily ", WriteIf(Interval()==3600,"Hourly ", 
  91. WriteIf(Interval()==900,"15 Min ", WriteIf(Interval()==300,"5 Min ", 
  92. WriteIf(Interval()==60,"1 Min ", "" ) ) ) ) )
  93. + Date() + "\c12" + WriteIf(Volume>0," Turnover=","") 
  94. + WriteIf(Volume>0, WriteVal(Volume*Close/1000), "" ) ;
  95. _SECTION_END();