Vous manquez des opportunités de trading :
- Applications de trading gratuites
- Plus de 8 000 signaux à copier
- Actualités économiques pour explorer les marchés financiers
Inscription
Se connecter
Vous acceptez la politique du site Web et les conditions d'utilisation
Si vous n'avez pas de compte, veuillez vous inscrire
Lignes obligatoires en jaune
Lignes jaunes requises
Maintenant, dites-moi comment faire du profit ici... Ou est-ce pour construire un jeu ?
Bonjour à tous, pouvez-vous s'il vous plaît m'aider à trouver une erreur dans le code de l'EA, je pense que j'ai tout regardé, il semble que tout soit écrit correctement dans le code, mais le programme ne fonctionne pas correctement pour une raison quelconque ! L'idée est la suivante : le conseiller doit chercher deux longues bougies de la même direction (la longueur entre les bougies est ajustable dans le conseiller, c'est-à-dire entre les deux bougies minimum ou maximum, selon la direction), si le prix dans la direction opposée casse le minimum ou le maximum de la dernière bougie, une transaction doit s'ouvrir (Exemple de situations d'image sur le graphique joint au fichier). Le conseiller devrait ouvrir des transactions à chaque fois que la situation s'y prête, mais pour une raison quelconque, il n'ouvre des transactions que dans les fenêtres de trading entre les jours. Voici la situation, qui n'est pas difficile de programmeurs, s'il vous plaît aider, fixer l'erreur. Le code EA se trouve ci-dessous ainsi que dans le fichier joint.
Bonjour à tous, pouvez-vous s'il vous plaît m'aider à trouver une erreur dans le code de l'EA, je pense avoir tout regardé, il semble avoir été écrit correctement dans le code, mais le programme ne trade pas correctement pour une raison quelconque ! L'idée est la suivante : le conseiller doit chercher deux longues bougies de la même direction (la longueur entre les bougies est ajustable dans le conseiller, c'est-à-dire entre les deux bougies minimum ou maximum, selon la direction), si le prix dans la direction opposée casse le minimum ou le maximum de la dernière bougie, une transaction doit s'ouvrir (Exemple de situations d'image sur le graphique joint au fichier). Le conseiller devrait ouvrir des transactions à chaque fois que la situation s'y prête, mais pour une raison quelconque, il n'ouvre des transactions que dans les fenêtres de trading entre les jours. Voici la situation, qui n'est pas difficile de programmeurs, s'il vous plaît aider, fixer l'erreur. Voir le code EA ci-dessous ainsi que dans le fichier joint.
Il est préférable d'écrire d'abord la partie de l'EA qui marquerait sur le graphique les bougies trouvées, afin que tout devienne clair. Et les lignes suivantes sont inutiles dans votre cas :
Maintenant, dites-moi comment faire un profit ici... Ou en avez-vous besoin pour construire un jeu ?
Il n'y a pas encore de moyen d'obtenir un bénéfice. Il existe un algorithme pour le calcul de deux objectifs de prix probables, le long de la tendance, par cinq points majeurs, mais il est calculé sur un serveur spécial avec un abonnement payant. Je veux calculer les objectifs moi-même, le travail sur l'algorithme n'est pas encore terminé.
À quoi ressemblera votre programme dans MQL4 ?
Si vous avez une bonne stratégie et que vous êtes prêt à la partager, je peux écrire un EA. Je vous invite à en discuter soit publiquement soit en message privé.
Anton, aide-moi, j'ai ajouté la fonction trailing stop à l'EA, je l'ai compilé et il montre deux erreurs. - On m'a fait un lavage de cerveau, je n'arrive pas à trouver comment les réparer pour obtenir une chouette. Cependant, les transactions sont fermées selon l'ancienne stratégie après que le prix ait touché la limite supérieure du canal et la limite inférieure, respectivement. Je suppose que quelque chose doit être changé ici aussi. - Rappelez les gars de l'armée du DNR.
#property copyright "Copyright 2017, MetaQuotes Software Corp."
#lien de propriété "https://www.mql5.com"
#propriété version "1.00"
#propriété stricte
//---------------------------------------------------------
extern double Lots = 0.01 ;
extern int TakeProfit = 600 ;
extern int StopLoss = 25 ;
extern int Magic = 0001 ;
extern int Slippage = 3 ;
extern int TralType = 0 ; // 0-SAR, 1-ATR, 2-HMA.
extern double SAR_Step = 0.02 ;
extern double SAR_Max = 0.2 ;
extern int ATR_Period = 14 ;
extern double ATR_K = 2.0 ;
extern inttern HMA_Period = 16 ;
extern intern HMA_Method = 3 ;
extern inttern HMA_Shift = 0 ;
datetime LBT ;
//---------------------------------------------------------
extern string TMA = "Paramètres de l'indicateur TMA" ;
extern string TimeFrame = "cadre temporel actuel" ;
extern int HalfLength = 56 ;
extern int Price = "PRICE_CLOSE ;
extern double ATRMultiplier = 2.0 ;
extern inttern ATRPeriod = 100 ;
extern bool Interpolate = true ;
//---------------------------------------------------------
double PriceHigh, PriceLow, SL, TP ;
int ticket ;
//+------------------------------------------------------------------+
//| Fonction d'initialisation de l'expert |
//+------------------------------------------------------------------+
int OnInit()
{
si (Chiffres == 3 || Chiffres == 5)
{
TakeProfit *= 10 ;
StopLoss *= 10 ;
Dérapage *= 10 ;
}
return(INIT_SUCCEEDED) ;
}
//+------------------------------------------------------------------+
//| Fonction de désinitialisation experte |
//+------------------------------------------------------------------+
void OnDeinit(const int reason)
{
}
//+------------------------------------------------------------------+
//| fonction tick expert |
//+------------------------------------------------------------------+
void OnTick()
{
PriceHigh = iCustom(NULL, 0, "TMA_Fair", TimeFrame, HalfLength, Price, ATRMultiplier, ATRPeriod, Interpolate, 1, 0) ;
PriceLow = iCustom(NULL, 0, "TMA_Fair", TimeFrame, HalfLength, Price, ATRMultiplier, ATRPeriod, Interpolate, 2, 0) ;
si(CountSell() == 0 && Bid >= PriceHigh)
{
ticket = OrderSend(Symbol(), OP_SELL, Lots, Bid, Slippage, 0, 0, "TMA robot", Magic, 0, Red) ;
si (ticket > 0)
{
SL = NormalizeDouble(Bid + StopLoss*Point, Digits) ;
TP = NormalizeDouble(Bid - TakeProfit*Point, Digits) ;
if (OrderSelect(ticket, SELECT_BY_TICKET))
si (!OrderModify(ticket, OrderOpenPrice(), SL, TP, 0))
Print("Erreur de modification de commande !")
}
}
si (CountBuy() == 0 && Ask <= PriceLow)
{
ticket = OrderSend(Symbol(), OP_BUY, Lots, Ask, Slippage, 0, 0, "TMA robot", Magic, 0, Blue) ;
si (ticket > 0)
{
TP = NormalizeDouble(Ask + TakeProfit*Point, Digits) ;
SL = NormalizeDouble(Ask - StopLoss*Point, Digits) ;
if (OrderSelect(ticket, SELECT_BY_TICKET))
if(!OrderModify(ticket, OrderOpenPrice(), SL, TP, 0))
Print("Erreur lors de la modification de l'ordre d'achat !")
} else Print("Erreur lors de l'ouverture de l'ordre d'achat") ;
}
//+------------------------------------------------------------------+
//| Fonction d'initialisation de l'expert |
//+------------------------------------------------------------------+
int init()
{
//--------
//--------
retour (0) ;
}
//+------------------------------------------------------------------+
//| fonction tick expert |
//+------------------------------------------------------------------+
void OnTick()
{
PriceHigh = iCustom(NULL, 0, "TMA_Fair", TimeFrame, HalfLength, Price, ATRMultiplier, ATRPeriod, Interpolate, 1, 0) ;
PriceLow = iCustom(NULL, 0, "TMA_Fair", TimeFrame, HalfLength, Price, ATRMultiplier, ATRPeriod, Interpolate, 2, 0) ;
si(CountSell() == 0 && Bid >= PriceHigh)
{
ticket = OrderSend(Symbol(), OP_SELL, Lots, Bid, Slippage, 0, 0, "TMA robot", Magic, 0, Red) ;
si (ticket > 0)
{
SL = NormalizeDouble(Bid + StopLoss*Point, Digits) ;
TP = NormalizeDouble(Bid - TakeProfit*Point, Digits) ;
if (OrderSelect(ticket, SELECT_BY_TICKET))
si (!OrderModify(ticket, OrderOpenPrice(), SL, TP, 0))
Print("Erreur de modification de l'ordre de vente !")
} else Print("Erreur d'ouverture de l'ordre de vente !")
}
si (CountBuy() == 0 && Ask <= PriceLow)
{
ticket = OrderSend(Symbol(), OP_BUY, Lots, Ask, Slippage, 0, 0, "TMA robot", Magic, 0, Blue) ;
si (ticket > 0)
{
TP = NormalizeDouble(Ask + TakeProfit*Point, Digits) ;
SL = NormalizeDouble(Ask - StopLoss*Point, Digits) ;
if (OrderSelect(ticket, SELECT_BY_TICKET))
if(!OrderModify(ticket, OrderOpenPrice(), SL, TP, 0))
Print("Erreur lors de la modification de l'ordre d'achat !")
} else Print("Erreur lors de l'ouverture de l'ordre d'achat") ;
}
si (Ask <= PriceLow && CountSell() > 0)
{
for (int i = OrdersTotal() -1 ; i>0 ; i--)
{
si (OrderSelect(i, SELECT_BY_POS, MODE_TRADES))
{
si (OrderMagicNumber() == Magic && OrderType() == OP_SELL)
if (!OrderClose(OrderTicket(), OrderLots(), Ask, Slippage, Black))
Print("Erreur de fermeture de l'ordre de vente !")
}
}
}
si (Bid >= PriceHigh && CountBuy() > 0)
{
for (int i = OrdersTotal() -1 ; i>0 ; i--)
{
si (OrderSelect(i, SELECT_BY_POS, MODE_TRADES))
{
si (OrderMagicNumber() == Magic && OrderType() == OP_BUY)
if(!OrderClose(OrderTicket(), OrderLots(), Bid, Slippage, Black))
Print("Erreur d'achat de OrderClose !")
}
}
}
}
//+------------------------------------------------------------------+
int CountSell()
{
int count = 0 ;
for (int trade = OrdersTotal()-1 ; trade>=0 ; trade--)
{
if(OrderSelect(trade, SELECT_BY_POS, MODE_TRADES))
{
if(OrderSymbol() == Symbol() && OrderMagicNumber() == Magic && OrderType() == OP_SELL)
compte++ ;
}
}
return(count) ;
}//+------------------------------------------------------------------+
int CountBuy()
{
int count = 0 ;
for (int trade = OrdersTotal()-1 ; trade>=0 ; trade--)
{
if(OrderSelect(trade, SELECT_BY_POS, MODE_TRADES))
{
if(OrderSymbol() == Symbol() && OrderMagicNumber() == Magic && OrderType() == OP_BUY)
compte++ ;
}
}
return(count) ;
}
//+------------------------------------------------------------------+
//| Fonction de désinitialisation experte |
//+------------------------------------------------------------------+
int deinit()
{
//+-------
//+-------
retour (0)
}
//+------------------------------------------------------------------+
//| fonction de démarrage de l'expert |
//+------------------------------------------------------------------+
int Start()
{
//-----
bool error = fals ;
if (LBT!=Time[0]) {
si (OrdersTotal()!=0) {
for (int i=0 ; i<OrdersTotal() ; i++) {
if (OrderSelect(i,SELECT_BY_POS)&&OrderSymbol()==Symbol()&&OrderType()<2) {
double SL = OrderStopLoss() ;
si OrderType()==0) {
switch (TralType) {
cas 0 : SL = iSAR(NULL,0,SAR_Step,SAR_Max,0) ;
pause ;
cas 1 : SL = High[1] - iATR(NULL,0,ATR,Period,1)*ATR_K ;
pause ;
cas 2 : SL = iCustom(NULL,0, "VininI_HMAsound&",HMA_Period,HMA_Method,3,HMA_Shift, fals,fals,",1,0,0) ;
pause ;
}
si (SL<OrderStopLoss())
SL = OrderStopLoss() ;
}
if (OrderType()==1) {
switch (TralType) {
cas 0 : SL = iSAR(NULL,0,SAR_Step,SAR_Max,0) ;
pause ;
cas 1 : SL = Low[1] + iATR(NULL,0,ATR,Period,1)*ATR_K ;
pause ;
cas 2 : SL = iCustom(NULL,0, "VininI_HMAsound&",HMA_Period,HMA_Method,3,HMA_Shift, fals,fals,",1,0,0) ;
pause ;
}
si (SL>OrderStopLoss())
SL = OrderStopLoss() ;
}
si (SL!=OrderStopLoss()) {
if(!OrderModify(OrderTicket(),OrderOpenPrice(),SL,OrderTakeProfit(),0))
erreur = vrai ;
}
}
}
}
si (!error)
LBT = Time[0] ;
}
retour (0) ;
}
//+------------------------------------------------------------------+
Pour acquérir de l'expérience dans ce domaine, j'écrirai gratuitement 25 EA pour vos idées et stratégies intéressantes.
Il ne reste que 19 EA
J'aiajouté la fonction de trailing stop à l'EA et je l'ai commenté mais il y a deux erreurs. - J'ai peut-être des erreurs, mais je ne sais pas comment les corriger. Cependant, les transactions sont fermées selon l'ancienne stratégie après que le prix ait touché la limite supérieure du canal et la limite inférieure, respectivement. Je suppose que quelque chose doit être changé ici aussi. - Rappelez les gars de l'armée du DNR.
#property copyright "Copyright 2017, MetaQuotes Software Corp."
#lien de propriété "https://www.mql5.com"
#propriété version "1.00"
#propriété stricte
//---------------------------------------------------------
extern double Lots = 0.01 ;
extern int TakeProfit = 600 ;
extern int StopLoss = 25 ;
extern int Magic = 0001 ;
extern int Slippage = 3 ;
extern int TralType = 0 ; // 0-SAR, 1-ATR, 2-HMA.
extern double SAR_Step = 0.02 ;
extern double SAR_Max = 0.2 ;
extern int ATR_Period = 14 ;
extern double ATR_K = 2.0 ;
extern inttern HMA_Period = 16 ;
extern intern HMA_Method = 3 ;
extern inttern HMA_Shift = 0 ;
datetime LBT ;
//---------------------------------------------------------
extern string TMA = "Paramètres de l'indicateur TMA" ;
extern string TimeFrame = "cadre temporel actuel" ;
extern int HalfLength = 56 ;
extern int Price = "PRICE_CLOSE ;
extern double ATRMultiplier = 2.0 ;
extern inttern ATRPeriod = 100 ;
extern bool Interpolate = true ;
//---------------------------------------------------------
double PriceHigh, PriceLow, SL, TP ;
int ticket ;
//+------------------------------------------------------------------+
//| Fonction d'initialisation de l'expert |
//+------------------------------------------------------------------+
int OnInit()
{
si (Chiffres == 3 || Chiffres == 5)
{
TakeProfit *= 10 ;
StopLoss *= 10 ;
Dérapage *= 10 ;
}
return(INIT_SUCCEEDED) ;
}
//+------------------------------------------------------------------+
//| Fonction de désinitialisation experte |
//+------------------------------------------------------------------+
void OnDeinit(const int reason)
{
}
//+------------------------------------------------------------------+
//| fonction tick expert |
//+------------------------------------------------------------------+
void OnTick()
{
PriceHigh = iCustom(NULL, 0, "TMA_Fair", TimeFrame, HalfLength, Price, ATRMultiplier, ATRPeriod, Interpolate, 1, 0) ;
PriceLow = iCustom(NULL, 0, "TMA_Fair", TimeFrame, HalfLength, Price, ATRMultiplier, ATRPeriod, Interpolate, 2, 0) ;
si(CountSell() == 0 && Bid >= PriceHigh)
{
ticket = OrderSend(Symbol(), OP_SELL, Lots, Bid, Slippage, 0, 0, "TMA robot", Magic, 0, Red) ;
si (ticket > 0)
{
SL = NormalizeDouble(Bid + StopLoss*Point, Digits) ;
TP = NormalizeDouble(Bid - TakeProfit*Point, Digits) ;
if (OrderSelect(ticket, SELECT_BY_TICKET))
si (!OrderModify(ticket, OrderOpenPrice(), SL, TP, 0))
Print("Erreur de modification de commande !")
}
}
si (CountBuy() == 0 && Ask <= PriceLow)
{
ticket = OrderSend(Symbol(), OP_BUY, Lots, Ask, Slippage, 0, 0, "TMA robot", Magic, 0, Blue) ;
si (ticket > 0)
{
TP = NormalizeDouble(Ask + TakeProfit*Point, Digits) ;
SL = NormalizeDouble(Ask - StopLoss*Point, Digits) ;
if (OrderSelect(ticket, SELECT_BY_TICKET))
if(!OrderModify(ticket, OrderOpenPrice(), SL, TP, 0))
Print("Erreur de modification de l'ordre d'achat !")
} else Print("Erreur lors de l'ouverture de l'ordre d'achat") ;
}
//+------------------------------------------------------------------+
//| Fonction d'initialisation de l'expert |
//+------------------------------------------------------------------+
int init()
{
//--------
//--------
retour (0) ;
}
//+------------------------------------------------------------------+
//| fonction tick expert |
//+------------------------------------------------------------------+
void OnTick()
{
PriceHigh = iCustom(NULL, 0, "TMA_Fair", TimeFrame, HalfLength, Price, ATRMultiplier, ATRPeriod, Interpolate, 1, 0) ;
PriceLow = iCustom(NULL, 0, "TMA_Fair", TimeFrame, HalfLength, Price, ATRMultiplier, ATRPeriod, Interpolate, 2, 0) ;
si(CountSell() == 0 && Bid >= PriceHigh)
{
ticket = OrderSend(Symbol(), OP_SELL, Lots, Bid, Slippage, 0, 0, "TMA robot", Magic, 0, Red) ;
si (ticket > 0)
{
SL = NormalizeDouble(Bid + StopLoss*Point, Digits) ;
TP = NormalizeDouble(Bid - TakeProfit*Point, Digits) ;
if (OrderSelect(ticket, SELECT_BY_TICKET))
si (!OrderModify(ticket, OrderOpenPrice(), SL, TP, 0))
Print("Erreur de modification de l'ordre de vente !")
} else Print("Erreur d'ouverture de l'ordre de vente !")
}
si (CountBuy() == 0 && Ask <= PriceLow)
{
ticket = OrderSend(Symbol(), OP_BUY, Lots, Ask, Slippage, 0, 0, "TMA robot", Magic, 0, Blue) ;
si (ticket > 0)
{
TP = NormalizeDouble(Ask + TakeProfit*Point, Digits) ;
SL = NormalizeDouble(Ask - StopLoss*Point, Digits) ;
if (OrderSelect(ticket, SELECT_BY_TICKET))
if(!OrderModify(ticket, OrderOpenPrice(), SL, TP, 0))
Print("Erreur de modification de l'ordre d'achat !")
} else Print("Erreur lors de l'ouverture de l'ordre d'achat") ;
}
si (Ask <= PriceLow && CountSell() > 0)
{
for (int i = OrdersTotal() -1 ; i>0 ; i--)
{
si (OrderSelect(i, SELECT_BY_POS, MODE_TRADES))
{
si (OrderMagicNumber() == Magic && OrderType() == OP_SELL)
if (!OrderClose(OrderTicket(), OrderLots(), Ask, Slippage, Black))
Print("Erreur de fermeture de l'ordre de vente !")
}
}
}
si (Bid >= PriceHigh && CountBuy() > 0)
{
for (int i = OrdersTotal() -1 ; i>0 ; i--)
{
si (OrderSelect(i, SELECT_BY_POS, MODE_TRADES))
{
si (OrderMagicNumber() == Magic && OrderType() == OP_BUY)
if(!OrderClose(OrderTicket(), OrderLots(), Bid, Slippage, Black))
Print("Erreur d'achat de OrderClose !")
}
}
}
}
//+------------------------------------------------------------------+
int CountSell()
{
int count = 0 ;
for (int trade = OrdersTotal()-1 ; trade>=0 ; trade--)
{
if(OrderSelect(trade, SELECT_BY_POS, MODE_TRADES))
{
if(OrderSymbol() == Symbol() && OrderMagicNumber() == Magic && OrderType() == OP_SELL)
compte++ ;
}
}
return(count) ;
}//+------------------------------------------------------------------+
int CountBuy()
{
int count = 0 ;
for (int trade = OrdersTotal()-1 ; trade>=0 ; trade--)
{
if(OrderSelect(trade, SELECT_BY_POS, MODE_TRADES))
{
if(OrderSymbol() == Symbol() && OrderMagicNumber() == Magic && OrderType() == OP_BUY)
compte++ ;
}
}
return(count) ;
}
//+------------------------------------------------------------------+
//| Fonction de désinitialisation experte |
//+------------------------------------------------------------------+
int deinit()
{
//+-------
//+-------
retour (0)
}
//+------------------------------------------------------------------+
//| fonction de démarrage de l'expert |
//+------------------------------------------------------------------+
int Start()
{
//-----
bool error = fals ;
if (LBT!=Time[0]) {
si (OrdersTotal()!=0) {
for (int i=0 ; i<OrdersTotal() ; i++) {
if (OrderSelect(i,SELECT_BY_POS)&&OrderSymbol()==Symbol()&&OrderType()<2) {
double SL = OrderStopLoss() ;
si OrderType()==0) {
switch (TralType) {
cas 0 : SL = iSAR(NULL,0,SAR_Step,SAR_Max,0) ;
pause ;
cas 1 : SL = High[1] - iATR(NULL,0,ATR,Period,1)*ATR_K ;
pause ;
cas 2 : SL = iCustom(NULL,0, "VininI_HMAsound&",HMA_Period,HMA_Method,3,HMA_Shift, fals,fals,",1,0,0) ;
pause ;
}
si (SL<OrderStopLoss())
SL = OrderStopLoss() ;
}
if (OrderType()==1) {
switch (TralType) {
cas 0 : SL = iSAR(NULL,0,SAR_Step,SAR_Max,0) ;
pause ;
cas 1 : SL = Low[1] + iATR(NULL,0,ATR,Period,1)*ATR_K ;
pause ;
cas 2 : SL = iCustom(NULL,0, "VininI_HMAsound&",HMA_Period,HMA_Method,3,HMA_Shift, fals,fals,",1,0,0) ;
pause ;
}
si (SL>OrderStopLoss())
SL = OrderStopLoss() ;
}
si (SL!=OrderStopLoss()) {
if(!OrderModify(OrderTicket(),OrderOpenPrice(),SL,OrderTakeProfit(),0))
erreur = vrai ;
}
}
}
}
si (!error)
LBT = Time[0] ;
}
retour (0) ;
}
//+------------------------------------------------------------------+
J'aiajouté la fonction de trailing stop au conseiller expert, et je l'ai compilé et j'ai obtenu deux erreurs. - J'ai perdu la tête, je n'arrive pas à trouver comment les réparer pour obtenir une chouette. Cependant, les transactions sont fermées selon l'ancienne stratégie après que le prix ait touché la limite supérieure du canal et la limite inférieure, respectivement. Je suppose que quelque chose doit être changé ici aussi. - Rendez-le aux gars de l'armée de la RPD.
Vous ne devriez pas faire de spam.
Je m'excuse si j'ai fait quelque chose de mal. Je ne comprends toujours pas comment j'ai pu spammer... Je crois que j'ai adressé deux messages à deux camarades. Ou cela n'est-il pas autorisé ? - C'est ma faute.