
이 전략은 여러 주기적 트렌드 추적, 거래량 분석 및 동적 위험 관리를 결합한 통합 거래 시스템이다. 이 전략은 평균선 ((EMA), 동향 지표 ((ADX), 상대적으로 강한 지표 ((RSI) 및 거래량 가중 평균 가격 ((VWAP) 과 같은 여러 기술 지표를 통합하여 스스로 적응하는 거래 프레임 워크를 구축한다. 이 전략은 특히 다른 시간 주기의 시장 형태를 식별하는 것을 강조하며 거래량 특성을 합성하여 시장을 최적화한다.
이 전략은 계층 구조로 설계되었으며, 다음과 같은 핵심 구성 요소를 포함하고 있습니다.
이 전략은 다단계 기술 지표 조합을 통해 시장의 추세, 변동성 및 거래량에 대한 전체적인 분석을 구현합니다. 핵심 장점은 다중 주기 분석과 엄격한 위험 통제를 결합하여 다양한 시장 환경에서 안정적인 성능을 유지할 수 있다는 것입니다.
/*backtest
start: 2024-03-07 18:40:00
end: 2025-02-17 08:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Binance","currency":"DOGE_USDT"}]
*/
//@version=6
strategy("优化后策略框架", overlay=true)
// 输入参数
ema_length = input.int(20, title="EMA周期")
adx_length = input.int(14, title="ADX周期")
rsi_length = input.int(21, title="RSI周期")
atr_length = input.int(14, title="ATR周期")
volume_length = input.int(20, title="成交量均值周期")
fibonacci_level = 1.618 // 斐波那契扩展位161.8%
// 计算技术指标
ema = ta.ema(close, ema_length)
// 使用ta.dmi()来获取+DI, -DI 和 ADX
[dm_plus, dm_minus, adx] = ta.dmi(adx_length, adx_length)
// 计算RSI和ATR
rsi = ta.rsi(close, rsi_length)
atr = ta.atr(atr_length)
vwap = ta.vwap(close)
avg_volume = ta.sma(volume, volume_length)
// 定义趋势
bull_trend = close > ema and adx > 25
bear_trend = close < ema and adx > 25
range_market = adx < 25
// VWAP分层定位
upper_bound = vwap + 1.5 * atr
lower_bound = vwap - 1.5 * atr
// 计算4小时图的信号
four_hour_ema = request.security(syminfo.tickerid, "240", ta.ema(close, ema_length))
four_hour_vwap = request.security(syminfo.tickerid, "240", ta.vwap(close))
four_hour_rsi = request.security(syminfo.tickerid, "240", ta.rsi(close, rsi_length))
four_hour_volume = request.security(syminfo.tickerid, "240", ta.sma(volume, volume_length))
// 多头入场条件
long_condition = bull_trend and (close[1] < four_hour_ema or close[1] < four_hour_vwap) and rsi[1] < 45 and rsi[0] > 40 and volume < avg_volume * 0.7
// 空头入场条件
short_condition = bear_trend and (close[1] > four_hour_ema or close[1] > four_hour_vwap) and rsi[1] > 55 and rsi[0] < 60 and volume < avg_volume * 0.8
// 计算止损和止盈
long_stop = close - 1.5 * atr
short_stop = close + 1.5 * atr
long_target = vwap + atr // 第一目标,VWAP+1×ATR
short_target = vwap - atr // 第一目标,VWAP-1×ATR
fibonacci_target = close + (fibonacci_level * (high - low)) // 斐波那契161.8%目标
// 计算头寸规模(仓位控制)
risk_per_trade = 0.01 // 单笔风险为账户净值的1%
account_balance = strategy.equity
position_size = (account_balance * risk_per_trade) / (1.5 * atr)
// 绘制买卖信号
plotshape(series=long_condition, title="多头入场", location=location.belowbar, color=color.green, style=shape.triangleup, text="BUY")
plotshape(series=short_condition, title="空头入场", location=location.abovebar, color=color.red, style=shape.triangledown, text="SELL")
// 执行策略
if (long_condition)
strategy.entry("Long", strategy.long, qty=position_size)
if (short_condition)
strategy.entry("Short", strategy.short, qty=position_size)
strategy.exit("Take Profit/Stop Loss", "Long", stop=long_stop, limit=long_target)
strategy.exit("Take Profit/Stop Loss", "Long", stop=long_stop, limit=fibonacci_target)
strategy.exit("Take Profit/Stop Loss", "Short", stop=short_stop, limit=short_target)
strategy.exit("Take Profit/Stop Loss", "Short", stop=short_stop, limit=fibonacci_target)
// 绘制VWAP和超买超卖区
plot(vwap, title="VWAP", color=color.blue)
plot(upper_bound, title="超买区", color=color.red, linewidth=2, style=plot.style_line)
plot(lower_bound, title="超卖区", color=color.green, linewidth=2, style=plot.style_line)