Cómo Dibujar Fractales Usando el Buffer Circular en MetaTrader 5

Mike 2013.01.18 22:00 50 0 0
Archivos adjuntos

Descripción

El CFractalsOnRingBuffer está diseñado para calcular el indicador técnico de fractales utilizando el algoritmo del buffer circular.

Declaración

class CFractalsOnRingBuffer

Título

#include <IncOnRingBuffer\CFractalsOnRingBuffer.mqh>

El archivo CFractalsOnRingBuffer.mqh debe colocarse en la carpeta IncOnRingBuffer, que debe establecerse en MQL5\Include\. Se adjuntan dos archivos con ejemplos utilizados por la clase desde esta carpeta. El archivo con la clase del buffer circular también debe estar en esta carpeta.

Métodos de la Clase

//--- método de inicialización:bool Init(                      // si hay error devuelve false, si tiene éxito - true
   int  bars_right  = 2,        // el número de barras a la derecha del extremo
   int  bars_left   = 2,        // el número de barras a la izquierda del extremo
   int  size_buffer = 256,      // el tamaño del buffer circular
   bool as_series   = false     // true, si es una serie temporal, de lo contrario - false
   );
//--- método de cálculo basado en una serie temporal o los buffers del indicador:int MainOnArray(                  // devuelve el número de elementos procesados
   constint     rates_total,     // el tamaño de los arrays
   constint     prev_calculated, // elementos procesados en la llamada anterior
   constdouble& high[],          // el array de los máximos
   constdouble& low[],           // el array de los mínimos
   );
//--- método de cálculo de fractal basado en elementos de la serie del array high[]double MainOnHigh(               // devuelve el valor del fractal superior para el elemento index-bars_right (barra)
   constint    rates_total,     // el tamaño del array
   constint    prev_calculated, // elementos procesados del array
   constint    begin,           // desde donde comienzan los datos significativos del array
   constdouble high,            // el máximo de la barra actual
   constint    index            // el índice del elemento (barra) actual
   );
//--- método de cálculo del fractal inferior basado en elementos de la serie del array low[]double MainOnLow(                // devuelve el valor del fractal inferior para el elemento index-bars_right (barra)
   constint    rates_total,     // el tamaño del array
   constint    prev_calculated, // elementos procesados del array
   constint    begin,           // desde donde comienzan los datos significativos del array
   constdouble low,             // el mínimo actual de la barra, el máximo del elemento actual del array
   constint    index            // el índice del elemento (barra) actual
   );
//--- métodos de acceso a los datos:int    BarsRequired();  // Devuelve el número necesario de barras para dibujar el indicadorstring Name();          // Devuelve el nombre del indicadorstring NameUpper()      // Devuelve el nombre de los fractales superioresstring NameLower()      // Devuelve el nombre de los fractales inferioresint    BarsRight()      // Devuelve el número de barras a la derecha del extremoint    BarsLeft()       // Devuelve el número de barras a la izquierda del extremoint    Size();          // Devuelve el tamaño del buffer circular

Para obtener los datos calculados del indicador desde los buffers circulares, es posible hacerlo como desde un array común. Por ejemplo:

//--- la clase con los métodos de cálculo del indicador de fractales:#include <IncOnRingBuffer\CFractalsOnRingBuffer.mqh>
CFractalsOnRingBuffer fractals;

...

//+------------------------------------------------------------------+//| Función de iteración del indicador personalizado                              |//+------------------------------------------------------------------+intOnCalculate(constint rates_total,
                constint prev_calculated,
                constdatetime& time[],
                constdouble& open[],
                constdouble& high[],
                constdouble& low[],
                constdouble& close[],
                constlong& tick_volume[],
                constlong& volume[],
                constint& spread[])
  {
//--- cálculo del indicador basado en la serie temporal de precios:
   fractals.MainOnArray(rates_total,prev_calculated,high,low);

...

//--- usar los datos de los buffers circulares "fractals",//    por ejemplo, copiar los datos en el buffer del indicador:
   for(int i=start;i<rates_total-BarsRight && !IsStopped();i++)
     {
      UpperBuffer[i] = fractals.upper[rates_total-1-i]; // fractales superiores
      LowerBuffer[i] = fractals.lower[rates_total-1-i]; // fractales inferiores
     }

...

//--- devolver valor de prev_calculated para la próxima llamada:
   return(rates_total);
  }

Ten en cuenta que la indexación en los buffers circulares es la misma que en la serie temporal.

Ejemplos

  1. El indicador calcula el archivo Test_Fractals_OnArrayRB.mq5 sobre la base de la serie temporal de precios. Se demuestra la aplicación del método MainOnArray().
  2. El archivo Test_Fractals_OnValueRB.mq5 demuestra el uso del método MainOnValue(). Primero se calcula y dibuja el indicador de fractales. Luego, sobre la base de este indicador, se dibuja otro fractal usando el buffer circular.


El resultado del trabajo del Test_Fractals_OnArrayRB.mq5 con el tamaño del buffer circular de 256 elementos



El resultado del trabajo del Test_Fractals_OnValueRB.mq5 con el tamaño del buffer circular de 256 elementos

 

Al escribir el código se utilizaron desarrollos de MetaQuotes Software Corp., Integer y GODZILLA.

Lista
Comentarios 0