Summary: 比特币K线区间稳定器EA是一款专为比特币设计的MQL4智能交易系统。分析K线区间、检测波动收缩、在区间突破时入场,适合H4周期稳定运行。




比特币K线区间稳定器EA专为比特币独特的价格行为而构建。不同于传统指标,它分析纯K线数据:区间大小、实体与影线比例以及波动收缩形态。EA识别低波动时期(压缩期),并在价格以动量确认突破既定区间时入场。动态止盈基于压缩区间大小,追踪止损在盈利达到1.5倍压缩区间后激活,锁定利润同时控制回撤。

推荐加载周期: H4
策略核心逻辑:
1. 区间检测:计算最近20根K线的平均真实区间。当当前区间 < 0.55倍平均区间时识别为盘整。
2. 压缩形态:要求至少连续3根K线的区间依次递减(波动收缩)。
3. 突破入场:当价格收盘价超出压缩期最高价或最低价至少1.5倍当前ATR时入场。
4. 风险管理:止损设在压缩区间另一侧。止盈为2.5倍压缩区间大小。盈利达到1倍压缩区间时启动追踪止损。

```mql4
//+------------------------------------------------------------------+
//| BTCKRangeStabilizer.mq4 |
//+------------------------------------------------------------------+
#property copyright ""
#property link ""
#property version "1.00"
#property strict

//--- 输入参数及注释
input double LotSize = 0.01; // 固定交易手数(0.01 BTC)
input int RangeLookback = 20; // 平均区间计算回溯周期
input double CompressionRatio = 0.55; // 压缩阈值(当前区间/平均区间)
input int MinCompressionCandles = 3; // 最少连续压缩K线数量要求
input double BreakoutMultiplier = 1.5; // 突破确认倍数(ATR倍数)
input double StopLossMultiplier = 1.2; // 止损倍数(压缩区间的倍数)
input double TakeProfitMultiplier = 2.5; // 止盈倍数(压缩区间的倍数)
input double TrailingActivate = 1.0; // 追踪止损启动(盈利达到x倍压缩区间)
input double TrailingStep = 0.5; // 追踪步长(压缩区间倍数)
input int MagicNumber = 202417; // EA魔术号
input int MaxSpread = 200; // 最大允许点差(比特币单位:点)
input double DailyLossLimit = 6.0; // 每日亏损限额(账户余额百分比)
input bool UseSundayClose = true; // 周日22:00 GMT前平仓

//--- 全局变量
double dailyStartBalance = 0;
datetime lastBarTime = 0;
bool sundayCloseExecuted = false;
double compressionHigh = 0;
double compressionLow = 0;
int compressionCandleCount = 0;
double compressionRange = 0;

//+------------------------------------------------------------------+
//| EA初始化函数 |
//+------------------------------------------------------------------+
int OnInit()
{
dailyStartBalance = AccountBalance();
lastBarTime = 0;
sundayCloseExecuted = false;
compressionHigh = 0;
compressionLow = 0;
compressionCandleCount = 0;
return(INIT_SUCCEEDED);
}

//+------------------------------------------------------------------+
//| EA退出函数 |
//+------------------------------------------------------------------+
void OnDeinit(const int reason)
{
Comment("");
}

//+------------------------------------------------------------------+
//| 计算单根K线的区间(最高价-最低价) |
//+------------------------------------------------------------------+
double CandleRange(int shift)
{
return iHigh(Symbol(), PERIOD_H4, shift) - iLow(Symbol(), PERIOD_H4, shift);
}

//+------------------------------------------------------------------+
//| 检测波动收缩形态 |
//+------------------------------------------------------------------+
bool DetectCompression()
{
double ranges[];
ArrayResize(ranges, RangeLookback);

for(int i = 1; i <= RangeLookback; i++)
ranges[i-1] = CandleRange(i);

// 计算平均区间
double avgRange = 0;
for(int i = 0; i < RangeLookback; i++)
avgRange += ranges[i];
avgRange /= RangeLookback;

if(avgRange <= 0) return false;

// 检查当前K线是否压缩
double currentRange = CandleRange(1);
bool isCompressed = (currentRange < avgRange * CompressionRatio);

// 跟踪连续压缩K线数量
if(isCompressed)
{
compressionCandleCount++;
// 更新压缩区间边界
double candleHigh = iHigh(Symbol(), PERIOD_H4, 1);
double candleLow = iLow(Symbol(), PERIOD_H4, 1);
if(compressionCandleCount == 1 || candleHigh > compressionHigh)
compressionHigh = candleHigh;
if(compressionCandleCount == 1 || candleLow < compressionLow)
compressionLow = candleLow;
}
else
{
compressionCandleCount = 0;
compressionHigh = 0;
compressionLow = 0;
}

compressionRange = compressionHigh - compressionLow;

return (compressionCandleCount >= MinCompressionCandles);
}

//+------------------------------------------------------------------+
//| 检测压缩区间的突破 |
//+------------------------------------------------------------------+
bool CheckBreakout(int &cmd, double &entryPrice, double &compRange)
{
if(compressionCandleCount < MinCompressionCandles)
return false;

double close1 = iClose(Symbol(), PERIOD_H4, 1);
double high1 = iHigh(Symbol(), PERIOD_H4, 1);
double low1 = iLow(Symbol(), PERIOD_H4, 1);
double atr = iATR(Symbol(), PERIOD_H4, 14, 1);

if(atr <= 0) atr = compressionRange * 0.5;

double breakoutThreshold = atr * BreakoutMultiplier;

// 向上突破:收盘价高于压缩高点 + 阈值
if(close1 > compressionHigh + breakoutThreshold)
{
cmd = OP_BUY;
entryPrice = Ask;
compRange = compressionRange;
return true;
}
// 向下突破:收盘价低于压缩低点 - 阈值
else if(close1 < compressionLow - breakoutThreshold)
{
cmd = OP_SELL;
entryPrice = Bid;
compRange = compressionRange;
return true;
}

return false;
}

//+------------------------------------------------------------------+
//| 管理持仓的追踪止损 |
//+------------------------------------------------------------------+
void ManageTrailing(double compRange)
{
for(int i = OrdersTotal()-1; i >= 0; i--)
{
if(OrderSelect(i, SELECT_BY_POS, MODE_TRADES))
{
if(OrderSymbol() == Symbol() && OrderMagicNumber() == MagicNumber)
{
double activateLevel = compRange * TrailingActivate;
double step = compRange * TrailingStep;

double newSL = 0;
if(OrderType() == OP_BUY)
{
double profit = Bid - OrderOpenPrice();
if(profit >= activateLevel)
{
newSL = Bid - step;
if(newSL > OrderStopLoss())
{
OrderModify(OrderTicket(), OrderOpenPrice(), newSL, OrderTakeProfit(), 0, clrNONE);
}
}
}
else if(OrderType() == OP_SELL)
{
double profit = OrderOpenPrice() - Ask;
if(profit >= activateLevel)
{
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(UseSundayClose && !sundayCloseExecuted)
{
datetime currentTime = TimeCurrent();
if(TimeDayOfWeek(currentTime) == 0 && TimeHour(currentTime) >= 22)
{
CloseAllOrders();
sundayCloseExecuted = true;
return;
}
if(TimeDayOfWeek(currentTime) != 0)
sundayCloseExecuted = false;
}

// 比特币点差过滤
if(MarketInfo(Symbol(), MODE_SPREAD) > MaxSpread)
{
Comment("当前点差过大:", MarketInfo(Symbol(), MODE_SPREAD));
return;
}

// 仅在新K线开始时检测入场(H4)
if(Time[0] == lastBarTime)
return;
lastBarTime = Time[0];

// 管理现有持仓
int posCount = CountPositions();
if(posCount > 0)
{
if(compressionRange > 0)
ManageTrailing(compressionRange);
return;
}

// 检测波动收缩形态
bool isCompressed = DetectCompression();
if(!isCompressed)
{
Comment("未检测到有效压缩形态");
return;
}

// 检查突破
int cmd = -1;
double entryPrice = 0;
double compRange = 0;

if(CheckBreakout(cmd, entryPrice, compRange))
{
double sl = 0, tp = 0;
double stopDistance = compRange * StopLossMultiplier;
double takeDistance = compRange * TakeProfitMultiplier;

if(cmd == OP_BUY)
{
sl = entryPrice - stopDistance;
tp = entryPrice + takeDistance;
}
else if(cmd == OP_SELL)
{
sl = entryPrice + stopDistance;
tp = entryPrice - takeDistance;
}

int ticket = OrderSend(Symbol(), cmd, LotSize, entryPrice, 5, sl, tp, "BTC K-Range", MagicNumber, 0, clrNONE);
if(ticket < 0)
{
Print("开仓失败,错误码:", GetLastError());
}
else
{
Print("突破开仓成功。压缩区间:", compRange);
}
}
}

//+------------------------------------------------------------------+
//| 统计当前魔术号的持仓数量 |
//+------------------------------------------------------------------+
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代码,仅供学习参考。
免责声明: 比特币交易因高波动性和潜在市场跳空具有极高风险。本EA按“原样”提供,不保证盈利。实盘部署前请在模拟账户测试至少2个月。历史表现不代表未来结果。
```