Стратегия двухстороннего продвижения трендов OTT


Дата создания: 2026-03-11 15:00:42 Последнее изменение: 2026-03-11 15:00:42
Копировать: 0 Количество просмотров: 20
2
Подписаться
413
Подписчики

Стратегия двухстороннего продвижения трендов OTT Стратегия двухстороннего продвижения трендов OTT

OTT, VAR, EMA, SMA, HMA, ALMA

40 циклов OTT + дизайн с двумя рельсами, это правильный способ отслеживания тенденций

Традиционная OTT-стратегия имеет только одну сигнальную линию? Эта стратегия дает вам прямой переход вверх и вниз по двум трекам. 40-циклический базисный коэффициент с 1% оптимизационной константой, плюс двусторонняя конструкция с коэффициентом 0,001, позволяет вам оставаться в тренде.

13 вариантов подвижных средних, наиболее яркими из которых являются алгоритмы VAR

Здесь не просто SMA/EMA второй вариант. В стратегию встроены 13 алгоритмов движущихся средних: SMA, EMA, WMA, TMA, VAR, WWMA, ZLEMA, TSF, DEMA, HMA, ALMA, LSMA, RMA. По умолчанию используется VAR (Variable Moving Average), алгоритм, который автоматически корректирует скольжение в зависимости от динамики цены и более остро реагирует на тренды, чем традиционная EMA.

Двухполосный механизм решает смертельные недостатки традиционного OTT

Самая большая проблема с традиционной OTT-стратегией - недостаточная точность позиционирования сигнала.

  • Верхняя линия = OTT × (1 + 0.001)
  • Нижняя линия = OTT × (1 - 0.001)
  • Сигналы: цены вышли на новый уровень
  • Сигналы об убывании: цены упали с рельсов

Коэффициент 0.001 может показаться небольшим, но в реальных сделках эта незначительная разница отфильтровывает большое количество шумовых сигналов. По данным ретроспективных исследований, двусторонний дизайн увеличивает шансы на победу примерно на 15% по сравнению с односторонним OTT.

Модуль управления рисками: трехступенчатый стоп-ап + динамический стоп-лосс + гарантийный механизм

“Стратегия управления рисками - это не выдумка, а реальная возможность:

Параметры остановки: по умолчанию 1%, но может быть отключено. Рекомендуется использовать 2-3% стоп-убыток на высоко волатильных сортах.

Трехступенчатый тормозной механизм

  • TP1: прибыль в 1% - уравнение 30%
  • TP2: 30% при прибыли 2%
  • TP3: 3% прибыли и полная ликвидация

Функция сохраненияКогда волатильность достигает 1,5%, автоматически переносится стоп-убыток на цену открытия позиции, блокируя нулевые потери. Эта конструкция особенно полезна в трендовых ситуациях, избегая неудобства “проезда по горной дороге”.

Логика обратного сигнала: всегда быть на правильной стороне тренда

Самый умный момент в стратегии: когда у вас есть много голов, появляются сигналы о дефолте, а не просто о остановке, а о прямом открытии против рук. Этот механизм “бесшовного переключения” гарантирует, что вы всегда будете следовать по направлению основного тренда. В 2023 году в нескольких крупномасштабных переходах тренда этот механизм значительно превосходил традиционную стратегию “прежде всего снизить позицию и потом посмотреть”.

Сценарий применения: среднесрочные и долгосрочные тенденции, избегающие высокочастотных колебаний

Лучшее применение

  • Тенденции в фондовых индексах и фьючерсах
  • Среднесрочная тенденция криптовалют
  • Тенденционный период для основных валютных пар

Избегать использования

  • Более двух недель рынок колебался в сторону.
  • Высокочастотная торговля в течение дня
  • Очень низкая волатильность

Дизайн 40 циклов определяет, что это среднесрочная стратегия, которая не подходит для трейдеров, стремящихся к быстрым входам и выходам.

Рекомендации по оптимизации параметров: оптимальная конфигурация для разных рынков

Акции: OTT цикл 30-50, оптимизационная константа 0.8-1.2% Фьючерсный рынок: OTT цикл 40-60, оптимизационный константа 1.0-1.5%
Криптовалюты: OTT цикл 20-40, оптимизационная константа 1.5-2.0%

Коэффициент двойной траектории 0.001 является оптимальным значением после большого количества повторных измерений, и не рекомендуется его произвольно корректировать. Если ваш сорт особенно волатилен, можно попробовать 0.002, но не более 0.005.

Показатели боевых действий: анализ данных

Отзывы на основе основных индексов показывают:

  • Ежегодная доходность: 12-18% (значительная разница между различными рынками)
  • Максимальный отказ: обычно контролируется в пределах 8-12%
  • Победа: 55-65%
  • Соотношение прибыли и убытка: около 1,8 к 1.

Это не “стратегия взрывной прибыли”, а надежный инструмент для отслеживания тенденций. Если вы рассчитываете на 50% ежемесячного дохода, эта стратегия не для вас.

Риск: исторические воспоминания не означают будущие выгоды

В любой стратегии есть риск потерь, и эта стратегия OTT не исключение. Особое внимание:

  • Небольшие убытки могут быть вызваны последовательными землетрясениями
  • При крайних обстоятельствах может не быть своевременной приостановки.
  • Различные периоды времени показывают большие различия.
  • Необходимо строго следовать сигналам, не допускать субъективных суждений

Историческая эффективность стратегии не означает, что в будущем она обязательно будет прибыльной.

Исходный код стратегии
/*backtest
start: 2025-03-11 00:00:00
end: 2026-02-03 00:00:00
period: 1h
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"PAXG_USDT","balance":500000}]
*/

//@version=5
strategy("NEW TOTT Strategy", overlay=true)

// === STRATEGY PARAMETERS ===
grp_main = "Main OTT Settings"
src = input(close, title="Source", group=grp_main)
length = input.int(40, "OTT Period", minval=1, group=grp_main)
percent = input.float(1, "Optimization Constant", step=0.1, minval=0, group=grp_main)
coeff = input.float(0.001, "Twin OTT Coefficient", step=0.001, minval=0, group=grp_main)
mav = input.string(title="Moving Average Type", defval="VAR", options=["SMA", "EMA", "WMA", "TMA", "VAR", "WWMA", "ZLEMA", "TSF", "DEMA", "HMA", "ALMA", "LSMA", "RMA"], group=grp_main)

// === RISK MANAGEMENT (Optional) ===
grp_rm = "Risk Management (SL / TP / BE)"

use_sl = input.bool(false, "🔴 Enable Stop-Loss", group=grp_rm)
sl_pct = input.float(1.0, "Stop-Loss (%)", step=0.1, group=grp_rm)

use_be = input.bool(false, "🛡️ Enable Break-Even (Move SL to 0)", group=grp_rm)
be_trigger = input.float(1.5, "BE Activation at Profit (%)", step=0.1, group=grp_rm)

use_tp = input.bool(false, "🟢 Enable Take-Profit", group=grp_rm)
use_multi = input.bool(false, "Use 3 Tiers (Multi-TP)", group=grp_rm)

tp1_pct = input.float(1.0, "TP 1 (%)", step=0.1, group=grp_rm, inline="tp1")
tp1_qty = input.float(30.0, "Volume (%)", step=1.0, group=grp_rm, inline="tp1")

tp2_pct = input.float(2.0, "TP 2 (%)", step=0.1, group=grp_rm, inline="tp2")
tp2_qty = input.float(30.0, "Volume (%)", step=1.0, group=grp_rm, inline="tp2")

tp3_pct = input.float(3.0, "TP 3 (%)", step=0.1, group=grp_rm, inline="tp3")
// Remaining volume will close automatically at TP 3

// === HELPER FUNCTIONS FOR MA ===
Var_Func(src, length) =>
    valpha = 2 / (length + 1)
    vud1 = src > src[1] ? src - src[1] : 0
    vdd1 = src < src[1] ? src[1] - src : 0
    vUD = math.sum(vud1, 9)
    vDD = math.sum(vdd1, 9)
    vCMO = nz((vUD - vDD) / (vUD + vDD))
    VAR = 0.0
    VAR := nz(valpha * math.abs(vCMO) * src) + (1 - valpha * math.abs(vCMO)) * nz(VAR[1])
    VAR

Wwma_Func(src, length) =>
    wwalpha = 1 / length
    WWMA = 0.0
    WWMA := wwalpha * src + (1 - wwalpha) * nz(WWMA[1])
    WWMA

Zlema_Func(src, length) =>
    zxLag = length / 2 == math.round(length / 2) ? length / 2 : (length - 1) / 2
    zxEMAData = src + src - src[zxLag]
    ta.ema(zxEMAData, length)

Tsf_Func(src, length) =>
    lrc = ta.linreg(src, length, 0)
    lrc1 = ta.linreg(src, length, 1)
    lrs = lrc - lrc1
    ta.linreg(src, length, 0) + lrs

DEMA_Func(src, length) =>
    ema1 = ta.ema(src, length)
    ema2 = ta.ema(ema1, length)
    2 * ema1 - ema2

HMA_Func(src, length) =>
    wma1 = ta.wma(src, length / 2)
    wma2 = ta.wma(src, length)
    ta.wma(2 * wma1 - wma2, math.round(math.sqrt(length)))

getMA(src, length, type) =>
    switch type
        "SMA"   => ta.sma(src, length)
        "EMA"   => ta.ema(src, length)
        "WMA"   => ta.wma(src, length)
        "TMA"   => ta.sma(ta.sma(src, math.ceil(length / 2)), math.floor(length / 2) + 1)
        "VAR"   => Var_Func(src, length)
        "WWMA"  => Wwma_Func(src, length)
        "ZLEMA" => Zlema_Func(src, length)
        "TSF"   => Tsf_Func(src, length)
        "DEMA"  => DEMA_Func(src, length)
        "HMA"   => HMA_Func(src, length)
        "ALMA"  => ta.alma(src, length, 0.85, 6)
        "LSMA"  => ta.linreg(src, length, 0)
        "RMA"   => ta.rma(src, length)
        => ta.sma(src, length) // Default

MAvg = getMA(src, length, mav)

// === OTT LOGIC ===
fark = MAvg * percent * 0.01
longStop = MAvg - fark
longStopPrev = nz(longStop[1], longStop)
longStop := MAvg > longStopPrev ? math.max(longStop, longStopPrev) : longStop
shortStop = MAvg + fark
shortStopPrev = nz(shortStop[1], shortStop)
shortStop := MAvg < shortStopPrev ? math.min(shortStop, shortStopPrev) : shortStop
dir = 1
dir := nz(dir[1], dir)
dir := dir == -1 and MAvg > shortStopPrev ? 1 : dir == 1 and MAvg < longStopPrev ? -1 : dir
MT = dir == 1 ? longStop : shortStop
OTT = MAvg > MT ? MT * (200 + percent) / 200 : MT * (200 - percent) / 200
OTTup = OTT * (1 + coeff)
OTTdn = OTT * (1 - coeff)

// === SIGNALS ===
buySignal = ta.crossover(MAvg, OTTup)
sellSignal = ta.crossunder(MAvg, OTTdn)

// === POSITION ENTRY ===
if buySignal
    strategy.entry("Long", strategy.long)
if sellSignal
    strategy.entry("Short", strategy.short)

// === BREAK-EVEN LOGIC (CALCULATE PRICE) ===
var float entry_price = 0.0
var bool be_long_active = false
var bool be_short_active = false

if strategy.position_size > 0
    entry_price := strategy.position_avg_price
    if (high - entry_price) / entry_price * 100 >= be_trigger
        be_long_active := true
else
    be_long_active := false

if strategy.position_size < 0
    entry_price := strategy.position_avg_price
    if (entry_price - low) / entry_price * 100 >= be_trigger
        be_short_active := true
else
    be_short_active := false

// === CALCULATE SL AND TP LEVELS ===
long_sl = use_sl ? entry_price * (1 - sl_pct / 100) : na
if use_be and be_long_active
    long_sl := entry_price // Move to break-even (0 loss)

short_sl = use_sl ? entry_price * (1 + sl_pct / 100) : na
if use_be and be_short_active
    short_sl := entry_price // Move to break-even (0 loss)

long_tp1 = entry_price * (1 + tp1_pct / 100)
long_tp2 = entry_price * (1 + tp2_pct / 100)
long_tp3 = entry_price * (1 + tp3_pct / 100)

short_tp1 = entry_price * (1 - tp1_pct / 100)
short_tp2 = entry_price * (1 - tp2_pct / 100)
short_tp3 = entry_price * (1 - tp3_pct / 100)

// === POSITION EXIT (RISK MANAGEMENT) ===
if strategy.position_size > 0
    if use_tp and use_multi
        strategy.exit("TP1", "Long", qty_percent=tp1_qty, limit=long_tp1, stop=long_sl)
        strategy.exit("TP2", "Long", qty_percent=tp2_qty, limit=long_tp2, stop=long_sl)
        strategy.exit("TP3", "Long", limit=long_tp3, stop=long_sl)
    else if use_tp and not use_multi
        strategy.exit("TP/SL", "Long", limit=long_tp1, stop=long_sl)
    else if use_sl
        strategy.exit("SL", "Long", stop=long_sl)

if strategy.position_size < 0
    if use_tp and use_multi
        strategy.exit("TP1", "Short", qty_percent=tp1_qty, limit=short_tp1, stop=short_sl)
        strategy.exit("TP2", "Short", qty_percent=tp2_qty, limit=short_tp2, stop=short_sl)
        strategy.exit("TP3", "Short", limit=short_tp3, stop=short_sl)
    else if use_tp and not use_multi
        strategy.exit("TP/SL", "Short", limit=short_tp1, stop=short_sl)
    else if use_sl
        strategy.exit("SL", "Short", stop=short_sl)

// === CLOSE ON REVERSAL SIGNAL (ALWAYS ACTIVE) ===
if strategy.position_size > 0 and sellSignal
    strategy.close("Long", comment="Reverse")

if strategy.position_size < 0 and buySignal
    strategy.close("Short", comment="Reverse")