Speed





//+------------------------------------------------------------------+
//|                                                 Speed.mq4        |
//|                      Copyright © 2005, MetaQuotes Software Corp. |
//|                                       http://www.metaquotes.net/ |
//+------------------------------------------------------------------+
#property copyright "Copyright © 2005, MetaQuotes Software Corp."
#property link      "http://www.metaquotes.net/"

#property indicator_separate_window
#property indicator_buffers 3
#property indicator_color1 LightSeaGreen
#property indicator_color2 Red
#property indicator_color3 Lime

extern bool cumulat=true;
extern int pips_min=10;
extern int pips_max=300;
extern int pips_min1=10;
extern int pips_max1=20;
extern int pips_min2=10;
extern int pips_max2=30;

//---- buffers
double ExtMapBuffer1[];
double ExtMapBuffer2[];
double ExtMapBuffer3[];
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int init()
  {
   IndicatorShortName("Speed ((C0-C1)/Cm) / ((V0-V1)/Vm)");
//---- indicators
   SetIndexStyle(0,DRAW_LINE);
   SetIndexBuffer(0,ExtMapBuffer1);
   SetIndexEmptyValue(0,0);
   SetIndexStyle(1,DRAW_LINE);
   SetIndexBuffer(1,ExtMapBuffer2);
   SetIndexEmptyValue(1,0);
   SetIndexStyle(2,DRAW_LINE);
   SetIndexBuffer(2,ExtMapBuffer3);   
   SetIndexEmptyValue(2,0);
   
//----
   return(0);
  }
//+------------------------------------------------------------------+
//| Accumulation/Distribution                                        |
//+------------------------------------------------------------------+
int start()
  {
   int i,n,Bars1,counted_bars=IndicatorCounted();
   RefreshRates();
      double high0 =0;
      double low0  =0;
      double open0 =0;
      double close0=0;
      double pips0=0;
      double vol0=0;
      
      double high1 =0;
      double low1  =0;
      double open1 =0;
      double close1=0;
      double pips1=0;
      double vol1=0;
      
      double high2 =0;
      double low2  =0;
      double open2 =0;
      double close2=0;
      double pips2=0;
      double vol2=0;     

      double high3 =0;
      double low3  =0;
      double open3 =0;
      double close3=0;
      double pips3=0;
      double vol3=0;
      
      double high4 =0;
      double low4  =0;
      double open4 =0;
      double close4=0;
      double pips4=0;
      double vol4=0;
      
      double high5 =0;
      double low5  =0;
      double open5 =0;
      double close5=0;
      double pips5=0;
      double vol5=0;    

      double close_med =0;
      double vol_med=0;
      double pips_med=0;      
      double vit1=0;   
      double vit2=0;         
//----
   //i=0;
   //n=Bars-counted_bars-1;
   //while(i<=n)
   Bars1=Bars/2;
   i=Bars1;//Bars-counted_bars-1;
   while(i>=0)   
   {
      high0 =High[i];
      low0  =Low[i];
      open0 =Open[i];
      close0=Close[i];
      pips0=close0/Point;
      vol0=Volume[i];
      
      high1 =High[i+1];
      low1  =Low[i+1];
      open1 =Open[i+1];
      close1=Close[i+1];
      pips1=close1/Point;
      vol1=Volume[i+1];
      
      high2 =High[i+2];
      low2  =Low[i+2];
      open2 =Open[i+2];
      close2=Close[i+2];
      pips2=close2/Point;
      vol2=Volume[i+2];     

      high3 =High[i+3];
      low3  =Low[i+3];
      open3 =Open[i+3];
      close3=Close[i+3];
      pips3=close0/Point;
      vol3=Volume[i+3];
      
      high4 =High[i+4];
      low4  =Low[i+4];
      open4 =Open[i+4];
      close4=Close[i+4];
      pips4=close1/Point;
      vol4=Volume[i+4];
      
      high5 =High[i+5];
      low5  =Low[i+5];
      open5 =Open[i+5];
      close5=Close[i+5];
      pips5=close5/Point;
      vol5=Volume[i+5];    

      close_med = (close0+close1+close2+close3+close4+close5)/6;
      vol_med= (vol0+vol1+vol2+vol3+vol4+vol5)/6;
      pips_med= (pips0+pips1+pips2+pips3+pips4+pips5)/6;      
      
      if (close_med==0) close_med=1;
      if (vol_med==0) vol_med=1;
      if (pips_med==0) pips_med=1;
      
      if (((pips0-pips1)>pips_min) && ((pips0-pips1)<pips_max) ) 
      {
        double x1=((vol0-vol1)/vol_med);
        if(x1==0) x1=1;
        vit1=((pips0-pips1)/pips_med)/x1;             
        ExtMapBuffer1[i]=vit1;//(close0-close1);//vit1;  //(close-low)-(high-close);
      }  
      else
        ExtMapBuffer1[i]=0;        

      if (((pips0-pips1)>pips_min1) && ((pips0-pips1)<pips_max1) ) 
      {
        double x2=((vol0-vol1)/vol_med);
        if(x2==0)x2=1;
        vit1=((pips0-pips1)/pips_med)/x2;             
        ExtMapBuffer2[i]=vit1;//(close0-close1);//vit1;  //(close-low)-(high-close);
      }  
      else
        ExtMapBuffer2[i]=0;      
 /*       
      if (((pips0-pips1)>pips_min2) && ((pips0-pips1)<pips_max2) ) 
      {
        vit1=((pips0-pips1)/pips_med)/((vol0-vol1)/vol_med);             
        ExtMapBuffer3[i]=vit1;//(close0-close1);//vit1;  //(close-low)-(high-close);
      }  
      else
        ExtMapBuffer3[i]=0;                 
      
 */   double x3=(vol1-vol2);
      if(x3==0)x3=1 ; 
      vit2=(pips1-pips2)/x3;  
      //ExtMapBuffer1[i]=ExtMapBuffer1[i+1]+Volume[i];             
      //ExtMapBuffer1[i]=vit1;  //(close-low)-(high-close);
      /*
      if(ExtMapBuffer1[i]!=0)
      {
         double diff=high-low;
         if(0==diff)
            ExtMapBuffer1[i]=0;
         else
         {
            ExtMapBuffer1[i]/=diff;
            ExtMapBuffer1[i]*=Volume[i];
         }
      }*/
      if((i<Bars1-1) && cumulat) 
      {
        ExtMapBuffer1[i]-=ExtMapBuffer1[i+1];
        ExtMapBuffer2[i]-=ExtMapBuffer2[i+1];
        //ExtMapBuffer3[i]-=ExtMapBuffer3[i+1];
      }  
      
      
      i--;
     }
//----
   return(0);
  }
//+------------------------------------------------------------------+



Sample





Analysis



Market Information Used:

Series array that contains the highest prices of each bar
Series array that contains the lowest prices of each bar
Series array that contains open prices of each bar
Series array that contains close prices for each bar
Series array that contains tick volumes of each bar


Indicator Curves created:

Implements a curve of type DRAW_LINE


Indicators Used:



Custom Indicators Used:

Order Management characteristics:

Other Features: