Indicadores: FivePattern - página 6

 
nav_soft:

...A propósito, notei um padrão ao otimizar o mecanismo de pesquisa, qualquer que seja o algoritmo de pesquisa: Ziguezague clássico ou outro, o erro na previsão do próximo modelo varia cerca de 20 +/-1%. E isso me leva a pensar que A. Merrill não descreveu deliberadamente 6 padrões (ou seja, 3 números M e W cada) ou não os detectou.

Anteriormente, ele escreveu que há mais 6 padrões. Essa é uma opinião errônea. Aqui está um script simples que confirma que há 32 padrões.

#include <Object.mqh>

#include <Arrays\ArrayObj.mqh>

//+------------------------------------------------------------------+

//| КЛАСС ХРАНЕНИЯ ПОЛУЧЕННЫХ ДАННЫХ                                 |

//+------------------------------------------------------------------+

class MyPPattern : public CObject

  {

private:

   double            A;

   double            B;

   double            C;

   double            D;

   double            E;

public:

                     MyPPattern(void){A=0;B=0;C=0;D=0;E=0;};

                     MyPPattern(double ia, double ib, double ic,

                                double id, double ie)

                                {A=ia;B=ib;C=ic;D=id;E=ie;};

                    ~MyPPattern(void){;};

   //+---------------------------------------------------------------+

   //| SET-МЕТОДЫ                                                    |

   //+---------------------------------------------------------------+

   void              SetA(double in){A = in;};

   void              SetB(double in){B = in;};

   void              SetC(double in){C = in;};

   void              SetD(double in){D = in;};

   void              SetE(double in){E = in;};

   //+---------------------------------------------------------------+

   //| GET-МЕТОДЫ                                                    |

   //+---------------------------------------------------------------+

   double            GetA(void){return(A);};

   double            GetB(void){return(B);};

   double            GetC(void){return(C);};

   double            GetD(void){return(D);};

   double            GetE(void){return(E);};

  };

//+------------------------------------------------------------------+

//| Script program start function                                    |

//+------------------------------------------------------------------+

void OnStart()

  {

   //--- value

   int         filehandle,total;

   double      a=1,b=1,c=1,d=1,e=1,sum=0;

   string      subfolder="Research";

   CArrayObj*  Marray = new CArrayObj;

   CArrayObj*  Warray = new CArrayObj;

   MyPPattern* ppattern;

   //--- Простой поисковый массив

   while(true)

     {

      //--- 1. Инкримент

      a = a + 1;

      if(a > 5){a = 1;b = b + 1;};

      if(b > 5){b = 1;c = c + 1;};

      if(c > 5){c = 1;d = d + 1;};

      if(d > 5){d = 1;e = e + 1;};

      //--- 2. Выход из цикла

      if(e > 5) break;

      //--- 3. Сумматор

      sum = a+b+c+d+e;

      //--- 4. Запись данных

      if(sum == 15)

        {

         //--- Проверка: неравенства

         if(a!=b && a!=c && a!=d && a!=e && b!=c && 

            b!=d && b!=e && c!=d && c!=e && d!=e)

           {

            //--- Проверка: зиг-заг формации

            if(a<b && b>c && c<d && d>e)

              {//--- Формация M-волн

               ppattern = new MyPPattern(a,b,c,d,e);

               Marray.Add(ppattern);

              }

            if(a>b && b<c && c>d && d<e)

              {//--- Формация W-волн

               ppattern = new MyPPattern(a,b,c,d,e);

               Warray.Add(ppattern);

              }

           }

        }

     }

   //--- Сохранение M-данных

   ResetLastError();

   filehandle=FileOpen(subfolder+"\\SearchNewPatternM.csv",FILE_WRITE|FILE_CSV);

   if(filehandle!=INVALID_HANDLE)

     {

      total = Marray.Total();

      for(int i=0;i<total;i++)

        {

         ppattern = Marray.At(i);

         FileWrite(filehandle,ppattern.GetA(),ppattern.GetB(),ppattern.GetC(),

                   ppattern.GetD(),ppattern.GetE());

        }

      //--- Close file

      FileClose(filehandle);

     }

   else Print(__FUNCTION__,": ERROR FileOpen = ",GetLastError());

   //--- Сохранение W-данных

   ResetLastError();

   filehandle=FileOpen(subfolder+"\\SearchNewPatternW.csv",FILE_WRITE|FILE_CSV);

   if(filehandle!=INVALID_HANDLE)

     {

      total = Warray.Total();

      for(int i=0;i<total;i++)

        {

         ppattern = Warray.At(i);

         FileWrite(filehandle,ppattern.GetA(),ppattern.GetB(),ppattern.GetC(),

                   ppattern.GetD(),ppattern.GetE());

        }

      //--- Close file

      FileClose(filehandle);

     }

   else Print(__FUNCTION__,": ERROR FileOpen = ",GetLastError());

   //--- delet all objects

   delete Marray;

   delete Warray;

  }

//+------------------------------------------------------------------+


E o erro de 20% do algoritmo é causado pela detecção tardia do padrão. Notei isso somente depois de testar um padrão duplo. Aqui está uma ilustração:

Detecção tardia de um padrão

 
nav_soft:

Anteriormente, escrevi que há mais 6 padrões. Isso é um equívoco. Aqui está um script simples que confirma que há 32 padrões.

#include <Object.mqh>

#include <Arrays\ArrayObj.mqh>

//+------------------------------------------------------------------+

//| КЛАСС ХРАНЕНИЯ ПОЛУЧЕННЫХ ДАННЫХ                                 |

//+------------------------------------------------------------------+

class MyPPattern : public CObject

  {

private:

   double            A;

   double            B;

   double            C;

   double            D;

   double            E;

public:

                     MyPPattern(void){A=0;B=0;C=0;D=0;E=0;};

                     MyPPattern(double ia, double ib, double ic,

                                double id, double ie)

                                {A=ia;B=ib;C=ic;D=id;E=ie;};

                    ~MyPPattern(void){;};

   //+---------------------------------------------------------------+

   //| SET-МЕТОДЫ                                                    |

   //+---------------------------------------------------------------+

   void              SetA(double in){A = in;};

   void              SetB(double in){B = in;};

   void              SetC(double in){C = in;};

   void              SetD(double in){D = in;};

   void              SetE(double in){E = in;};

   //+---------------------------------------------------------------+

   //| GET-МЕТОДЫ                                                    |

   //+---------------------------------------------------------------+

   double            GetA(void){return(A);};

   double            GetB(void){return(B);};

   double            GetC(void){return(C);};

   double            GetD(void){return(D);};

   double            GetE(void){return(E);};

  };

//+------------------------------------------------------------------+

//| Script program start function                                    |

//+------------------------------------------------------------------+

void OnStart()

  {

   //--- value

   int         filehandle,total;

   double      a=1,b=1,c=1,d=1,e=1,sum=0;

   string      subfolder="Research";

   CArrayObj*  Marray = new CArrayObj;

   CArrayObj*  Warray = new CArrayObj;

   MyPPattern* ppattern;

   //--- Простой поисковый массив

   while(true)

     {

      //--- 1. Инкримент

      a = a + 1;

      if(a > 5){a = 1;b = b + 1;};

      if(b > 5){b = 1;c = c + 1;};

      if(c > 5){c = 1;d = d + 1;};

      if(d > 5){d = 1;e = e + 1;};

      //--- 2. Выход из цикла

      if(e > 5) break;

      //--- 3. Сумматор

      sum = a+b+c+d+e;

      //--- 4. Запись данных

      if(sum == 15)

        {

         //--- Проверка: неравенства

         if(a!=b && a!=c && a!=d && a!=e && b!=c && 

            b!=d && b!=e && c!=d && c!=e && d!=e)

           {

            //--- Проверка: зиг-заг формации

            if(a<b && b>c && c<d && d>e)

              {//--- Формация M-волн

               ppattern = new MyPPattern(a,b,c,d,e);

               Marray.Add(ppattern);

              }

            if(a>b && b<c && c>d && d<e)

              {//--- Формация W-волн

               ppattern = new MyPPattern(a,b,c,d,e);

               Warray.Add(ppattern);

              }

           }

        }

     }

   //--- Сохранение M-данных

   ResetLastError();

   filehandle=FileOpen(subfolder+"\\SearchNewPatternM.csv",FILE_WRITE|FILE_CSV);

   if(filehandle!=INVALID_HANDLE)

     {

      total = Marray.Total();

      for(int i=0;i<total;i++)

        {

         ppattern = Marray.At(i);

         FileWrite(filehandle,ppattern.GetA(),ppattern.GetB(),ppattern.GetC(),

                   ppattern.GetD(),ppattern.GetE());

        }

      //--- Close file

      FileClose(filehandle);

     }

   else Print(__FUNCTION__,": ERROR FileOpen = ",GetLastError());

   //--- Сохранение W-данных

   ResetLastError();

   filehandle=FileOpen(subfolder+"\\SearchNewPatternW.csv",FILE_WRITE|FILE_CSV);

   if(filehandle!=INVALID_HANDLE)

     {

      total = Warray.Total();

      for(int i=0;i<total;i++)

        {

         ppattern = Warray.At(i);

         FileWrite(filehandle,ppattern.GetA(),ppattern.GetB(),ppattern.GetC(),

                   ppattern.GetD(),ppattern.GetE());

        }

      //--- Close file

      FileClose(filehandle);

     }

   else Print(__FUNCTION__,": ERROR FileOpen = ",GetLastError());

   //--- delet all objects

   delete Marray;

   delete Warray;

  }

//+------------------------------------------------------------------+


E o erro de 20% do algoritmo é causado pela detecção tardia do padrão. Percebi isso somente depois de testar um padrão duplo; aqui está uma ilustração:


Entendo que o código foi totalmente reescrito, quando poderei ver esse milagre?
 
ozhiganov:
Sei que o código foi totalmente reescrito. Quando poderemos nos familiarizar com essa maravilha?

Há muitas mudanças:

1. o indicador se tornou "binário": o padrão mais antigo é definido em períodos horários, o mais novo funciona em minutos ("abordagem dos traders" - não sei se terei tempo para adicionar a marcação dos limites da sessão de negociação). O padrão comum é exibido em um gráfico, portanto, há um algoritmo para restaurar o valor total do extremo de tempo do padrão sênior;

2. A classe MyCExtremum foi reescrita: a) o Zig-Zag clássico permanece; b) modificação do Zig-Zag com uma etapa de porcentagem; c) e meu fractal experimental (extremo) + etapa de porcentagem (nas imagens, é o que está funcionando);

3. No Algoritmo de detecção do primeiro ponto do modelo sênior, a condição de ir além dos limites das Bandas de Bollinger é verificada, e o algoritmo também observa essa condição em outros pontos. Acho que, com base nisso, podemos julgar a precisão de um determinado modelo e sua atual integridade (há dificuldades aqui... ainda não há um algoritmo claro);

4. Gráficos: decidi usar objetos ElliotWave5 já prontos;

Será lançado muito em breve. Durante os testes... e isso consome mais tempo do que o projeto.

 
nav_soft:

Há muitas mudanças:

1. o indicador tornou-se "binário": o padrão sênior é definido em períodos horários, o júnior funciona em minutos ("abordagem dos traders" - não sei se terei tempo de adicionar a marcação dos limites da sessão de negociação). O padrão comum é exibido em um gráfico, portanto, há um algoritmo para restaurar o valor total do extremo de tempo do padrão sênior;

2. A classe MyCExtremum foi reescrita: a) o Zig-Zag clássico permanece; b) modificação do Zig-Zag com uma etapa de porcentagem; c) e meu fractal experimental (extremo) + etapa de porcentagem (nas imagens, é o que está funcionando);

3. No Algoritmo de detecção do primeiro ponto do modelo sênior, a condição de ir além dos limites das Bandas de Bollinger é verificada, e o algoritmo também observa essa condição em outros pontos. Acho que, com base nisso, podemos julgar a precisão de um determinado modelo e sua atual integridade (há dificuldades aqui... ainda não há um algoritmo claro);

4. Gráficos: decidi usar objetos ElliotWave5 já prontos;

Será lançado muito em breve. Durante os testes... o que consome mais tempo do que o projeto.

Estou ansioso por isso!!!
 

Início dos testes de campo do sinal/consultor Five Wave: https: //www.mql5.com/ru/signals/98850. O Expert Advisor gera sinais de negociação com base na previsão do indicador FivePattern.

Торговые сигналы для MetaTrader 5: Five Wave indicator Five Pattern
Торговые сигналы для MetaTrader 5: Five Wave indicator Five Pattern
  • Andrey Emelyanov
  • www.mql5.com
Сигнал от советника Five Wave. Торговые правила советника генерируются на индикаторе FivePattern . Скачать индикатор FivePattern и ознакомиться с его работой можно по ссылке .
 
nav_soft:

Начал полевые испытания сигнала/советника Five Wave: https://www.mql5.com/pt/signals/98850 . Советник генерирует торговые сигналы на основе прогноза от индикатора FivePattern.

nav_soft
:

Início dos testes de campo do sinal/consultor Five Wave: https: //www.mql5.com/ru/signals/98850. O Expert Advisor gera sinais de negociação com base na previsão do indicador FivePattern.

Ótimo, estou esperando há muito tempo, o indicador no Code Base será atualizado?
 
ozhiganov:
Ótimo, estou esperando há muito tempo, o indicador no Code Base será atualizado?
Sim. 18.04.2015 - Enviarei o código aos moderadores para verificação e o publicarei no fórum como um arquivo.
[Excluído]  

HEAVY!!!! Para o desenvolvedor, parabéns!

Gostei do fato de que havia algo novo, absolutamente diferente dos outros. Quase como um know-how.

[Excluído]  
Obrigado ao desenvolvedor, estou aguardando a versão atualizada, pois já estamos em 20 de abril)
 
bom dia, como faço para instalar no mt5 esse indicador? how to install this indicator in mt5? my email felipebm1@hotmail.com    thanks