Rejoindre la communauté
banner_forum
Devenez membre de la plus grande
communauté francophone sur le Forex
Partagez, échangez et apprenez en gagnant des crédits sur votre compte de trading

QPG RENKO VERSION 1

  • lefeuvr3

    Je me suis inspiré mais de loin :) de la façon de faire RENKO
    Merci d'ameliorer cet EA
    Code
    //+------------------------------------------------------------------+ //| QPG RENKO VERSION 1.mq4 | //| QPG | //| https://www.mql5.com | //+------------------------------------------------------------------+ #property copyright "QPG" #property link "https://www.mql5.com" #property version "1.00" extern string re="REGULATOR"; extern int adxperiod =14; extern int adxthreshold =27; extern int LotFactor =64; extern int rsiperiod = 2; //rsi period extern int rsiupper = 80; //rsi upper bound, wont buy above this value extern int rsilower = 20; //rsi lower bound, wont sell below this value extern int V0=0; extern int V1=1; extern int MagicNumber=10001; double lot; extern double StopLoss=50; extern double TakeProfit=50; extern int TrailingStop=50; extern int Slippage=3; /*extern int delta_open_buy =10; extern int delta_open_sell =10; extern int delta_close_buy=10; extern int delta_close_sell=10;*/ extern int C0=0; extern int H1=1; extern int H2=2; extern int H3=0; extern int L1=1; extern int L2=2; extern int L3=2; extern int delta=27; //+------------------------------------------------------------------+ // expert start function //+------------------------------------------------------------------+ int start() { double MyPoint=Point; if(Digits==3 || Digits==5) MyPoint=Point*10; double TheStopLoss=0; double TheTakeProfit=0; if( TotalOrdersCount()==0 ) { int result=0; double booster = Volume[V1]< Volume[V0] &&(iADX(Symbol(),0,adxperiod,PRICE_CLOSE,MODE_MAIN,0)>adxthreshold ) && iRSI(Symbol(),0,rsiperiod,PRICE_CLOSE,0)>rsilower && iRSI(Symbol(),0,rsiperiod,PRICE_CLOSE,0)<rsiupper; //+------------------------------------------------------------------+ if((Close[C0]>Open[C0])&&(Close[C0]>High[H1]) // Here is your open buy rule &&(Close[C0]-High[H1])>(delta/*_open_buy*/*Point) &&(booster)) if((Close[C0]>Open[C0])&&(Close[C0]>High[H2]) // Here is your open buy rule &&(Close[C0]-High[H2])>(delta/*_open_buy*/*Point)&&(booster)) //+------------------------------------------------------------------+ { result=OrderSend(Symbol(),OP_BUY,NR(Lot_Volume()),Ask,Slippage,0,0,"EA Generator www.ForexEAdvisor.com",MagicNumber,0,Blue); if(result>0) { TheStopLoss=0; TheTakeProfit=0; if(TakeProfit>0) TheTakeProfit=Ask+TakeProfit*MyPoint; if(StopLoss>0) TheStopLoss=Ask-StopLoss*MyPoint; if(OrderSelect(result,SELECT_BY_TICKET)) bool modif1=OrderModify(OrderTicket(),OrderOpenPrice(),NormalizeDouble(TheStopLoss,Digits),NormalizeDouble(TheTakeProfit,Digits),0,Green); } return(0); } //+------------------------------------------------------------------+ if((Close[C0] <Open[C0])&& (Close[C0]<Low[L1]) // Here is your open Sell rule &&(Low[L1]-Close[C0])>(delta/*_open_sell*/*Point) &&(booster)) if((Close[C0] <Open[C0])&& (Close[C0]<Low[L2]) // Here is your open Sell rule &&(Low[L2]-Close[C0])>(delta/*_open_sell*/*Point)&&(booster)) //+------------------------------------------------------------------+ { result=OrderSend(Symbol(),OP_SELL,NR(Lot_Volume()),Bid,Slippage,0,0,"EA Generator www.ForexEAdvisor.com",MagicNumber,0,Red); if(result>0) { TheStopLoss=0; TheTakeProfit=0; if(TakeProfit>0) TheTakeProfit=Bid-TakeProfit*MyPoint; if(StopLoss>0) TheStopLoss=Bid+StopLoss*MyPoint; if(OrderSelect(result,SELECT_BY_TICKET)) bool modif2=OrderModify(OrderTicket(),OrderOpenPrice(),NormalizeDouble(TheStopLoss,Digits),NormalizeDouble(TheTakeProfit,Digits),0,Green); } return(0); } } for(int cnt=0;cnt<OrdersTotal();cnt++) { if(OrderSelect(cnt, SELECT_BY_POS, MODE_TRADES)) if(OrderType()<=OP_SELL && OrderSymbol()==Symbol() && OrderMagicNumber()==MagicNumber ) { if(OrderType()==OP_BUY) { //+------------------------------------------------------------------+ if((Close[C0] <Open[C0]) &&(Close[C0]<Low[L1]) // Here is your close buy rule &&(Low[L1]-Close[C0])>(delta/*_close_buy*/*Point) &&(booster)) if((Close[C0] <Open[C0]) &&(Close[C0]<Low[L2]) //Here is your close buy rule &&(Low[L2]-Close[C0])>(delta/*_close_buy*/*Point)&&(booster)) //+------------------------------------------------------------------+ { bool modif3=OrderClose(OrderTicket(),OrderLots(),OrderClosePrice(),Slippage,Red); } if(TrailingStop>0) { if(Bid-OrderOpenPrice()>MyPoint*TrailingStop) { if(OrderStopLoss()<Bid-MyPoint*TrailingStop) { bool modif4=OrderModify(OrderTicket(),OrderOpenPrice(),Bid-TrailingStop*MyPoint,OrderTakeProfit(),0,Green); return(0); } } } } else { //+------------------------------------------------------------------+ if((Close[C0]>Open[C0])&&(Close[C0]>High[H1]) // Here is your close sell rule &&(Close[C0]-High[H1])>(delta/*_close_sell*/*Point) &&(booster)) if((Close[C0]>Open[C0])&&(Close[C0]>High[H2]) // Here is your close sell rule &&(Close[C0]-High[H2])>(delta/*_close_sell*/*Point)&&(booster)) //+------------------------------------------------------------------+ { bool modif5= OrderClose(OrderTicket(),OrderLots(),OrderClosePrice(),Slippage,Red); } if(TrailingStop>0) { if((OrderOpenPrice()-Ask)>(MyPoint*TrailingStop)) { if((OrderStopLoss()>(Ask+MyPoint*TrailingStop)) || (OrderStopLoss()==0)) { bool modif6=OrderModify(OrderTicket(),OrderOpenPrice(),Ask+MyPoint*TrailingStop,OrderTakeProfit(),0,Red); return(0); } } } } } } return(0); } int TotalOrdersCount() { int result=0; for(int i=0;i<OrdersTotal();i++) { if(OrderSelect(i,SELECT_BY_POS ,MODE_TRADES)) if (OrderMagicNumber()==MagicNumber) result++; } return (result); } //+------------------------------------------------------------------+ //Calculates Lot Size based on balance and factor //+------------------------------------------------------------------+ double NR(double thelot) { double maxlots=MarketInfo(Symbol(),MODE_MAXLOT), minilot=MarketInfo(Symbol(),MODE_MINLOT), lstep=MarketInfo(Symbol(),MODE_LOTSTEP); double lots=lstep*NormalizeDouble(thelot/lstep,0); lots=MathMax(MathMin(maxlots,lots),minilot); return (lots); } //+------------------------------------------------------------------+ double Lot_Volume() { lot=AccountBalance() * 0.01 /LotFactor ; return(lot); } //+------------------------------------------------------------------+ //|
    lefeuvr3 a joint une image
    qpg-renko-version-1-11054