Cauchy_derivative_YTG

Author: Yuriy Tokman
1 Views
0 Downloads
0 Favorites
Cauchy_derivative_YTG
//+------------------------------------------------------------------+
//|                                            Cauchy derivative.mq5 |
//|                                                     Yuriy Tokman |
//|                                                http://ytg.com.ua |
//+------------------------------------------------------------------+
#property copyright "Yuriy Tokman"
#property link      "http://ytg.com.ua"
#property version   "1.00"
#property indicator_separate_window

#property indicator_buffers 1
#property indicator_plots   1
#property indicator_width1   2
#property indicator_type1   DRAW_HISTOGRAM
#property indicator_color1  clrDarkViolet
//--- input parameters
input int            YMA_Period=5;
input int            GMA_Period=12;
//--- indicator buffers
double Buffer[];
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int OnInit()
  {
   SetIndexBuffer(0,Buffer);
   //IndicatorSetInteger(INDICATOR_DIGITS,_Digits);
   PlotIndexSetInteger(0,PLOT_DRAW_BEGIN,MathMax(YMA_Period,GMA_Period));
   string short_name="Cauchy derivative YTG";
   IndicatorSetString(INDICATOR_SHORTNAME,short_name);
//---
   return(INIT_SUCCEEDED);
  }
//+------------------------------------------------------------------+
//| Custom indicator iteration function                              |
//+------------------------------------------------------------------+
int OnCalculate(const int rates_total,
                const int prev_calculated,
                const datetime &time[],
                const double &open[],
                const double &high[],
                const double &low[],
                const double &close[],
                const long &tick_volume[],
                const long &volume[],
                const int &spread[])
  {
//----
   int i,limit;
//--- check for rates
   if(rates_total<MathMax(YMA_Period,GMA_Period)) return(0);
//--- preliminary calculations
   if(prev_calculated==0)limit=MathMax(YMA_Period,GMA_Period);
   else limit=prev_calculated-1;
//--- the main loop of calculations
   for(i=limit;i<rates_total && !IsStopped();i++)
     {
      double MA = ma (open,high,low,close,i);
      double MG = mg (open,high,low,close,i);
      double MA1 = ma (open,high,low,close,i-1);
      double MG1 = mg (open,high,low,close,i-1);      
      Buffer[i] = (MA - MG) - (MA1 - MG1);
     }
 //----
   return(rates_total);
  }
//+------------------------------------------------------------------+
 double mg (const double &o[],const double &h[],const double &l[],const double &c[],int _i)
  {
   double res =1;
   for(int j=_i;j>_i-GMA_Period && j>0;j--)
   res *= (c[j]+o[j]+h[j]+l[j])/4.0;
   return(MathPow(res,1.0/GMA_Period));  
  }
 double ma (const double &o[],const double &h[],const double &l[],const double &c[],int _i)
  {
   double res =1;
   for(int j=_i;j>_i-YMA_Period && j>0;j--)
   res += (c[j]+o[j]+h[j]+l[j])/4.0;
   return(res/YMA_Period);  
  }

Comments

Markdown supported. Formatting help

Markdown Formatting Guide

Element Markdown Syntax
Heading # H1
## H2
### H3
Bold **bold text**
Italic *italicized text*
Link [title](https://www.example.com)
Image ![alt text](image.jpg)
Code `code`
Code Block ```
code block
```
Quote > blockquote
Unordered List - Item 1
- Item 2
Ordered List 1. First item
2. Second item
Horizontal Rule ---