Summary: 黄金宏观矩阵EA是一款专为XAUUSD设计的MQL4智能交易系统。结合高周期宏观趋势过滤与低周期突破确认,适配黄金高波动特性,适合M30周期稳定运行。
黄金宏观矩阵EA专为黄金(XAUUSD)设计,聚焦于宏观趋势方向与突破精确度的结合。受专业级EA结构启发,本EA首先使用EMA趋势过滤器在高周期(H1)确定方向偏好,然后在执行周期(M30)等待波动率确认后再入场。EA通过要求多个时间框架的方向对齐,避免了黄金交易中的常见陷阱——假突破和突然反转。基于ATR的固定止损确保每笔交易的风险可控,而自适应追踪止损在趋势发展中锁定利润。EA包含每日净值保护、点差控制和周五平仓机制,全方位保障资金安全。
推荐加载周期: M30
策略核心逻辑:
1. 宏观趋势过滤(H1):EMA(50)与EMA(200)确定主趋势方向。
2. 波动率确认(M30):价格必须收盘突破近期20周期高低点。
3. 入场触发:宏观趋势方向与波动突破方向一致时开仓。
4. 风险管理:ATR动态止损(1.5倍ATR),止盈3倍ATR,盈利达到1倍ATR后启动追踪止损。
```mql4
//+------------------------------------------------------------------+
//| GoldMacroMatrixEA.mq4 |
//+------------------------------------------------------------------+
#property copyright ""
#property link ""
#property version "1.00"
#property strict
//--- 输入参数及注释
input double LotSize = 0.01; // 固定交易手数(黄金0.01手)
input int MacroTrendFast = 50; // 宏观趋势快EMA(H1)
input int MacroTrendSlow = 200; // 宏观趋势慢EMA(H1)
input int BreakoutPeriod = 20; // 突破检测回溯K线数
input int ATRPeriod = 14; // ATR周期(止损计算)
input double ATRStopMultiplier = 1.5; // 止损倍数(ATR倍数)
input double ATRTakeMultiplier = 3.0; // 止盈倍数(ATR倍数)
input double TrailingStartATR = 1.0; // 追踪止损启动(盈利达到x倍ATR)
input double TrailingStepATR = 0.5; // 追踪步长(ATR倍数)
input int MagicNumber = 202421; // EA魔术号
input int MaxSpread = 35; // 最大允许点差(黄金单位:点)
input double DailyLossLimit = 5.0; // 每日亏损限额(账户余额百分比)
input bool UseFridayClose = true; // 周五21:00 GMT前平仓
//--- 全局变量
double dailyStartBalance = 0;
datetime lastBarTime = 0;
bool fridayCloseExecuted = false;
double avgATR = 0;
//+------------------------------------------------------------------+
//| EA初始化函数 |
//+------------------------------------------------------------------+
int OnInit()
{
dailyStartBalance = AccountBalance();
lastBarTime = 0;
fridayCloseExecuted = false;
avgATR = iATR(Symbol(), PERIOD_M30, ATRPeriod, 1);
if(avgATR <= 0) avgATR = 200 * Point;
return(INIT_SUCCEEDED);
}
//+------------------------------------------------------------------+
//| EA退出函数 |
//+------------------------------------------------------------------+
void OnDeinit(const int reason)
{
Comment("");
}
//+------------------------------------------------------------------+
//| 获取高周期宏观趋势方向(H1) |
//+------------------------------------------------------------------+
int GetMacroTrend()
{
double closeH1 = iClose(Symbol(), PERIOD_H1, 1);
double emaFast = iMA(Symbol(), PERIOD_H1, MacroTrendFast, 0, MODE_EMA, PRICE_CLOSE, 1);
double emaSlow = iMA(Symbol(), PERIOD_H1, MacroTrendSlow, 0, MODE_EMA, PRICE_CLOSE, 1);
// 看涨:价格位于双EMA上方,且快EMA高于慢EMA
bool bullish = (closeH1 > emaFast && closeH1 > emaSlow && emaFast > emaSlow);
// 看跌:价格位于双EMA下方,且快EMA低于慢EMA
bool bearish = (closeH1 < emaFast && closeH1 < emaSlow && emaFast < emaSlow);
if(bullish) return 1;
if(bearish) return -1;
return 0;
}
//+------------------------------------------------------------------+
//| 检查执行周期的波动突破(M30) |
//+------------------------------------------------------------------+
bool CheckBreakout(int direction, double &entryPrice, double &sl, double &tp, double atr)
{
if(direction == 0) return false;
// 计算回溯周期内的最高点和最低点
int highIdx = iHighest(Symbol(), PERIOD_M30, MODE_HIGH, BreakoutPeriod, 2);
int lowIdx = iLowest(Symbol(), PERIOD_M30, MODE_LOW, BreakoutPeriod, 2);
double breakoutHigh = iHigh(Symbol(), PERIOD_M30, highIdx);
double breakoutLow = iLow(Symbol(), PERIOD_M30, lowIdx);
double close1 = iClose(Symbol(), PERIOD_M30, 1);
double open1 = iOpen(Symbol(), PERIOD_M30, 1);
if(direction == 1) // 向上突破做多
{
if(close1 > breakoutHigh && close1 > open1)
{
entryPrice = Ask;
sl = entryPrice - (atr * ATRStopMultiplier);
tp = entryPrice + (atr * ATRTakeMultiplier);
return true;
}
}
else if(direction == -1) // 向下突破做空
{
if(close1 < breakoutLow && close1 < open1)
{
entryPrice = Bid;
sl = entryPrice + (atr * ATRStopMultiplier);
tp = entryPrice - (atr * ATRTakeMultiplier);
return true;
}
}
return false;
}
//+------------------------------------------------------------------+
//| 管理持仓的追踪止损 |
//+------------------------------------------------------------------+
void ManageTrailingStop(double atr)
{
for(int i = OrdersTotal()-1; i >= 0; i--)
{
if(OrderSelect(i, SELECT_BY_POS, MODE_TRADES))
{
if(OrderSymbol() == Symbol() && OrderMagicNumber() == MagicNumber)
{
double activate = atr * TrailingStartATR;
double step = atr * TrailingStepATR;
double newSL = 0;
if(OrderType() == OP_BUY)
{
double profit = Bid - OrderOpenPrice();
if(profit >= activate)
{
newSL = Bid - step;
if(newSL > OrderStopLoss())
OrderModify(OrderTicket(), OrderOpenPrice(), newSL, OrderTakeProfit(), 0, clrNONE);
}
}
else if(OrderType() == OP_SELL)
{
double profit = OrderOpenPrice() - Ask;
if(profit >= activate)
{
newSL = Ask + step;
if(newSL < OrderStopLoss() || OrderStopLoss() == 0)
OrderModify(OrderTicket(), OrderOpenPrice(), newSL, OrderTakeProfit(), 0, clrNONE);
}
}
break;
}
}
}
}
//+------------------------------------------------------------------+
//| EA主循环函数(每Tick执行) |
//+------------------------------------------------------------------+
void OnTick()
{
// 每日净值保护
double currentEquity = AccountEquity();
double lossPercent = (dailyStartBalance - currentEquity) / dailyStartBalance * 100;
if(lossPercent >= DailyLossLimit)
{
Comment("已达每日亏损上限,停止开新仓");
return;
}
// 周五收盘前平仓(规避周末跳空)
if(UseFridayClose && !fridayCloseExecuted)
{
datetime currentTime = TimeCurrent();
if(TimeDayOfWeek(currentTime) == 5 && TimeHour(currentTime) >= 21)
{
CloseAllOrders();
fridayCloseExecuted = true;
return;
}
if(TimeDayOfWeek(currentTime) != 5)
fridayCloseExecuted = false;
}
// 点差过滤
if(MarketInfo(Symbol(), MODE_SPREAD) > MaxSpread)
{
Comment("当前点差过大:", MarketInfo(Symbol(), MODE_SPREAD));
return;
}
// 仅在新K线开始时检测入场(M30)
if(Time[0] == lastBarTime)
return;
lastBarTime = Time[0];
// 管理现有持仓
int posCount = CountPositions();
if(posCount > 0)
{
double atr = iATR(Symbol(), PERIOD_M30, ATRPeriod, 1);
if(atr > 0) ManageTrailingStop(atr);
return;
}
// 获取ATR并更新平均值
double atr = iATR(Symbol(), PERIOD_M30, ATRPeriod, 1);
if(atr > 0) avgATR = (avgATR * 0.95) + (atr * 0.05);
// 波动率保护:ATR过高时跳过(规避新闻行情)
if(atr > avgATR * 2.0 && avgATR > 0)
{
Comment("当前波动率过高,ATR: ", atr);
return;
}
// 获取宏观趋势方向
int macroTrend = GetMacroTrend();
if(macroTrend == 0)
{
Comment("H1宏观趋势方向不明确");
return;
}
// 检查突破入场
double entryPrice = 0, sl = 0, tp = 0;
if(CheckBreakout(macroTrend, entryPrice, sl, tp, atr))
{
int cmd = (macroTrend == 1) ? OP_BUY : OP_SELL;
int ticket = OrderSend(Symbol(), cmd, LotSize, entryPrice, 5, sl, tp, "Gold Macro Matrix", MagicNumber, 0, clrNONE);
if(ticket < 0)
Print("开仓失败,错误码:", GetLastError());
else
Print("突破开仓成功,方向:", cmd==OP_BUY?"买入":"卖出");
}
}
//+------------------------------------------------------------------+
//| 统计当前魔术号的持仓数量 |
//+------------------------------------------------------------------+
int CountPositions()
{
int count = 0;
for(int i = OrdersTotal()-1; i >= 0; i--)
{
if(OrderSelect(i, SELECT_BY_POS, MODE_TRADES))
{
if(OrderSymbol() == Symbol() && OrderMagicNumber() == MagicNumber)
count++;
}
}
return count;
}
//+------------------------------------------------------------------+
//| 平仓当前品种下所有属于该EA的订单 |
//+------------------------------------------------------------------+
void CloseAllOrders()
{
for(int i = OrdersTotal()-1; i >= 0; i--)
{
if(OrderSelect(i, SELECT_BY_POS, MODE_TRADES))
{
if(OrderSymbol() == Symbol() && OrderMagicNumber() == MagicNumber)
{
if(OrderType() == OP_BUY)
OrderClose(OrderTicket(), OrderLots(), Bid, 5, clrNONE);
else if(OrderType() == OP_SELL)
OrderClose(OrderTicket(), OrderLots(), Ask, 5, clrNONE);
}
}
}
}
//+------------------------------------------------------------------+
```
参考来源: 原创MQL4代码,策略架构参考了2025年最新黄金EA的宏观趋势结构。
免责声明: 黄金交易因高波动性具有重大风险。本EA按“原样”提供,不保证盈利。实盘部署前请在模拟账户充分测试。历史表现不代表未来结果。
```