自适应趋势流动性多重过滤交易策略

EMA SMA MACD ATR HLC3
创建日期: 2025-01-06 11:58:25 最后修改: 2025-01-06 11:58:25
复制: 0 点击次数: 124
1
关注
1166
关注者

自适应趋势流动性多重过滤交易策略

概述

本策略是一个基于多重技术指标过滤的自适应趋势跟踪系统。它结合了指数移动平均线(EMA)、简单移动平均线(SMA)和移动平均线趋同散度(MACD)等多个技术指标,通过动态调整参数来适应不同的市场环境,实现高效的趋势捕捉和风险控制。该策略采用分层过滤机制,通过多重技术指标的协同配合,显著提高了交易信号的可靠性。

策略原理

策略的核心逻辑基于三层过滤机制: 1. 自适应趋势识别层:使用快速和慢速EMA的组合计算趋势基准线,并结合市场波动性动态调整上下轨道线。 2. SMA过滤层:通过简单移动平均线确保价格运动方向与整体趋势保持一致。 3. MACD确认层:利用MACD指标的趋势确认功能,进一步验证交易信号的有效性。

交易信号的生成需要满足所有过滤条件:趋势转换、SMA方向确认以及MACD信号线的支持。策略还包含了基于账户权益的动态仓位管理系统,通过杠杆因子自动调整持仓规模。

策略优势

  1. 自适应性强:通过动态调整参数,策略能够适应不同的市场环境。
  2. 风险控制完善:多重过滤机制显著降低了虚假信号的出现概率。
  3. 可定制性高:用户可以根据个人交易风格调整各项参数。
  4. 自动化程度高:支持JSON格式的警报消息,便于与自动交易系统对接。
  5. 可视化效果好:提供了丰富的视觉反馈,包括趋势带、信号标记等。

策略风险

  1. 趋势依赖性:在震荡市场中可能产生频繁的假信号。
  2. 滞后性风险:多重过滤机制可能导致入场时机延迟。
  3. 参数敏感性:不同参数组合可能导致策略表现差异较大。
  4. 杠杆风险:过高的杠杆可能放大损失。

策略优化方向

  1. 波动率适应:增加基于ATR的动态止损机制。
  2. 市场环境识别:添加市场状态分类系统,在不同市场环境下使用不同的参数组合。
  3. 信号质量评分:建立信号强度评分系统,根据信号强度动态调整仓位。
  4. 资金管理优化:引入更复杂的资金管理算法,实现更精细的仓位控制。

总结

该策略通过多层过滤机制和动态参数调整,实现了较为可靠的趋势跟踪效果。虽然存在一定的滞后性和参数依赖性风险,但通过合理的参数优化和风险控制措施,仍然可以在实际交易中取得稳定的表现。建议交易者在实盘使用前,充分进行回测验证,并根据个人风险承受能力调整参数设置。

策略源码
/*backtest
start: 2024-12-29 00:00:00
end: 2025-01-05 00:00:00
period: 45m
basePeriod: 45m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=6
strategy("Adaptive Trend Flow Strategy with Filters for SPX", overlay=true, max_labels_count=500, 
     initial_capital=1000, commission_type=strategy.commission.cash_per_order, commission_value=0.01, slippage=2,
     margin_long=20, margin_short=20, default_qty_type=strategy.percent_of_equity, default_qty_value=100)

// User-defined inputs for trend logic
atr           = input.int(14, "Main Length", minval=2, group = "Find more strategies like this on pineindicators.com")
length        = input.int(2, "Main Length", minval=2)
smooth_len    = input.int(2, "Smoothing Length", minval=2)
sensitivity   = input.float(2.0, "Sensitivity", step=0.1)

// User-defined inputs for SMA filter
use_sma_filter = input.bool(true, "Enable SMA Filter?")
sma_length = input.int(4, "SMA Length", minval=1)

// User-defined inputs for MACD filter
use_macd_filter = input.bool(true, "Enable MACD Filter?")
macd_fast_length = input.int(2, "MACD Fast Length", minval=1)
macd_slow_length = input.int(7, "MACD Slow Length", minval=1)
macd_signal_length = input.int(2, "MACD Signal Length", minval=1)
// User-defined inputs for leverage
leverage_factor = input.float(4.5, "Leverage Factor", minval=1.0, step=0.1)
id           = input("besttrader123", title= "Your TradingView username", group = "Automate this strategy with plugpine.com")
key           = input("nc739ja84gf", title= "Unique identifier (UID)")
ticker        = input("SPX", title= "Ticker/symbol of your broker")
bullcolor     = #0097a7
bearcolor     = #ff195f
showbars      = input.bool(true, "Color Bars?")
showbg        = input.bool(true, "Background Color?")
showsignals   = input.bool(true, "Show Signals?")


// Trend calculation functions
calculate_trend_levels() =>
    typical = hlc3
    fast_ema = ta.ema(typical, length)
    slow_ema = ta.ema(typical, length * 2)
    basis = (fast_ema + slow_ema) / 2
    vol = ta.stdev(typical, length)
    smooth_vol = ta.ema(vol, smooth_len)
    upper = basis + (smooth_vol * sensitivity)
    lower = basis - (smooth_vol * sensitivity)
    [basis, upper, lower]

get_trend_state(upper, lower, basis) =>
    var float prev_level = na
    var int trend = 0
    if na(prev_level)
        trend := close > basis ? 1 : -1
        prev_level := trend == 1 ? lower : upper
    if trend == 1
        if close < lower
            trend := -1
            prev_level := upper
        else
            prev_level := lower
    else
        if close > upper
            trend := 1
            prev_level := lower
        else
            prev_level := upper
    [trend, prev_level]

[basis, upper, lower] = calculate_trend_levels()
[trend, level] = get_trend_state(upper, lower, basis)

// SMA filter
sma_value = ta.sma(close, sma_length)
sma_condition = use_sma_filter ? close > sma_value : true

// MACD filter
[macd_line, signal_line, _] = ta.macd(close, macd_fast_length, macd_slow_length, macd_signal_length)
macd_condition = use_macd_filter ? macd_line > signal_line : true

// Signal detection with filters
long_signal = trend == 1 and trend[1] == -1 and sma_condition and macd_condition
short_signal = trend == -1 and trend[1] == 1

// Plotting visuals
p2 = plot(basis, color=trend == 1 ? bullcolor : bearcolor, linewidth=2)
p1 = plot(level, color=close > level ? bullcolor : bearcolor, linewidth=2, style=plot.style_linebr)
// if showsignals and ta.crossover(close, level)
//     label.new(bar_index, level, "▲", color=bullcolor, textcolor=chart.bg_color, style=label.style_label_upper_right)
// if showsignals and ta.crossunder(close, level)
//     label.new(bar_index, level, "▼", color=bearcolor, textcolor=chart.fg_color, style=label.style_label_lower_right)

qty = strategy.equity / close * leverage_factor

// Automated alerts
if long_signal
    alert('{"AccountID": "' + id + '","Key": "' + key + '", "symbol": "' + ticker + '", "action": "long", "volume": ' + str.tostring(qty) + '}', alert.freq_once_per_bar)
if short_signal
    alert('{"AccountID": "' + id + '","Key": "' + key + '", "symbol": "' + ticker + '", "action": "closelong"}', alert.freq_once_per_bar)

// Strategy entries and exits
if long_signal
    strategy.entry("Long", strategy.long, qty=qty)
if short_signal
    strategy.close("Long")

// Optional SMA and MACD plot
plot(use_sma_filter ? sma_value : na, color=color.new(color.blue, 80), title="SMA")
plot(use_macd_filter ? macd_line : na, color=color.new(color.orange, 80), title="MACD Line")
plot(use_macd_filter ? signal_line : na, color=color.new(color.red, 80), title="Signal Line")
相关推荐
更多内容