Многопериодная стратегия адаптивной торговли с блоком ордеров на прорыв фракталов

OB SD MA ATR
Дата создания: 2024-12-27 15:49:16 Последнее изменение: 2024-12-27 15:49:16
Копировать: 8 Количество просмотров: 479
1
Подписаться
1617
Подписчики

Многопериодная стратегия адаптивной торговли с блоком ордеров на прорыв фракталов

Обзор

Стратегия представляет собой адаптивную торговую систему, основанную на теории фракталов и анализе блоков ордеров. Он выявляет высоковероятностные торговые возможности, определяя ключевые уровни поддержки и сопротивления в структуре рынка в сочетании с сигналами прорыва фракталов и подтверждениями блоков ордеров. Стратегия объединяет несколько технических индикаторов, включая фрактальные индикаторы, динамические блоки ордеров и системы подтверждения прорыва цены, что позволяет точно определять точки разворота рынка и точно улавливать торговые возможности.

Стратегический принцип

Основная логика стратегии строится на трех основных столпах: во-первых, постоянный мониторинг рыночных максимумов и минимумов с помощью модуля расчета фракталов для выявления потенциальных областей разворота тренда; во-вторых, посредством анализа блока ордеров, установление областей спроса и предложения на ключевых ценовых уровнях. ; и, наконец, через систему подтверждения прорыва для проверки действительности ценовых прорывов. Когда цена пробивает верхний фрактал и подтверждается, что она действительна, система создает блок ордеров области спроса в ближайшей области красной свечи и открывает длинный ордер; когда цена пробивает нижний фрактал и подтверждается, что она действительна , система создаст область предложения в ближайшей области зеленой свечи Блок ордеров и откроет короткий ордер. Стратегия также включает в себя функцию динамического обновления цвета блока ордеров, которая используется для интуитивного отображения относительного положения цены и блока ордеров.

Стратегические преимущества

  1. Высокая адаптивность: стратегия может динамически корректировать положение и размер блока ордеров в соответствии с рыночными условиями и адаптироваться к различным рыночным средам.
  2. Механизм множественного подтверждения: объединяет фрактальный прорыв, подтверждение блока ордеров и анализ ценового действия для снижения риска ложных сигналов.
  3. Улучшенное управление рисками: помогите трейдерам отслеживать статус работы стратегии в режиме реального времени с помощью наглядной визуальной обратной связи и контрольного списка статуса.
  4. Превосходная визуализация: интуитивно понятный графический интерфейс, включающий фрактальные маркеры, отображение блоков заказов и контрольный список статуса.
  5. Гибкие и настраиваемые параметры: пользователи могут настраивать ключевые параметры, такие как период фрактала, тип прорыва и т. д., в соответствии со своим личным стилем торговли.

Стратегический риск

  1. Риск волатильности рынка: на высоковолатильных рынках могут генерироваться ложные сигналы прорыва, требующие дополнительных механизмов фильтрации.
  2. Риск проскальзывания: в рыночной среде с недостаточной ликвидностью цена исполнения ордера может отклоняться от идеальной точки входа.
  3. Зависимость от тренда: стратегия может не работать так же хорошо на боковом рынке, как на трендовом.
  4. Чувствительность параметров: различные настройки фрактального периода могут привести к существенно разным результатам торговли.
  5. Потребление вычислительных ресурсов: сложные функции визуализации и вычисления в реальном времени могут увеличить нагрузку на систему.

Направление оптимизации

  1. Представляем фильтры волатильности: оптимизируйте торговые сигналы с помощью ATR или других индикаторов волатильности.
  2. Добавьте механизм подтверждения тренда: объедините его со скользящей средней или другими индикаторами тренда для повышения надежности сигнала.
  3. Улучшите механизм стоп-лосса: разработайте динамическую стратегию стоп-лосса на основе структуры блока ордеров.
  4. Оптимизируйте размер блока ордеров: динамически корректируйте размер блока ордеров в зависимости от волатильности рынка.
  5. Добавьте анализ объема: объедините данные по объему, чтобы проверить эффективность прорыва.

Подвести итог

Это сложная торговая стратегия, которая объединяет несколько измерений технического анализа. Она создает полную торговую систему с теорией фракталов и анализом блока ордеров в качестве ядра. Преимущества стратегии заключаются в ее адаптивности и множественных механизмах подтверждения, но в то же время необходимо также обращать внимание на влияние рыночной среды на эффективность стратегии. Ожидается, что благодаря рекомендуемым направлениям оптимизации надежность и стабильность стратегии будут дополнительно повышены.

Исходный код стратегии
/*backtest
start: 2019-12-23 08:00:00
end: 2024-12-25 08:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=5
strategy("Supply and Demand - Order Block Strategy", format=format.price, precision=0, overlay=true)

// Input options for customization
changeColor = input(false, title="Change Box Colors?")
breakType = input.string("Wick+Body", title="Fractal Break Type:", options=["Wick+Body", "Body"])
n = input.int(title="Periods", defval=2, minval=1, tooltip="Number of periods for fractal lookback")

if n <= 0
    runtime.error("Periods input must be greater than zero.")

transGreenClr = input.color(color.new(color.green, 80), title="Bg:", inline="a_1")
greenClr = input.color(color.new(color.green, 0), title="Border:", inline="a_1")

transRedClr = input.color(color.new(color.red, 80), title="Bg:", inline="b_1")
redClr = input.color(color.new(color.red, 0), title="Border:", inline="b_1")

// --- Fractal Calculation ---
upFractal = high[n] == ta.highest(high, 2 * n + 1)
downFractal = low[n] == ta.lowest(low, 2 * n + 1)
// --- End Fractal Calculation ---

var float topValue = na
var float bottomValue = na
var int lastRedIndex = na
var float lastRedLow = na
var float lastRedHigh = na
var int lastGreenIndex = na
var float lastGreenLow = na
var float lastGreenHigh = na
var line topLine = na
var line bottomLine = na
var box demandBox = na
var box supplyBox = na
var topBreakBlock = false
var bottomBreakBlock = false
var isLongBreak = false
var isShortBreak = false
topBreakCheckSource = breakType == "Wick+Body" ? high : close
bottomBreakCheckSource = breakType == "Wick+Body" ? low : close

// Last Red Check
if close < open
    lastRedIndex := bar_index
    lastRedLow := low
    lastRedHigh := high

// Last Green Check
if close > open
    lastGreenIndex := bar_index
    lastGreenLow := low
    lastGreenHigh := high

// Top break
if ta.crossover(topBreakCheckSource, topValue) and not topBreakBlock
    topBreakBlock := true
    isLongBreak := true
    // line.set_x2(topLine, bar_index)
    // demandBox := box.new(lastRedIndex - 1, lastRedHigh, lastRedIndex + 1, lastRedLow, bgcolor=transGreenClr, border_color=greenClr)
    if strategy.position_size <= 0
        strategy.entry("Long", strategy.long)

// Bottom break
if ta.crossunder(bottomBreakCheckSource, bottomValue) and not bottomBreakBlock
    bottomBreakBlock := true
    isShortBreak := true
    // line.set_x2(bottomLine, bar_index)
    // supplyBox := box.new(lastGreenIndex - 1, lastGreenHigh, lastGreenIndex + 1, lastGreenLow, bgcolor=transRedClr, border_color=redClr)
    if strategy.position_size >= 0
        strategy.entry("Short", strategy.short)

// New up fractal
if upFractal
    topBreakBlock := false
    isLongBreak := false
    topValue := high[n]
    // topLine := line.new(bar_index[n], topValue, bar_index, topValue, color=color.teal, style=line.style_dotted, width=2)
    // if not isLongBreak[1]
    //     line.delete(topLine[1])

// New down fractal
if downFractal
    bottomBreakBlock := false
    isShortBreak := false
    bottomValue := low[n]
    // bottomLine := line.new(bar_index[n], bottomValue, bar_index, bottomValue, color=color.maroon, style=line.style_dotted, width=2)
    // if not isShortBreak[1]
    //     line.delete(bottomLine[1])

// Box state update
// activeBoxes = box.all
// if array.size(activeBoxes) > 0 and changeColor
//     for i = 0 to array.size(activeBoxes) - 1
//         boxId = array.get(activeBoxes, i)
//         bVal = box.get_bottom(boxId)
//         tVal = box.get_top(boxId)
//         if close < bVal
//             box.set_bgcolor(boxId, transRedClr)
//             box.set_border_color(boxId, redClr)
//         if close > tVal
//             box.set_bgcolor(boxId, transGreenClr)
//             box.set_border_color(boxId, greenClr)

//PLOTS
plotshape(downFractal ,style=shape.triangleup, location=location.belowbar, offset=-n, color=color.new(color.gray,80), size = size.tiny)
plotshape(upFractal, style=shape.triangledown,   location=location.abovebar, offset=-n, color=color.new(color.gray,80), size = size.tiny)

// --- Checklist Table ---
// var table checklistTable = table.new(position.bottom_right, 2, 8, bgcolor=color.new(color.gray, 80), border_width=1)

// if barstate.islast
//     table.cell(checklistTable, 0, 0, "Condition", text_color=color.white, text_size=size.small, bgcolor=color.teal)
//     table.cell(checklistTable, 1, 0, "Status", text_color=color.white, text_size=size.small, bgcolor=color.teal)

//     table.cell(checklistTable, 0, 1, "Up Fractal", text_size=size.small)
//     table.cell(checklistTable, 1, 1, upFractal ? "✅" : "❌", text_color=upFractal ? color.green : color.red, text_size=size.small)

//     table.cell(checklistTable, 0, 2, "Down Fractal", text_size=size.small)
//     table.cell(checklistTable, 1, 2, downFractal ? "✅" : "❌", text_color=downFractal ? color.green : color.red, text_size=size.small)

//     table.cell(checklistTable, 0, 3, "Top Break", text_size=size.small)
//     table.cell(checklistTable, 1, 3, isLongBreak ? "✅" : "❌", text_color=isLongBreak ? color.green : color.red, text_size=size.small)

//     table.cell(checklistTable, 0, 4, "Bottom Break", text_size=size.small)
//     table.cell(checklistTable, 1, 4, isShortBreak ? "✅" : "❌", text_color=isShortBreak ? color.green : color.red, text_size=size.small)

//     table.cell(checklistTable, 0, 5, "Last Red Candle", text_size=size.small)
//     table.cell(checklistTable, 1, 5, close < open ? "✅" : "❌", text_color=close < open ? color.green : color.red, text_size=size.small)

//     table.cell(checklistTable, 0, 6, "Last Green Candle", text_size=size.small)
//     table.cell(checklistTable, 1, 6, close > open ? "✅" : "❌", text_color=close > open ? color.green : color.red, text_size=size.small)

//     table.cell(checklistTable, 0, 7, "Box Color Change Active", text_size=size.small)
//     table.cell(checklistTable, 1, 7, changeColor ? "✅" : "❌", text_color=changeColor ? color.green : color.red, text_size=size.small)