Librerías: Report - página 6

 
 

¡Hola!

He generado alguna información de las ofertas. También estoy escribiendo un código para detracciones, actualmente en beta :)

Archivos adjuntos:
 
Arthur Albano:

¡Hola!

He generado alguna información de las ofertas. También estoy escribiendo un código para drawdowns, actualmente en beta :)

Resultados de las operaciones. ¿Son buenos estos resultados en una cuenta demo?

Resultados comerciales
 
 
Cuadro de equilibrio alternativo multiplataforma

Foro sobre negociación, sistemas automatizados de negociación y prueba de estrategias de negociación

Scripts: Gráfico de saldos HTML

fxsaber, 2019.04.08 09:16

Para MT4/5.
// Código MQL4&5

#property strict

// Copiar "Graph.txt" a "Files\Graph.txt".
// https://www.mql5.com/en/code/25199
// #resource "\Scripts\Graph_HTML\Resource\Graph.txt" as string htm_file

#import "shell32.dll"
  int ShellExecuteW( int hwnd, string lpOperation, string lpFile, string lpParameters, string lpDirectory, int nShowCmd );
#import

#ifdef __MQL5__
  #include <MT4Orders.mqh> // https://www.mql5.com/en/code/16006

  #define  BASEPATH (TerminalInfoString(TERMINAL_PATH) + "\\MQL5\\Files\\")
#else // __MQL5__
  #define  BASEPATH (TerminalInfoString(TERMINAL_PATH) + "\\MQL4\\Files\\")
#endif // __MQL5__

bool CreateBalanceData( const string FileName = "exdat.txt" )
{
  const int handle = FileOpen(FileName, FILE_WRITE | FILE_TXT | FILE_ANSI);
  const bool Res = (handle != INVALID_HANDLE);

  if (Res)
  {
  // https://www.mql5.com/ru/forum/170953/page14#comment_10550116
  #define  CLOSETIME_INDEX 0
  #define  TICKET_INDEX 1
    long Tickets[][2];
    int Total = OrdersHistoryTotal();    

  #ifdef __MQL5__
    static const bool Sort = false;
  #else // __MQL5__
    #ifdef __VIRTUAL__
      static const bool IsTester = ::MQLInfoInteger(MQL_TESTER);

      const bool Sort = !IsTester && !VIRTUAL::GetHandle();
    #else // __VIRTUAL__
      static const bool Sort = !::MQLInfoInteger(MQL_TESTER);
    #endif // __VIRTUAL__

    if (Sort)
    {
      int Amount = 0;

      for (int i = (::ArrayResize(Tickets, Total) >> 1) - 1; i >= 0; i--) // https://www.mql5.com/ru/forum/170953/page16#comment_10604064
        if (OrderSelect(i, SELECT_BY_POS, MODE_HISTORY))
        {
          Tickets[Amount][CLOSETIME_INDEX] = OrderCloseTime();
          Tickets[Amount++][TICKET_INDEX] = OrderTicket();
        }

      if ((bool)(Total = ::ArrayResize(Tickets, Amount) >> 1)) // https://www.mql5.com/ru/forum/170953/page16#comment_10604064
        ::ArraySort(Tickets);
    }
  #endif // __MQL5__
    
    double Balance = 0;

    FileWriteString(handle, "var dat1=[\n");

    for (int i = 0; i < Total; i++)
      if ((Sort ? OrderSelect((int)Tickets[i][TICKET_INDEX], SELECT_BY_TICKET) : (OrderSelect(i, SELECT_BY_POS, MODE_HISTORY))) && // int - (Sort == true) sólo para MQL4.
          ((OrderType() <= OP_SELL) || (OrderType() > OP_SELLSTOP)))
    #undef  TICKET_INDEX
    #undef  CLOSETIME_INDEX
      {
        Balance += OrderProfit() + OrderCommission() + OrderSwap();

        FileWriteString(handle, "[" + (string)((long)OrderCloseTime() * 1000) + "," + DoubleToString(Balance, 2) + "],\n");
      }

    FileWriteString(handle, "];\n");
    FileWriteString(handle, "var T1=dat1[0][0];\n");
    FileWriteString(handle, "var T2=dat1[dat1.length-1][0];\n");
    FileWriteString(handle, "var nTrades=dat1.length;\n");
    FileWriteString(handle, "var Balance=" + DoubleToString(Balance, 2) + ";\n");
    FileWriteString(handle, "var Currency=\"" + AccountInfoString(ACCOUNT_CURRENCY) + "\";\n");

    FileClose(handle);
  }

  return(Res);
}

string GetHTM( const string FileName = "Graph.txt" )
{
  uchar Data[];

  const int handle = FileOpen(FileName, FILE_READ | FILE_BIN);
  const bool Res = (handle != INVALID_HANDLE);

  if (Res)
  {
    FileReadArray(handle, Data);

    FileClose(handle);
  }

  return(Res ? CharArrayToString(Data) : NULL);
}

//+------------------------------------------------------------------+
//| Crea el informe de balance de 'HighCharts' sobre las operaciones en formato .html || //| Crea el informe de balance sobre las operaciones en formato .html
//+------------------------------------------------------------------+
void CreateHighChartsBalanceReport( const string FileName = "Graph.htm" )
{
  const int handle = FileOpen(FileName, FILE_WRITE | FILE_TXT | FILE_ANSI);

  if (handle != INVALID_HANDLE)
  {
// FileWriteString(handle, htm_file);
    FileWriteString(handle, GetHTM());
    FileClose(handle);

    if (CreateBalanceData())
      ShellExecuteW(0, "Open", BASEPATH + FileName, NULL, NULL, 3);
  }
}

void OnStart()
{
  CreateHighChartsBalanceReport();
}



Diferente de Informe - gráfico interactivo con varios artificios.

Balance Graph HTML
Balance Graph HTML
  • www.mql5.com
Pan PrizMA Sin leverage 72 Builds a sliding line with a polynomial of 4 degrees. Extrapolates as a section of a given function with a sinusoid and its axial one. One value is taken from the constructed lines on each bar and a line of extrapolated values is plotted...
 

Excelente herramienta. Sin embargo, cuando se ejecutan pruebas a futuro, sólo guarda el informe de backtest y el balance.

¿Alguna sugerencia sobre cómo guardar también las pruebas prospectivas?


F

 
Se ha añadido una nueva función. Ejemplo de aplicación a un Asesor Experto estándar.
#define  REPORT_TESTER             // El comprobador registrará automáticamente los informes
#define  REPORT_TESTER_INPUTS      // El informe de una sola pasada mostrará los parámetros de entrada de EA - requiere resolución DLL.
#define  REPORT_INTERACTIVE_CHARTS // Añade gráficos interactivos al informe.
#define  REPORT_BROWSER            // Crear un informe con el inicio del navegador - requiere permiso DLL.
#include <Report.mqh> // https://www.mql5.com/es/code/18801

#include <..\Experts\Examples\Moving Average\Moving Average.mq5>


En el trailer está el resultado de lanzar una sola pasada. Ahora puede ver los parámetros de entrada del Asesor Experto y el gráfico de balance interactivo.


Se ha actualizado el script ZY CustomReport. Pruebe un informe de operaciones no estático en su cuenta. Ejemplo de trabajo.

Archivos adjuntos:
Reports.zip  138 kb
 

Finalmente los pases individuales se convirtieron en completos - todos los gráficos aparecieron en el informe.

También en MT4 para todos los brokers en el informe se añadieron datos sobre deslizamientos al ejecutar TP/SL. Para ello, es necesario actualizar la biblioteca.

 

Se han añadido ajustes de comprobador a los informes de una sola pasada.


 

Inesperadamente resultó que a pesar del uso constante de MT5-Tester, dejé completamente de mirar las pestañas Backtest y Chart.

Cuando necesito calcular más rápido o establecer condiciones para la ejecución de la orden, el tamaño de la comisión, lo hago todo a través de Virtual.

La conveniencia es que no necesitas saber Virtual o Report en absoluto. Simplemente escribo las mismas líneas al principio y MT5-Tester se transforma.