Descripción
El CFractalsOnRingBuffer está diseñado para calcular el indicador técnico de fractales utilizando el algoritmo del buffer circular.
Declaración
class CFractalsOnRingBufferTí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
- 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().
- 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.

Comentarios 0