Ten Stochs Wave Filter EA v1[1].1

Author: Copyright � 2008, TradingSytemForex
Orders Execution
Checks for the total of open ordersIt Closes Orders by itself It automatically opens orders when conditions are reachedIt can change open orders parameters, due to possible stepping strategy
Indicators Used
Stochastic oscillator
0 Views
0 Downloads
0 Favorites

Profitability Reports

AUD/USD Oct 2024 - Jan 2025
194.00 %
Total Trades 44
Won Trades 0
Lost trades 0
Win Rate 0.00 %
Expected payoff 7.42
Gross Profit 671.98
Gross Loss -345.60
Total Net Profit 326.38
-100%
-50%
0%
50%
100%
GBP/USD Oct 2024 - Jan 2025
163.00 %
Total Trades 92
Won Trades 21
Lost trades 71
Win Rate 0.23 %
Expected payoff 2.63
Gross Profit 625.53
Gross Loss -383.40
Total Net Profit 242.13
-100%
-50%
0%
50%
100%
Ten Stochs Wave Filter EA v1[1].1
//+------------------------------------------------------------------+
//|                                           Ten Stochs Wave EA.mq4 |
//|                              Copyright © 2008, TradingSytemForex |
//|                                http://www.tradingsystemforex.com |
//+------------------------------------------------------------------+

#property copyright "Copyright © 2008, TradingSytemForex"
#property link "http://www.tradingsystemforex.com"

#define OrSt "Ten Stochs Wave EA"

extern string STO="---------------- Stochs";
extern double First_Stoch_KP=1;
extern double Stoch_Slowing=2;
extern double Stoch_HLevel=80;
extern double Stoch_LLevel=20;
extern string LM="---------------- Lot Management";
extern double Lots=0.1;
extern bool MM=true; //money management
extern double Risk=2; //risk in percentage
extern string TSTB="---------------- TP SL TS BE";
bool RealSL_Enabled=false;
int RealSL=5; //stop loss under 15 pîps
bool RealTP_Enabled=false;
int RealTP=10; //take profit under 10 pîps
extern int SL=180; //stop loss
extern int TP=1000; //take profit
extern int TS=0; //trailing stop
extern int TS_Step=1; //trailing stop step
extern int BE=0; //breakeven
extern string EXT="---------------- Extras";
extern bool Reverse=false;
bool Add_Positions=false; //positions cumulated
int MaxOrders=100; //maximum number of orders
extern int Magic=0;

int Slip=3;static int TL=0;double MML=0;

// expert start function
int start(){int j=0,limit=1;double BV=0,SV=0;BV=0;SV=0;double STOM1,STOM2,STOM3,STOM4,STOM5,STOM6,STOM7,STOM8,STOM9,STOM10,STOM1b,STOM2b,STOM3b,STOM4b,STOM5b,STOM6b,STOM7b,STOM8b,STOM9b,STOM10b,STO1b,STO1;
  if(CntO(OP_BUY,Magic)>0) TL=1;if(CntO(OP_SELL,Magic)>0) TL=-1;for(int i=1;i<=limit;i++){
  
  STOM1=iStochastic(NULL,0,First_Stoch_KP,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i);STOM1b=iStochastic(NULL,0,First_Stoch_KP,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i+1);
  STOM2=iStochastic(NULL,0,First_Stoch_KP+1,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i);STOM2b=iStochastic(NULL,0,First_Stoch_KP+1,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i+1);
  STOM3=iStochastic(NULL,0,First_Stoch_KP+2,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i);STOM3b=iStochastic(NULL,0,First_Stoch_KP+2,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i+1);
  STOM4=iStochastic(NULL,0,First_Stoch_KP+3,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i);STOM4b=iStochastic(NULL,0,First_Stoch_KP+3,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i+1);
  STOM5=iStochastic(NULL,0,First_Stoch_KP+4,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i);STOM5b=iStochastic(NULL,0,First_Stoch_KP+4,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i+1);
  STOM6=iStochastic(NULL,0,First_Stoch_KP+5,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i);STOM6b=iStochastic(NULL,0,First_Stoch_KP+5,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i+1);
  STOM7=iStochastic(NULL,0,First_Stoch_KP+6,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i);STOM7b=iStochastic(NULL,0,First_Stoch_KP+6,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i+1);
  STOM8=iStochastic(NULL,0,First_Stoch_KP+7,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i);STOM8b=iStochastic(NULL,0,First_Stoch_KP+7,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i+1);
  STOM9=iStochastic(NULL,0,First_Stoch_KP+8,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i);STOM9b=iStochastic(NULL,0,First_Stoch_KP+8,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i+1);
  STOM10=iStochastic(NULL,0,First_Stoch_KP+9,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i);STOM10b=iStochastic(NULL,0,First_Stoch_KP+9,Stoch_Slowing,3,MODE_SMA,0,MODE_MAIN,i+1);
  
  STO1b=(STOM1b+STOM2b+STOM3b+STOM4b+STOM5b+STOM6b+STOM7b+STOM8b+STOM9b+STOM10b);
  STO1=(STOM1+STOM2+STOM3+STOM4+STOM5+STOM6+STOM7+STOM8+STOM9+STOM10);

  if(STO1<STO1b&&STO1>Stoch_HLevel){if(Reverse) BV=1; else SV=1; break;}
  if(STO1>STO1b&&STO1<Stoch_LLevel){if(Reverse) SV=1; else BV=1; break;}}

// expert money management
if(MM){if(Risk<0.1 || Risk>100) {Comment("Invalid Risk Value."); return(0);}
   else {MML=MathFloor((AccountFreeMargin() *AccountLeverage()*Risk*Point*100)/(Ask*MarketInfo(Symbol(),MODE_LOTSIZE)*MarketInfo(Symbol(),MODE_MINLOT )))*MarketInfo(Symbol(),MODE_MINLOT );}}
if(MM==false){MML=Lots;}

// expert init positions
int cnt=0,OP=0,OS=0,OB=0,CS=0,CB=0;OP=0;for(cnt=0; cnt<OrdersTotal();cnt++) {OrderSelect(cnt, SELECT_BY_POS, MODE_TRADES);
if((OrderType()==OP_SELL || OrderType()==OP_BUY) && OrderSymbol()==Symbol() && ((OrderMagicNumber()==Magic) || Magic==0)) OP=OP+1;}
if(OP>=1){OS=0; OB=0;}OB=0;OS=0;CB=0;CS=0;

// expert conditions to open position
if(SV>0){OS=1;OB=0;}if(BV>0){OB=1;OS=0;}

// expert conditions to close position
if((SV>0) || (RealSL_Enabled && (OrderOpenPrice()-Bid)/Point>=RealSL)||(RealTP_Enabled && (Ask-OrderOpenPrice())/Point>=RealTP)){CB=1;}
if((BV>0) || (RealSL_Enabled && (Ask-OrderOpenPrice())/Point>=RealSL)||(RealTP_Enabled && (OrderOpenPrice()-Bid)/Point>=RealTP)){CS=1;}
for(cnt=0;cnt<OrdersTotal();cnt++){OrderSelect(cnt,SELECT_BY_POS,MODE_TRADES);
	if(OrderType()==OP_BUY && OrderSymbol()==Symbol() && ((OrderMagicNumber()==Magic) || Magic==0)){if (CB==1){OrderClose(OrderTicket(),OrderLots(),Bid,Slip,Red); return(0);}}
	if(OrderType()==OP_SELL && OrderSymbol()==Symbol() && ((OrderMagicNumber()==Magic) || Magic==0)){
	if(CS==1){OrderClose(OrderTicket(),OrderLots(),Ask,Slip,Red);return(0);}}}double SLI=0,TPI=0;int TK=0;

// expert open position value
if((AddP() && Add_Positions && OP<=MaxOrders) || (OP==0 && !Add_Positions)) {
	if(OS==1){if (TP==0) TPI=0; else TPI=Bid-TP*Point;if (SL==0) SLI=0; else SLI=Bid+SL*Point;TK=OrderSend(Symbol(),OP_SELL,MML,Bid,Slip,SLI,TPI,OrSt,Magic,0,Red);OS=0;return(0);}	
	if(OB==1){if(TP==0) TPI=0; else TPI=Ask+TP*Point;if(SL==0) SLI=0; else SLI=Ask-SL*Point;TK=OrderSend(Symbol(),OP_BUY,MML,Ask,Slip,SLI,TPI,OrSt,Magic,0,Lime);OB=0; return(0);}}
for(j=0;j<OrdersTotal();j++){if(OrderSelect(j,SELECT_BY_POS, MODE_TRADES)){if (OrderSymbol()==Symbol() && ((OrderMagicNumber()==Magic) || Magic==0)) {TrP();}}}return(0);}

// expert number of orders
int CntO(int Type,int Magic){int _CntO;_CntO=0;
for(int j=0;j<OrdersTotal();j++){OrderSelect(j, SELECT_BY_POS, MODE_TRADES);if(OrderSymbol()==Symbol()) {if((OrderType()==Type && (OrderMagicNumber()==Magic) || Magic==0)) _CntO++;}}return(_CntO);}

// expert trailing stop
void TrP(){double pb,pa,pp;pp=MarketInfo(OrderSymbol(),MODE_POINT);if (OrderType()==OP_BUY){pb=MarketInfo(OrderSymbol(),MODE_BID);

//expert breakeven
    if(BE>0){if((pb-OrderOpenPrice())>BE*pp){if((OrderStopLoss()-OrderOpenPrice())<0){ModSL(OrderOpenPrice()+0*pp);}}}
    if(TS>0){if((pb-OrderOpenPrice())>TS*pp){if(OrderStopLoss()<pb-(TS+TS_Step-1)*pp){ModSL(pb-TS*pp);return;}}}}
  if(OrderType()==OP_SELL){pa=MarketInfo(OrderSymbol(),MODE_ASK);if(BE>0){if((OrderOpenPrice()-pa)>BE*pp){if((OrderOpenPrice()-OrderStopLoss())<0){ModSL(OrderOpenPrice()-0*pp);}}}
  if (TS>0){if (OrderOpenPrice()-pa>TS*pp){if (OrderStopLoss()>pa+(TS+TS_Step-1)*pp || OrderStopLoss()==0){ModSL(pa+TS*pp);return;}}}}}

//expert stoploss
void ModSL(double ldSL){bool fm;fm=OrderModify(OrderTicket(),OrderOpenPrice(),ldSL,OrderTakeProfit(),0,CLR_NONE);}

//expert add positions function
bool AddP(){int _num=0; int _ot=0;
for (int j=0;j<OrdersTotal();j++){if(OrderSelect(j,SELECT_BY_POS)==true && OrderSymbol()==Symbol() && OrderType()<3 && ((OrderMagicNumber()==Magic) || Magic==0)) {	
	 _num++;if(OrderOpenTime()>_ot) _ot=OrderOpenTime();}}
if(_num==0) return(true);if(_num>0 && ((Time[0]-_ot))>0) return(true);else return(false);}

Comments

Markdown supported. Formatting help

Markdown Formatting Guide

Element Markdown Syntax
Heading # H1
## H2
### H3
Bold **bold text**
Italic *italicized text*
Link [title](https://www.example.com)
Image ![alt text](image.jpg)
Code `code`
Code Block ```
code block
```
Quote > blockquote
Unordered List - Item 1
- Item 2
Ordered List 1. First item
2. Second item
Horizontal Rule ---