
Стратегия представляет собой количественную торговую систему, объединяющую Гаусский канал и случайный относительно слабый индикатор Stochastic RSI. Стратегия используется для того, чтобы выявлять возможности рыночного обратного тренда, отслеживая пересечения цены с Гаусским каналом и движение случайного RSI. Гаусский канал, построенный из движущихся средних и стандартных отклонений, динамически отражает диапазон колебаний рынка, в то время как случайный RSI обеспечивает подтверждающий сигнал динамики.
Основная логика стратегии включает в себя следующие ключевые части:
Эта стратегия, в сочетании с отслеживанием тенденций и динамическими показателями в техническом анализе, создает логически целостную, управляемую рисками, количественную торговую систему. Несмотря на некоторые присущие риски, благодаря постоянной оптимизации и усовершенствованию стратегия может стабильно работать в различных рыночных условиях. Модульная конструкция стратегии также обеспечивает хорошую основу для последующей оптимизации и расширения.
/*backtest
start: 2024-02-21 00:00:00
end: 2025-02-18 08:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Binance","currency":"BNB_USDT"}]
*/
//@version=5
strategy("SAJJAD JAMSHIDI Channel with Stochastic RSI Strategy", overlay=true, commission_type=strategy.commission.percent, commission_value=0.1, slippage=0, default_qty_type=strategy.percent_of_equity, default_qty_value=100, process_orders_on_close=true)
// Gaussian Channel Inputs
lengthGC = input.int(20, "Gaussian Channel Length", minval=1)
multiplier = input.float(2.0, "Standard Deviation Multiplier", minval=0.1)
// Calculate Gaussian Channel
basis = ta.ema(close, lengthGC)
deviation = multiplier * ta.stdev(close, lengthGC)
upperChannel = basis + deviation
lowerChannel = basis - deviation
// Plot Gaussian Channel
plot(basis, "Basis", color=color.blue)
plot(upperChannel, "Upper Channel", color=color.green)
plot(lowerChannel, "Lower Channel", color=color.red)
// Stochastic RSI Inputs
rsiLength = input.int(14, "RSI Length", minval=1)
stochLength = input.int(14, "Stochastic Length", minval=1)
smoothK = input.int(3, "Smooth K", minval=1)
smoothD = input.int(3, "Smooth D", minval=1)
// Calculate RSI
rsi = ta.rsi(close, rsiLength)
// Calculate Stochastic RSI
lowestRSI = ta.lowest(rsi, stochLength)
highestRSI = ta.highest(rsi, stochLength)
stochRSI = (rsi - lowestRSI) / (highestRSI - lowestRSI) * 100
k = ta.sma(stochRSI, smoothK)
d = ta.sma(k, smoothD)
// Trading Conditions
stochUp = k > d
priceAboveUpper = ta.crossover(close, upperChannel)
priceBelowUpper = ta.crossunder(close, upperChannel)
strategy.entry("Long", strategy.long, when=priceAboveUpper and stochUp)
strategy.close("Long", when=priceBelowUpper)