Эта стратегия представляет собой 4-часовую временную систему количественного трейдинга, основанную на полосах Боллинджера, сочетающую в себе концепции трейдинга прорыва тренда и среднего реверсии. Стратегия улавливает рыночный импульс через прорывы полос Боллинджера, используя среднее значение реверсии цены для получения прибыли и внедрения стоп-лосса для контроля риска. Она использует 3-кратный рычаг кредитования, обеспечивая доходность при тщательном рассмотрении управления рисками.
Основная логика основана на следующих ключевых элементах: 1. Использует 20-периодную скользящую среднюю в качестве средней полосы, с двумя стандартными отклонениями для диапазона волатильности 2. Входные сигналы: длинные, когда тело свечи (среднее количество открытых и закрытых) прерывается выше верхней полосы, короткие, когда прерывается ниже нижней полосы 3. Сигналы выхода: Закрыть длинные позиции, когда две последовательные свечи имеют как открытые, так и закрытые цены ниже верхней полосы и закрыть ниже открытых; обратная логика для коротких позиций Контроль риска: устанавливает стоп-лосс на текущих высоких/низких точках свечи для обеспечения контролируемых потерь на торговую сделку
Эта стратегия сочетает в себе характеристики Bollinger Bands
/*backtest start: 2019-12-23 08:00:00 end: 2024-12-10 08:00:00 period: 1d basePeriod: 1d exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=5 strategy("Bollinger 4H Follow", overlay=true, initial_capital=300, commission_type=strategy.commission.percent, commission_value=0.04) // StartYear = input(2022,"Backtest Start Year") // StartMonth = input(1,"Backtest Start Month") // StartDay = input(1,"Backtest Start Day") // testStart = timestamp(StartYear,StartMonth,StartDay,0,0) // EndYear = input(2023,"Backtest End Year") // EndMonth = input(12,"Backtest End Month") // EndDay = input(31,"Backtest End Day") // testEnd = timestamp(EndYear,EndMonth,EndDay,0,0) lev = 3 // Input parameters length = input.int(20, title="Bollinger Band Length") mult = input.float(2.0, title="Bollinger Band Multiplier") // Bollinger Bands calculation basis = ta.sma(close, length) upperBand = basis + mult * ta.stdev(close, length) lowerBand = basis - mult * ta.stdev(close, length) // Conditions for Open Long openLongCondition = strategy.position_size == 0 and close > open and (close + open) / 2 > upperBand // Conditions for Open Short openShortCondition = strategy.position_size == 0 and close < open and (close + open) / 2 < lowerBand // Conditions for Close Long closeLongCondition = strategy.position_size > 0 and strategy.position_size > 0 and (close < upperBand and open < upperBand and close < open) // Conditions for Close Short closeShortCondition = strategy.position_size < 0 and strategy.position_size < 0 and (close > lowerBand and open > lowerBand and close > open) // Long entry if openLongCondition strategy.entry("Long", strategy.long, qty=strategy.equity * lev / close) strategy.exit("Long SL", from_entry="Long", stop=low) // Set Stop-Loss // Short entry if openShortCondition strategy.entry("Short", strategy.short, qty=strategy.equity * lev / close) strategy.exit("Short SL", from_entry="Short", stop=high) // Set Stop-Loss // Long exit if closeLongCondition strategy.close("Long", comment = "TP") // Short exit if closeShortCondition strategy.close("Short", comment = "TP") // Plot Bollinger Bands plot(upperBand, color=color.yellow, title="Upper Band") plot(lowerBand, color=color.yellow, title="Lower Band")