/*
   Generated by EX4-TO-MQ4 decompiler V4.0.225.1g []
   Website: http://purebeam.biz
   E-mail : hussamalqudsi@yahoo.com
*/
#property copyright "Copyright 2010, hussam alqudsi"
#property link      "hussamalqudsi@yahoo.com"

#property indicator_separate_window
#property indicator_buffers 3
#property indicator_color1 Blue
#property indicator_color2 Lime
#property indicator_color3 Red

extern int intensity = 50;
extern int periods = 800;
double g_ibuf_84[];
double g_ibuf_88[];
double g_ibuf_92[];

int init() {
   SetIndexStyle(0, DRAW_NONE);
   SetIndexStyle(1, DRAW_HISTOGRAM, STYLE_SOLID, 5, Lime);
   SetIndexStyle(2, DRAW_HISTOGRAM, STYLE_SOLID, 5, Red);
   SetIndexBuffer(0, g_ibuf_84);
   SetIndexBuffer(1, g_ibuf_88);
   SetIndexBuffer(2, g_ibuf_92);
   IndicatorShortName("FREE SCALPING SYSTEM");
   SetIndexLabel(1, NULL);
   SetIndexLabel(2, NULL);
   return (0);
}

int start() {
   int li_0;
   double ld_8;
   double ld_16;
   double ld_80;
   int li_4 = IndicatorCounted();
   double ld_32 = 0;
   double ld_40 = 0;
   double ld_unused_48 = 0;
   double ld_unused_56 = 0;
   double ld_64 = 0;
   double ld_unused_72 = 0;
   double l_low_88 = 0;
   double l_high_96 = 0;
   if (li_4 > 0) li_4--;
   if (periods > Bars || periods == 0) li_0 = Bars - intensity;
   else li_0 = periods - intensity;
   for (int li_104 = li_0; li_104 >= 0; li_104--) {
      l_high_96 = High[iHighest(NULL, 0, MODE_HIGH, intensity, li_104)];
      l_low_88 = Low[iLowest(NULL, 0, MODE_LOW, intensity, li_104)];
      ld_80 = (High[li_104] + Low[li_104]) / 2.0;
      ld_32 = 0.66 * ((ld_80 - l_low_88) / (l_high_96 - l_low_88) - 0.5) + 0.05 * ld_40;
      ld_32 = MathMin(MathMax(ld_32, -0.999), 0.999);
      g_ibuf_84[li_104] = MathLog((ld_32 + 1.0) / (1 - ld_32)) / 2.0 + ld_64 / 2.0;
      ld_40 = ld_32;
      ld_64 = g_ibuf_84[li_104];
   }
   bool li_108 = TRUE;
   for (li_104 = li_0 - 2; li_104 >= 0; li_104--) {
      ld_16 = g_ibuf_84[li_104];
      ld_8 = g_ibuf_84[li_104 + 1];
      if ((ld_16 < 0.0 && ld_8 > 0.0) || ld_16 < 0.0) li_108 = FALSE;
      if ((ld_16 > 0.0 && ld_8 < 0.0) || ld_16 > 0.0) li_108 = TRUE;
      if (!li_108) {
         g_ibuf_92[li_104] = ld_16;
         g_ibuf_88[li_104] = 0.0;
      } else {
         g_ibuf_88[li_104] = ld_16;
         g_ibuf_92[li_104] = 0.0;
      }
   }
   return (0);
}