Стратегия двойных индикаторов стохастического импульса

Автор:Чао Чжан, Дата: 2023-10-07 16:45:25
Тэги:

Обзор

Эта стратегия использует двойные индикаторы стохастического импульса (SMI и RSI) для длинных и коротких сигналов, а также мартингейл и телесный фильтр для выбора торговых сигналов, целью которых является фиксация среднесрочных тенденций и колебаний цен.

Логика стратегии

Стратегия оценивает длинный и короткий с использованием двух стохастических индикаторов SMI и RSI. SMI рассчитывается на основе скользящей средней диапазоны бар и ценовой шкалы, хорошей для определения точек перелома. RSI сравнивает силу быка и медведя для определения состояния перекупленности и перепроданности. Стратегия длится, когда SMI ниже -50 и RSI ниже 20; коротко, когда SMI выше 50 и RSI выше 80.

Для фильтрации ложных прорывов стратегия также использует 1/3 10-периодного тела SMA в качестве условия фильтра прорыва.

Кроме того, стратегия использует необязательный мартингейл, который заключается в увеличении лота на проигрышных сделках, пытаясь восстановить предыдущие потери.

Функциональность Backtest проверяет стратегию путем ввода диапазона дат.

Анализ преимуществ

Стратегия сочетает в себе двойные стохастические индикаторы и фильтры, способные эффективно выявлять точки переворота, фиксировать среднесрочные тенденции и отслеживать колебания цен.

  • SMI обладает высокой способностью распознавать точки перелома и может эффективно определять условия перекупки и перепродажи.
  • Добавление RSI позволяет избежать пропуска торгов.
  • Фильтр тела устраняет ложные прорывы и улучшает точность сигнала.
  • Опциональная стратегия мартингейла позволяет восстановить часть потерь.

Анализ рисков

  • Как отстающие показатели, SMI и RSI имеют риск преследования максимумов и уничтожения минимумов.
  • Мартингейл несет в себе риск ускорения потерь.
  • Фильтры могут отфильтровывать некоторые действительные сигналы на различных рынках.

Риски могут быть смягчены путем оптимизации параметров SMI и RSI для снижения вероятности преследования/убийства, стратегического использования мартингейла путем контроля соотношения масштабирования и времени и возможности дискреционных фильтров на основе рыночных условий.

Руководство по оптимизации

  • Оптимизировать параметры SMI и RSI для наилучшей эффективности суждения.
  • Регулировать параметры фильтра для снижения вероятности фильтрации действительных сигналов.
  • Оптимизируйте время и соотношение масштабирования мартингейла.
  • Включайте индикаторы тренда, чтобы избежать торговли против тренда.
  • Добавьте стоп-лосс для ограничения потерь на одиночных сделках.

Резюме

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


/*backtest
start: 2022-09-30 00:00:00
end: 2023-10-06 00:00:00
period: 2d
basePeriod: 1d
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=2
// strategy(title = "CS Basic Scripts - Stochastic Special (Strategy)", shorttitle = "Stochastic Special", overlay = false, default_qty_type = strategy.percent_of_equity, default_qty_value = 100, pyramiding = 0)

//Settings 
needlong = input(true, defval = true, title = "Long")
needshort = input(true, defval = true, title = "Short")
usemar = input(false, defval = false, title = "Use Martingale")
capital = input(100, defval = 100, minval = 1, maxval = 10000, title = "Capital, %")
usesmi = input(true, defval = true, title = "Use SMI Strategy")
usersi = input(true, defval = true, title = "Use RSI Strategy")
usebod = input(true, defval = true, title = "Use Body-Filter")
a = input(5, "SMI Percent K Length")
b = input(3, "SMI Percent D Length")
limit = input(50, defval = 50, minval = 1, maxval = 100, title = "SMI Limit")

//Backtesting Input Range
fromyear = input(2017, defval = 2017, minval = 1900, maxval = 2100, title = "From Year")
toyear = input(2100, defval = 2100, minval = 1900, maxval = 2100, title = "To Year")
frommonth = input(01, defval = 01, minval = 01, maxval = 12, title = "From Month")
tomonth = input(12, defval = 12, minval = 01, maxval = 12, title = "To Month")
fromday = input(01, defval = 01, minval = 01, maxval = 31, title = "From day")
today = input(31, defval = 31, minval = 01, maxval = 31, title = "To day")

//Fast RSI
fastup = rma(max(change(close), 0), 7)
fastdown = rma(-min(change(close), 0), 7)
fastrsi = fastdown == 0 ? 100 : fastup == 0 ? 0 : 100 - (100 / (1 + fastup / fastdown))

//Stochastic Momentum Index
ll = lowest (low, a)
hh = highest (high, a)
diff = hh - ll
rdiff = close - (hh+ll)/2
avgrel = ema(ema(rdiff,b),b)
avgdiff = ema(ema(diff,b),b)
SMI = avgdiff != 0 ? (avgrel/(avgdiff/2)*100) : 0
SMIsignal = ema(SMI,b)

//Lines
plot(SMI, color = blue, linewidth = 3, title = "Stochastic Momentum Index")
plot(SMIsignal, color = red, linewidth = 3, title = "SMI Signal Line")
plot(limit, color = black, title = "Over Bought")
plot(-1 * limit, color = black, title = "Over Sold")
plot(0, color = blue, title = "Zero Line")

//Body Filter
nbody = abs(close - open)
abody = sma(nbody, 10)
body = nbody > abody / 3 or usebod == false

//Signals
up1 = SMI < -1 * limit and close < open and body and usesmi
dn1 = SMI > limit and close > open and body and usesmi
up2 = fastrsi < 20 and close < open and body and usersi
dn2 = fastrsi > 80 and close > open and body and usersi
exit = ((strategy.position_size > 0 and close > open) or (strategy.position_size < 0 and close < open)) and body

//Trading
profit = exit ? ((strategy.position_size > 0 and close > strategy.position_avg_price) or (strategy.position_size < 0 and close < strategy.position_avg_price)) ? 1 : -1 : profit[1]
mult = usemar ? exit ? profit == -1 ? mult[1] * 2 : 1 : mult[1] : 1
lot = strategy.position_size == 0 ? strategy.equity / close * capital / 100 * mult : lot[1]

if up1 or up2
    if strategy.position_size < 0
        strategy.close_all()
        
    strategy.entry("long", strategy.long, needlong == false ? 0 : lot, when=(time > timestamp(fromyear, frommonth, fromday, 00, 00) and time < timestamp(toyear, tomonth, today, 23, 59)))

if dn1 or dn2
    if strategy.position_size > 0
        strategy.close_all()
        
    strategy.entry("Short", strategy.short, needshort == false ? 0 : lot, when=(time > timestamp(fromyear, frommonth, fromday, 00, 00) and time < timestamp(toyear, tomonth, today, 23, 59)))
    
if time > timestamp(toyear, tomonth, today, 23, 59) or exit
    strategy.close_all()

Больше