Você está perdendo oportunidades de negociação:
- Aplicativos de negociação gratuitos
- 8 000+ sinais para cópia
- Notícias econômicas para análise dos mercados financeiros
Registro
Login
Você concorda com a política do site e com os termos de uso
Se você não tem uma conta, por favor registre-se
...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:
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:
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.
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.
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.
Начал полевые испытания сигнала/советника Five Wave: https://www.mql5.com/pt/signals/98850 . Советник генерирует торговые сигналы на основе прогноза от индикатора FivePattern.
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?
HEAVY!!!! Para o desenvolvedor, parabéns!
Gostei do fato de que havia algo novo, absolutamente diferente dos outros. Quase como um know-how.