Job finished
Execution time 4 hours
Feedback from customer
very fast and good to work with
Feedback from employee
Nice working with you, No stress :)
Specification
heres the code (#include <Trade\Trade.mqh> // Include the CTrade class
CTrade trade; // Declare an instance of CTrade
// Symbols to trade
string SYMBOLS[] = {"XAUUSDm", "US30m", "GBPUSDm", "USTECm", "EURUSDm"};
// Parameters for 15-minute scalping and integrated strategy
double MIN_LOT_SIZE = 0.01; // Minimum lot size for most brokers
double TRAILING_STOP_LOSS = 5; // Trailing stop loss (points)
double RISK_PERCENTAGE = 0.5; // Risk per trade in percentage (smaller for scalping)
int MA_PERIOD_M5 = 10; // Moving average period for M15
int MA_PERIOD_D1 = 100; // Moving average period for D1 (longer-term trend)
int ATR_PERIOD = 5; // ATR period for volatility filter
double MIN_ATR_THRESHOLD = 0.0002; // Minimum ATR value for high volatility (tighter for scalping)
int trade_count = 0; // Counter to track the number of trades
datetime last_trade_time = 0; // Track last trade time for session filtering
// Variables to store the last detected pattern and trend
struct TradeSetup {
string trend;
string pattern;
};
TradeSetup last_setup[ArraySize(SYMBOLS)]; // Array to store last setup for each symbol
// Function declarations
double calculate_lot_size(double risk_percentage, double stop_loss_distance);
void log_trade(string symbol, double entry_price, double exit_price, string type);
double adjust_stop_loss(double atr_value);
int execute_trade(string symbol, string type, double lot_size);
// Function to calculate lot size based on risk percentage and stop loss distance
double calculate_lot_size(double risk_percentage, double stop_loss_distance) {
double account_balance = AccountInfoDouble(ACCOUNT_BALANCE);
double risk_amount = account_balance * (3 / 100);
double lot_size = risk_amount / stop_loss_distance;
return NormalizeDouble(lot_size, 2); // Adjust to the broker's lot size precision
}
// Function to adjust stop loss based on ATR value
double adjust_stop_loss(double atr_value) {
return atr_value * 1.5; // Adjust this multiplier as needed
}
// Function to log trade details
void log_trade( double entry_price, double exit_price, string type) {
Print("Trade executed: ", symbol, " Entry: ", entry_price, " Exit: ", exit_price, " Type: ", type);
}
void IntegratedStrategy(double price, double support, double resistance,
double demandZone, double supplyZone,
bool isBullishPattern, bool isBearishPattern,
bool isBreakout, bool isBreakdown,
bool isFalseBreakout, bool isReversal,
bool isUptrend, bool isDowntrend,
double volume, double rsi)
//--- Pure Price Action: Reversal at Key Levels
if (isReversal) {
// Buying Reversal at Support or Demand Zone
if (SymbolInfoDouble(symbol, SYMBOL_BID) <= support || SymbolInfoDouble(symbol, SYMBOL_BID) <= demandZone) {
// Confirmations: Bullish candlestick pattern, volume increase, RSI not overbought
if (bullishSignal == "bullish_engulfing" && volume > 0 && rsi < 70) {
request.action = TRADE_ACTION_DEAL;
request.symbol = symbol;
request.volume = LOT_SIZE; // You can adjust lot size here
request.type = ORDER_TYPE_BUY;
request.price = SymbolInfoDouble(symbol, SYMBOL_ASK);
request.sl = 3; // Define stop loss (modify as needed)
request.tp = 15; // Define take profit (modify as needed)
request.deviation = 3;
request.comment = "Buy Reversal at Support/Demand";
if (!execute_trade(request, result)) {
Print("Failed to place Buy order at Supoort/Demand.");
}
}
// Selling Reversal at Resistance or Supply Zone
if (SymbolInfoDouble(symbol, SYMBOL_BID) >= resistance || SymbolInfoDouble(symbol, SYMBOL_BID) >= supplyZone) {
// Confirmations: Bearish candlestick pattern, volume increase, RSI overbought
if (bearishSignal == "bearish_engulfing" && volume > 0 && rsi > 70) {
request.action = TRADE_ACTION_DEAL;
request.symbol = symbol;
request.volume = LOT_SIZE; // You can adjust lot size here
request.type = ORDER_TYPE_SELL;
request.price = SymbolInfoDouble(symbol, SYMBOL_BID);
request.sl = 3; // Define stop loss (modify as needed)
request.tp = 15; // Define take profit (modify as needed)
request.deviation = 3;
request.comment = "Sell Reversal at Resistance/Supply";
if (!execute_trade(request, result)) {
Print("Failed to place Sell order at Resistance/Supply.");
}
}
}
//--- Price Action: Breakout or Breakdown
if (isBreakout && SymbolInfoDouble(symbol, SYMBOL_BID) > resistance) {
// Buy on confirmed breakout with strong volume
if (volume > 0 && rsi < 70) {
request.action = TRADE_ACTION_DEAL;
request.symbol = symbol;
request.volume = LOT_SIZE; // You can adjust lot size here
request.type = ORDER_TYPE_BUY;
request.price = SymbolInfoDouble(symbol, SYMBOL_ASK);
request.deviation = 3;
request.comment = "Buy Breakout";
if (!execute_trade(request, result)) {
Print("Failed to place Buy order at Breakout.");
}
}
if (isBreakdown && SymbolInfoDouble(symbol, SYMBOL_BID) < support) {
// Sell on confirmed breakdown with strong volume
if (volume > 0 && rsi > 70) {
request.action = TRADE_ACTION_DEAL;
request.symbol = symbol;
request.volume = LOT_SIZE; // You can adjust lot size here
request.type = ORDER_TYPE_SELL;
request.price = SymbolInfoDouble(symbol, SYMBOL_BID);
request.deviation = 3;
request.comment = "Sell Breakdown";
if (!execute_trade(request, result)) {
Print("Failed to place Sell order at Breakdown.");
}
}
//--- False Breakout: Sell After False Breakout at Resistance or Buy After False Breakout at Support
if (isFalseBreakout) {
if (SymbolInfoDouble(symbol, SYMBOL_BID) > resistance && bearishSignal == "bearish_engulfing" && volume > 0 && rsi > 70) {
request.action = TRADE_ACTION_DEAL;
request.symbol = symbol;
request.volume = LOT_SIZE; // You can adjust lot size here
request.type = ORDER_TYPE_SELL;
request.price = SymbolInfoDouble(symbol, SYMBOL_BID);
request.deviation = 3;
request.comment = "Sell False Breakout at Resistance";
if (!execute_trade(request, result)) {
Print("Failed to place Sell order at Resistance.");
}
if (SymbolInfoDouble(symbol, SYMBOL_BID) < support && bullishSignal == "bullish_engulfing" && volume > 0 && rsi < 30) {
request.action = TRADE_ACTION_DEAL;
request.symbol = symbol;
request.volume = LOT_SIZE; // You can adjust lot size here
request.type = ORDER_TYPE_BUY;
request.price = SymbolInfoDouble(symbol, SYMBOL_ASK);
request.deviation = 3;
request.comment = "Buy False Breakout at Support";
if (!execute_trade(request, result)) {
Print("Failed to place Buy order at Support.");
}
}
//--- Trend Continuation: Buy in Uptrend at Demand Zone or Support, Sell in Downtrend at Supply Zone or Resistance
if (isUptrend) {
if (SymbolInfoDouble(symbol, SYMBOL_BID) <= demandZone || SymbolInfoDouble(symbol, SYMBOL_BID) <= support) {
if (bullishSignal == "bullish_engulfing" && volume > 0 && rsi < 70) {
request.action = TRADE_ACTION_DEAL;
request.symbol = symbol;
request.volume = LOT_SIZE; // You can adjust lot size here
request.type = ORDER_TYPE_BUY;
request.price = SymbolInfoDouble(symbol, SYMBOL_ASK);
request.deviation = 3;
request.comment = "Buy in Uptrend at Demand/Support";
if (!execute_trade(request, result)) {
Print("Failed to place Buy order at Demand/Support.");
}
}
}
if (isDowntrend) {
if (SymbolInfoDouble(symbol, SYMBOL_BID) >= supplyZone || SymbolInfoDouble(symbol, SYMBOL_BID) >= resistance) {
if (bearishSignal == "bearish_engulfing" && volume > 0 && rsi > 70) {
request.action = TRADE_ACTION_DEAL;
request.symbol = symbol;
request.volume = LOT_SIZE; // You can adjust lot size here
request.type = ORDER_TYPE_SELL;
request.price = SymbolInfoDouble(symbol, SYMBOL_BID);
request.deviation = 3;
request.comment = "Sell in Downtrend at Supply/Resistance";
if (!execute_trade(request, result)) {
Print("Failed to place Sell order at Supply/Resistance.");
}
}
}
}
}
//--- Function to execute trade with error checking
bool execute_trade(MqlTradeRequest &request, MqlTradeResult &result) {
if (!OrderSend(request, result)) {
Print("OrderSend failed with error ", GetLastError());
return false;
}
if (result.retcode != TRADE_RETCODE_DONE) {
Print("OrderSend failed, return code: ", result.retcode);
return false;
}
Print("Order placed successfully with ticket ", result.order);
return true;
}
//--- Event handler
void OnTick() {
strategy_execution(); // Execute strategy on every tick
}
// Trailing stop-loss function
void apply_trailing_stop(int ticket, double trail_distance) {
double current_price = SymbolInfoDouble(Symbol(), SYMBOL_BID);
double stop_loss = PositionGetDouble(POSITION_SL);
if (PositionSelectByTicket(ticket) && current_price - trail_distance > stop_loss) {
MqlTradeRequest request;
MqlTradeResult result;
ZeroMemory(request);
request.action = TRADE_ACTION_SLTP;
request.position = ticket;
request.sl = current_price - trail_distance;
if (!OrderSend(request, result)) {
Print("Trailing stop modification failed with error ", GetLastError());
} else if (result.retcode != TRADE_RETCODE_DONE) {
Print("Trailing stop modification failed, return code: ", result.retcode);
} else {
Print("Trailing stop updated successfully for ticket ", ticket);
}
}
}
// Moving average calculation for trend detection
double calculate_moving_average(string symbol, int period, int timeframe)
{
double ma[];
if (CopyBuffer(iMA(symbol, PERIOD_M15, period, 0, MODE_SMA, PRICE_CLOSE), 0, 0, 1, ma) > 0)
return ma[0];
return 0;
}
// ATR calculation for volatility filter
double calculate_atr(string symbol, int timeframe, int period)
{
double atr[];
if (CopyBuffer(iATR(symbol, PERIOD_M15, period), 0, 0, 1, atr) > 0)
return atr[0];
return 0;
}
// Detect trend based on 15-minute and daily charts
string detect_trend(string symbol)
{
// Calculate moving averages
double ma_m15 = calculate_moving_average(symbol, MA_PERIOD_M15, PERIOD_M15);
double ma_d1 = calculate_moving_average(symbol, MA_PERIOD_D1, PERIOD_D1);
// Retrieve the current price
double price = iClose(symbol, PERIOD_M15, 0); // Using M15 period
// Determine trend based on the price and moving averages
if (price > ma_m15 && price > ma_d1)
return "uptrend";
else if (price < ma_m15 && price < ma_d1)
return "downtrend";
return ""; // No clear trend
}
// Calculate ATR and stop loss distance
double atr_value = calculate_atr(symbol, PERIOD_M15, atr_period);
double stop_loss_distance = adjust_stop_loss(atr_value);
double lot_size = calculate_lot_size(risk_percentage, stop_loss_distance);
// ATR Volatility filter for M15
bool is_volatile(string symbol)
{
double atr_value = calculate_atr(symbol, PERIOD_M15, ATR_PERIOD);
return (atr_value >= MIN_ATR_THRESHOLD);
}
// Candlestick pattern detection (e.g., engulfing pattern)
string detect_bullish_engulfing(double &open[], double &close[])
{
if (close[1] < open[1] && close[0] > open[0] && close[0] > open[1] && open[0] < close[1])
return "bullish_engulfing";
return "";
}
string detect_bearish_engulfing(double &open[], double &close[])
{
if (close[1] > open[1] && close[0] < open[0] && close[0] < open[1] && open[0] > close[1])
return "bearish_engulfing";
return "";
}
// Fetch data function
bool get_data(string symbol, int timeframe, int bars, double &high[], double &low[], double &close[], double &open[])
{
MqlRates rates[]; // Declare an array of MqlRates structures
// Use CopyRates to fetch the data
int copied = CopyRates(symbol, PERIOD_M15, 0, bars, rates);
// Check if rates were successfully copied
if (copied <= 0)
{
Print("Failed to copy rates for ", symbol, " on timeframe ", timeframe);
return false;
}
// Resize the arrays based on the number of bars copied
ArrayResize(high, copied);
ArrayResize(low, copied);
ArrayResize(close, copied);
ArrayResize(open, copied);
// Ensure the array is accessed from newest to oldest
ArraySetAsSeries(rates, true);
// Copy data into the respective arrays
for (int i = 0; i < copied; i++)
{
high[i] = rates[i].high;
low[i] = rates[i].low;
close[i] = rates[i].close;
open[i] = rates[i].open;
}
// Return true if data was successfully copied
return true;
}
int execute_trade(string symbol, string type, double lot_size) {
MqlTradeRequest request;
MqlTradeResult result;
ZeroMemory(request);
request.action = TRADE_ACTION_DEAL;
request.symbol = symbol;
request.volume = lot_size;
request.type = (type == "buy") ? ORDER_TYPE_BUY : ORDER_TYPE_SELL;
request.price = (type == "buy") ? SymbolInfoDouble(symbol, SYMBOL_ASK) : SymbolInfoDouble(symbol, SYMBOL_BID);
request.deviation = 3; // Adjust deviation as needed
request.comment = type + " trade executed";
if(OrderSend(request, result)) {
trade_count++; // Increment trade count on successful trade
return result.handle; // Return the ticket number
} else {
Print("Error executing trade: ", GetLastError());
return -1; // Return -1 on failure
}
}
// Function to check if the current time is within trading session hours
bool is_trading_session() {
datetime current_time = TimeCurrent();
int hour = TimeHour(current_time);
// Example: London session (9:00 - 17:00) and New York session (15:00 - 22:00)
return (hour >= 9 && hour < 17) || (hour >= 15 && hour < 22);
}
// Main trading loop
void OnTick() {
if(trade_count >= 4) // Stop execution once trade limit is reached
{
Print("Trading halted after opening 4 trades.");
return;
}
for(int i = 0; i < ArraySize(SYMBOLS); i++) {
string symbol = SYMBOLS[i];
double high[1000], low[1000], close[1000], open[1000];
int bars = 1000; // Number of bars to retrieve
// Retrieve data, handling the case where it fails
if (!get_data(symbol, PERIOD_M15, bars, high, low, close, open)) {
Print("Failed to get data for ", symbol);
continue; // Skip to the next symbol if data retrieval fails
}
// Perform trend detection and get candlestick patterns
string trend = detect_trend(symbol);
string bullishSignal = detect_bullish_engulfing(open, close);
string bearishSignal = detect_bearish_engulfing(open, close);
// Check if there is volatility and if we're within the trading session
if (!is_volatile(symbol) || !is_trading_session()) {
Print("Skipping ", symbol, " due to low volatility or out of trading session.");
continue;
}
// Check if the current setup matches the last one
if (trend == "uptrend" && bullishSignal == "bullish_engulfing") {
// If the setup is the same as the last one, skip the trade
if (last_setup[i].trend == trend && last_setup[i].pattern == bullishSignal) {
Print("Skipping trade for ", symbol, " as the setup is the same as the last trade.");
continue;
}
// Execute a buy trade
int ticket = execute_trade(symbol, "buy", MIN_LOT_SIZE);
log_trade(symbol, SymbolInfoDouble(symbol, SYMBOL_ASK), "BUY");
apply_trailing_stop(ticket, TRAILING_STOP_LOSS);
// Update last setup
last_setup[i].trend = trend;
last_setup[i].pattern = bullishSignal;
}
else if (trend == "downtrend" && bearishSignal == "bearish_engulfing") {
// If the setup is the same as the last one, skip the trade
if (last_setup[i].trend == trend && last_setup[i].pattern == bearishSignal) {
Print("Skipping trade for ", symbol, " as the setup is the same as the last trade.");
continue;
}
// Execute a sell trade
int ticket = execute_trade(symbol, "sell", MIN_LOT_SIZE);
log_trade(symbol, SymbolInfoDouble(symbol, SYMBOL_BID), "SELL");
apply_trailing_stop(ticket, TRAILING_STOP_LOSS);
// Update last setup
last_setup[i].trend = trend;
last_setup[i].pattern = bearishSignal;
}
}
)
Responded
1
Rating
Projects
32
63%
Arbitration
1
0%
/
0%
Overdue
1
3%
Working
Published: 5 codes
2
Rating
Projects
5
0%
Arbitration
5
0%
/
40%
Overdue
0
Free
3
Rating
Projects
69
35%
Arbitration
4
25%
/
75%
Overdue
0
Free
4
Rating
Projects
20
35%
Arbitration
3
0%
/
100%
Overdue
0
Free
Published: 1 code
5
Rating
Projects
4
0%
Arbitration
2
0%
/
100%
Overdue
2
50%
Free
6
Rating
Projects
635
33%
Arbitration
41
39%
/
46%
Overdue
11
2%
Loaded
7
Rating
Projects
8
0%
Arbitration
4
0%
/
100%
Overdue
3
38%
Free
8
Rating
Projects
0
0%
Arbitration
3
0%
/
100%
Overdue
0
Working
9
Rating
Projects
14
21%
Arbitration
0
Overdue
0
Working
10
Rating
Projects
146
34%
Arbitration
13
8%
/
62%
Overdue
26
18%
Free
Published: 6 codes
Similar orders
Build MT5 Expert Advisor – LadyKiller EA
1000 - 2000 USD
I am looking for a professional MQL5 developer to build a MetaTrader 5 Expert Advisor from scratch. The EA will be called LadyKiller EA. It must trade only the following instruments: • XAUUSD (Gold) • US30 / Dow Jones Index Requirements: • Strong and reliable buy and sell entry logic • Stop Loss and Take Profit system • Risk management (lot size control) • Maximum trades protection • Drawdown protection • Trend
I need an mql5 EA which can be used with 100$ capital very low drawdown The EA should be high frequency trading special for XAUUSD and btcusd or binary options but also the EA should be testable via strategy tester and demo test for five days is needed NO SELECTION CAN BE DONE WITHOUT TESTING when applying make sure you send the backtester results with demo EA testable via strategy tester
Advanced MT5 Expert Advisor Available
450 - 600 USD
I currently have a powerful and well-structured Expert Advisor available on the MT5 platform. This EA is designed with: ✅ Advanced entry and exit logic ✅ Smart risk management system ✅ Automatic lot sizing option ✅ Break-even and trailing stop protection ✅ Spread and session filters ✅ Drawdown control features ✅ Optimized for XAUUSD and scalping strategies ✅ Suitable for prop firm challenges like FTMO It is built for
Looking for a Powerful MT5 Trading Strategy or Custom EA?
1000 - 1200 USD
Do you need a profitable and well-structured trading strategy converted into a fully automated Expert Advisor on the MT5 platform? I specialize in developing advanced, high-performance EAs with: ✅ Smart entry & exit logic ✅ Risk-based lot size calculation ✅ Break-even & trailing stop system ✅ Spread & session filters ✅ Daily drawdown protection ✅ Prop firm (FTMO-style) risk compliance ✅ Fully automated trade
Hello, I'm looking to find out the cost of creating a mobile trading robot. I've tried to describe it as thoroughly as possible in the following document. I look forward to your response. I'd like to know the costs, delivery time, and how you plan to implement it before making a decision
I am offering a ready-to-use trading system that connects MetaTrader 4 signals with automated trading on Polymarket. The system is already fully developed and working. What the system does: The bot copies signals from a custom MT4 indicator and executes trades automatically on Polymarket prediction markets. How it works: A custom MT4 indicator generates BUY or SELL signals using buffers. When a signal appears, it is
DO NOT RESPOND TO WORK WITH ANY AI. ( I CAN ALSO DO THAT ) NEED REAL DEVELOPING SKILL Hedge Add-On Rules for Existing EA Core Idea SL becomes hypothetical (virtual) for the initial basket and for the hedge basket . When price hits the virtual SL level , EA does not close the losing trades. Instead, EA opens one hedge basket in the opposite direction. Original basket direction Hedge basket direction (opposite) Inputs
Billionflow
30 - 100 USD
Trading specifications: Indicators: Bollinger band ( Period 40, Deviation 1 apply to close) Moving Average (Exponential ) Period 17 applied to high Moving Average ( Exponential ) Period 17 applied to low But Signal enter a buy trade when prices crosses the lower band of the bollinger band up and also crosses the moving average channel of high and low the reverse is true for sell signal
Hello, I am a user of the "BUY STOP SELL STOP V6" trading bot, which is an advanced Grid System bot. The bot is primarily designed for Gold (XAUUSD), but I want it to work on all currency pairs. "The bot contains a privacy/protection code that prevents it from running on other accounts or being modified on any platform, as it has a client account number lock mechanism" --- Bot Description & Current Settings Bot Type
Looking to purchase a Good forex or gold/ BTC trading EA and it's source code. Must be compatible with low budget like less than $500 accounts, Must need no manual intervention and run fully automated. If you are interested in selling me the source code, please share the Read only account access where the EA has already been running on, so i can check past performance and get an idea on how it works or runs. Dont
Project information
Budget
30+ USD
Deadline
from 1 to 2 day(s)