- Evento principal de Asesores Expertos: OnTick
- Principios y conceptos básicos: orden, transacción y posición
- Tipos de operaciones de trading
- Tipos de órdenes
- Modos de ejecución de órdenes por precio y volumen
- Fechas de vencimiento de órdenes pendientes
- Cálculo del margen para una orden futura: OrderCalcMargin
- Estimación del beneficio de una operación de trading: OrderCalcProfit
- Estructura MqlTradeRequest
- Estructura MqlTradeCheckResult
- Solicitar validación: OrderCheck
- Solicitar resultado del envío: estructura MqlTradeResult
- Enviar una solicitud de trading: OrderSend y OrderSendAsync
- Operaciones de compraventa
- Modificar los niveles de Stop Loss y/o Take Profit de una posición
- Trailing stop
- Cierre de una posición: total y parcial
- Cierre de posiciones opuestas: total y parcial
- Colocar una orden pendiente
- Modificar una orden pendiente
- Borrar una orden pendiente
- Obtener una lista de órdenes activas
- Propiedades de una orden (activas e históricas)
- Funciones para leer las propiedades de órdenes activas
- Seleccionar órdenes por propiedades
- Obtener la lista de posiciones
- Propiedades de posiciones
- Funciones de lectura de propiedades de posición
- Propiedades de transacción
- Seleccionar órdenes y transacciones del historial
- Funciones para leer propiedades de órdenes del historial
- Funciones para leer propiedades de transacciones del historial
- Tipos de transacciones de trading
- Evento OnTradeTransaction
- Peticiones síncronas y asíncronas
- Evento OnTrade
- Seguimiento de los cambios en el entorno de trading
- Crear Asesores Expertos multisímbolo
- Limitaciones y ventajas de los Asesores Expertos
- Crear Asesores Expertos en el Asistente MQL
Estimación del beneficio de una operación de trading: OrderCalcProfit
Una de las funciones de la API de MQL5, OrderCalcProfit, permite preevaluar el resultado financiero de una operación de trading si se cumplen las condiciones previstas. Por ejemplo, utilizando esta función puede averiguar la cantidad de beneficios al alcanzar el nivel Take Profit, y la cantidad de pérdidas cuando se activa Stop Loss.
bool OrderCalcProfit(ENUM_ORDER_TYPE action, const string symbol, double volume,
double openPrice, double closePrice, double &profit)
La función calcula el beneficio o la pérdida en la divisa de la cuenta para el entorno de mercado actual basándose en los parámetros pasados.
El tipo de orden se especifica en el parámetro action. Sólo se permiten órdenes de mercado ORDER_TYPE_BUY u ORDER_TYPE_SELL de la enumeración ENUM_ORDER_TYPE. El nombre del instrumento financiero y su volumen se pasan en los parámetros symbol y volume. Los precios de entrada y salida del mercado se fijan mediante los parámetros openPrice y closePrice, respectivamente. La variable profit se pasa por referencia como último parámetro, y en ella se escribirá el valor del beneficio.
La función devuelve un indicador de éxito (true) o de error (false).
La fórmula de cálculo del resultado financiero utilizada en OrderCalcProfit depende del tipo de símbolo.
Identificador |
Formula |
|---|---|
SYMBOL_CALC_MODE_FOREX |
(ClosePrice - OpenPrice) * ContractSize * Lots |
SYMBOL_CALC_MODE_FOREX_NO_LEVERAGE |
(ClosePrice - OpenPrice) * ContractSize * Lots |
SYMBOL_CALC_MODE_CFD |
(ClosePrice - OpenPrice) * ContractSize * Lots |
SYMBOL_CALC_MODE_CFDINDEX |
(ClosePrice - OpenPrice) * ContractSize * Lots |
SYMBOL_CALC_MODE_CFDLEVERAGE |
(ClosePrice - OpenPrice) * ContractSize * Lots |
SYMBOL_CALC_MODE_EXCH_STOCKS |
(ClosePrice - OpenPrice) * ContractSize * Lots |
SYMBOL_CALC_MODE_EXCH_STOCKS_MOEX |
(ClosePrice - OpenPrice) * ContractSize * Lots |
SYMBOL_CALC_MODE_FUTURES |
(ClosePrice - OpenPrice) * Lots * TickPrice / TickSize |
SYMBOL_CALC_MODE_EXCH_FUTURES |
(ClosePrice - OpenPrice) * Lots * TickPrice / TickSize |
SYMBOL_CALC_MODE_EXCH_FUTURES_FORTS |
(ClosePrice - OpenPrice) * Lots * TickPrice / TickSize |
SYMBOL_CALC_MODE_EXCH_BONDS |
Lots * ContractSize * (ClosePrice * FaceValue + AccruedInterest) |
SYMBOL_CALC_MODE_EXCH_BONDS_MOEX |
Lots * ContractSize * (ClosePrice * FaceValue + AccruedInterest) |
SYMBOL_CALC_MODE_SERV_COLLATERAL |
Lots * ContractSize * MarketPrice * LiqudityRate |
En las fórmulas se utiliza la siguiente notación:
- Lotes - volumen de la posición en lotes (acciones del contrato)
- ContractSize - tamaño del contrato (un lote, SYMBOL_TRADE_CONTRACT_SIZE)
- TickPrice - precio del tick (SYMBOL_TRADE_TICK_VALUE)
- TickSize - tamaño del tick (SYMBOL_TRADE_TICK_SIZE)
- MarketPrice - último precio de oferta/compra (Bid/Ask) conocido según el tipo de transacción
- OpenPrice - precio de apertura de la posición
- ClosePrice - precio de cierre de la posición
- FaceValue - valor nominal del bono (SYMBOL_TRADE_FACE_VALUE)
- LiqudityRate - ratio de liquidez (SYMBOL_TRADE_LIQUIDITY_RATE)
- AccruedInterest - ingresos por cupones acumulados (SYMBOL_TRADE_ACCRUED_INTEREST)
La función OrderCalcProfit sólo puede utilizarse en Asesores Expertos y scripts. Para calcular los beneficios/pérdidas potenciales en los indicadores es necesario aplicar un método alternativo, por ejemplo, cálculos independientes mediante fórmulas.
Para eludir la restricción de uso de las funciones OrderCalcProfit y OrderCalcMargin en indicadores, hemos desarrollado un conjunto de funciones que realizan cálculos utilizando las fórmulas de esta sección, así como la sección Requisitos de margen. Las funciones se encuentran en el archivo de encabezado MarginProfitMeter.mqh, dentro del espacio de nombres común MPM (de «Margin Profit Meter»).
En concreto, para calcular el resultado financiero, es importante disponer del valor de un punto de un instrumento concreto. En las fórmulas anteriores, participa indirectamente en la diferencia entre los precios de apertura y cierre (ClosePrice - OpenPrice).
La función calcula el valor de un punto de precio PointValue.
namespace MPM
|
Al principio de la función solicitamos todas las propiedades de los símbolos necesarias para el cálculo. A continuación, en función del tipo de símbolo, se obtiene el beneficio/pérdida en la divisa del beneficio de este instrumento. Tenga en cuenta que aquí no hay bonos cuyas fórmulas tengan en cuenta el precio nominal y los ingresos por cupones.
double result = 0;
|
Por último, convertimos el importe a la divisa de la cuenta, si difiere.
string account = AccountInfoString(ACCOUNT_CURRENCY);
|
La función de ayuda Convert se utiliza para convertir importes. A su vez, depende de la función FindExchangeRate, que busca entre todos los símbolos disponibles uno que contenga el tipo de cambio de la divisa current a la moneda account.
bool Convert(const string current, const string account,
|
La función FindExchangeRate busca caracteres en Observación de Mercado y devuelve el nombre del primer símbolo de Forex que coincida, si hay varios, en el parámetro result. Si la cotización corresponde al orden directo de las divisas «current/account», la función devolverá +1, y si es al contrario, será «account/current», es decir, -1.
int FindExchangeRate(const string current, const string account, string &result)
|
El código completo de las funciones se encuentra en el archivo adjunto MarginProfitMeter.mqh.
Vamos a comprobar el rendimiento de la función OrderCalcProfit y del grupo de funciones MPM con un script de prueba ProfitMeter.mq5: calcularemos la estimación de ganancias/pérdidas de las operaciones virtuales para todos los símbolos de Observación de Mercado, y lo haremos utilizando dos métodos: el integrado y el nuestro.
En los parámetros de entrada del script, puede seleccionar el tipo de operación Action (compra o venta), el tamaño del lote Lot y el tiempo de mantenimiento de la posición en barras Duration. El resultado financiero se calcula para las cotizaciones de las últimas barras Duration del marco temporal actual.
#property script_show_inputs
|
En el cuerpo del script, conectamos los archivos de encabezado y mostramos el encabezado con los parámetros.
#include <MQL5Book/MarginProfitMeter.mqh>
|
A continuación, en un bucle a través de símbolos, realizamos los cálculos de dos maneras e imprimimos los resultados para compararlos.
for(int i = 0; i < SymbolsTotal(true); i++)
|
Pruebe a ejecutar el script para diferentes cuentas y conjuntos de instrumentos.
Profits/Losses for buying 1.0 lots of 13 symbols in Market Watch on last 20 bars H1
|
Lo ideal es que los números de cada línea coincidan.