Эта стратегия представляет собой адаптивную стратегию ценового канала, основанную на индикаторе среднего истинного диапазона (ATR) и среднем направленном индексе (ADX).
Вычислить максимальный максимум (HH) и минимальный минимум (LL) за данную длину.
Вычислить +DI и -DI на основе движения цен вверх и вниз.
Если ADX < 25, рынок считается боковым. Если закрыть > верхний канал (HH - ATR мультипликатор * ATR), идти длинный. Если закрыть < нижний канал (LL + ATR мультипликатор * ATR), идти короткий.
Если ADX >= 25 и +DI > -DI, рынок быстрый.
Если ADX >= 25 и +DI < -DI, рынок медвежий.
Положение выхода после столбцов exit_length с момента входа.
Стратегия адаптируется автоматически на основе рыночных условий, используя стратегию канала на боковом рынке и тенденцию, следующую тренду на рынке.
Использование ATR и ADX обеспечивает адаптивность.
Принудительный выход добавляет стабильности.
ADX может часто генерировать ложные сигналы.
Плохие параметры ATR и ADX приводят к плохой работе.
Не в состоянии эффективно защитить от черных лебедей.
Оптимизировать параметры ATR и ADX для повышения адаптивности.
Добавьте стоп-лосс для ограничения потерь.
Добавьте фильтры, чтобы избежать ложных сигналов.
Стратегия сочетает в себе индикаторы и механизмы для адаптации к рыночным условиям. Но ошибки могут произойти из-за ограничений показателей. Будущие оптимизации параметров и контроля рисков.
/*backtest start: 2023-11-03 00:00:00 end: 2023-12-03 00:00:00 period: 1h basePeriod: 15m exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=5 strategy("Adaptive Price Channel Strategy", overlay=true) length = input(20, title="Length") exit_length = input(10, title="Exit After X Periods") atr_multiplier = input(3.2, title="ATR Multiplier") startDate = input(defval = timestamp("2019-01-15T08:15:15+00:00"), title = "Start Date") endDate = input(defval = timestamp("2033-04-01T08:15:00+00:00"), title = "End Date") hh = ta.highest(high, length) ll = ta.lowest(low, length) atr = ta.atr(length) // calculate +DI and -DI upMove = high - high[1] downMove = low[1] - low plusDM = na(upMove[1]) ? na : (upMove > downMove and upMove > 0 ? upMove : 0) minusDM = na(downMove[1]) ? na : (downMove > upMove and downMove > 0 ? downMove : 0) plusDI = ta.rma(plusDM, length) / atr * 100 minusDI = ta.rma(minusDM, length) / atr * 100 // calculate ADX dx = math.abs(plusDI - minusDI) / (plusDI + minusDI) * 100 adx = ta.rma(dx, length) var int barSinceEntry = na if (not na(close[length]) ) if (adx < 25) // Sideways market if (close > hh - atr_multiplier * atr) strategy.entry("PChLE", strategy.long, comment="PChLE") barSinceEntry := 0 else if (close < ll + atr_multiplier * atr) strategy.entry("PChSE", strategy.short, comment="PChSE") barSinceEntry := 0 else if (adx >= 25 and plusDI > minusDI) // Bullish market if (close > hh - atr_multiplier * atr) strategy.entry("PChLE", strategy.long, comment="PChLE") barSinceEntry := 0 else if (adx >= 25 and plusDI < minusDI) // Bearish market if (close < ll + atr_multiplier * atr) strategy.entry("PChSE", strategy.short, comment="PChSE") barSinceEntry := 0 if (na(barSinceEntry)) barSinceEntry := barSinceEntry[1] + 1 else if (barSinceEntry >= exit_length) strategy.close("PChLE") strategy.close("PChSE") barSinceEntry := na plot(hh, title="Highest High", color=color.green, linewidth=2) plot(ll, title="Lowest Low", color=color.red, linewidth=2)