
এই কৌশলটি একটি পরিমাণগত ট্রেডিং সিস্টেম যা গাউসিয়ান চ্যানেল এবং একটি এলোমেলো অপেক্ষাকৃত দুর্বল সূচক স্টোক্যাস্টিক আরএসআইয়ের সাথে মিলিত। এই কৌশলটি বাজারের ট্রেন্ড রিভার্সনের সুযোগগুলিকে গাউসিয়ান চ্যানেলের সাথে ক্রস এবং এলোমেলো আরএসআইয়ের গতিবিধি পর্যবেক্ষণ করে। গাউসিয়ান চ্যানেলটি একটি চলমান গড় এবং স্ট্যান্ডার্ড ডিভেরিয়েন্ট দ্বারা নির্মিত, যা বাজারের ওঠানামাকে গতিশীলভাবে প্রতিফলিত করে, যখন এলোমেলো আরএসআই গতিশীলতার দিক থেকে নিশ্চিতকরণ সংকেত সরবরাহ করে।
কৌশলটির মূল যুক্তিতে নিম্নলিখিত মূল অংশগুলি অন্তর্ভুক্ত রয়েছে:
কৌশলটি প্রযুক্তিগত বিশ্লেষণে প্রবণতা ট্র্যাকিং এবং গতিশীলতার সূচকগুলির সাথে মিলিত হয়ে একটি যৌক্তিকভাবে সম্পূর্ণ, ঝুঁকি-নিয়ন্ত্রিত পরিমাণগত ট্রেডিং সিস্টেম তৈরি করে। যদিও কিছু অন্তর্নিহিত ঝুঁকি রয়েছে, তবে ক্রমাগত অপ্টিমাইজেশন এবং পরিমার্জনের মাধ্যমে কৌশলটি বিভিন্ন বাজারের পরিবেশে স্থিতিশীল পারফরম্যান্স বজায় রাখার সম্ভাবনা রয়েছে। কৌশলটির মডিউল ডিজাইনটি পরবর্তী অপ্টিমাইজেশন এবং প্রসারণের জন্য একটি ভাল ভিত্তি সরবরাহ করে।
/*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)