
আরএসআই ডাবল-এক্সেল বিভাজন পরিমাণ কৌশলটি একটি উচ্চতর ট্রেডিং কৌশল যা দামের ক্রিয়াকলাপ এবং অপেক্ষাকৃত শক্তিশালী সূচক ((আরএসআই) এর মধ্যে নিয়মিত উত্সাহী এবং পতনের বিভাজন সনাক্ত করে সম্ভাব্য বিপরীতমুখী সুযোগগুলি সনাক্ত করে। এই কৌশলটি একটি স্বয়ংক্রিয় এক্সেল পয়েন্ট সনাক্তকরণ অ্যালগরিদম ব্যবহার করে, দুটি ভিন্ন স্টপ লস / স্টপ ম্যানেজমেন্ট পদ্ধতির সমন্বয় করে এবং বিভাজন সংকেত নিশ্চিত হওয়ার পরে স্বয়ংক্রিয়ভাবে অবস্থান স্থাপন করে। কৌশলটির মূলটি হল মূল্য এবং আরএসআই সূচকগুলির মধ্যে সঠিক গাণিতিক গণনার মাধ্যমে বিভাজন প্রমাণিত হওয়া এবং গতিশীল ঝুঁকি ব্যবস্থাপনার পদ্ধতিটি নিশ্চিত করে যে প্রতিটি লেনদটি পূর্বাভাসিত ঝুঁকি-ফিরেট অনুপাত অনুসরণ করে।
RSI ডাবল-এক্সাস বিপরীত পরিমাণ কৌশলটি একটি কাঠামোগত বিপরীত চিহ্নিতকরণ এবং কঠোর ঝুঁকি ব্যবস্থাপনার মাধ্যমে একটি কাঠামোগত বিপরীত ট্রেডিং পদ্ধতি সরবরাহ করে। এর মূল মূল্য হ’ল traditionalতিহ্যবাহী প্রযুক্তিগত বিশ্লেষণের ধারণাগুলিকে পরিমাপযোগ্য ট্রেডিং নিয়মগুলিতে রূপান্তর করা এবং দ্বি-মডেল স্টপ লস মেশিনের মাধ্যমে বিভিন্ন বাজার পরিবেশের সাথে খাপ খাইয়ে নেওয়া। কৌশলটির দুর্দান্ত পারফরম্যান্সের জন্য তিনটি মূল উপাদান প্রয়োজনঃ যথাযথ প্যারামিটার অপ্টিমাইজেশন, কঠোর ঝুঁকি নিয়ন্ত্রণ এবং ধারাবাহিক প্রয়োগের শৃঙ্খলা। এই কৌশলটি বিশেষত বাজারের পরিবেশের জন্য উপযুক্ত, যেখানে কিছুটা অস্থিরতা রয়েছে তবে প্রবণতা চরম নয়, মধ্যবিত্ত ব্যবসায়ীদের জন্য একটি দুর্দান্ত মডেল।
/*backtest
start: 2024-04-25 00:00:00
end: 2025-04-23 08:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Futures_Binance","currency":"DOGE_USDT"}]
*/
//@version=6
strategy("RSI Divergence Strategy - AliferCrypto", overlay=true, default_qty_type=strategy.percent_of_equity, default_qty_value=10)
// === RSI Settings ===
rsiLength = input.int(14, minval=1, title="RSI Length", group="RSI Settings", tooltip="Number of periods for RSI calculation")
rsiSource = input.source(close, title="RSI Source", group="RSI Settings", tooltip="Price source used for RSI calculation")
// === Divergence Settings ===
lookLeft = input.int(5, minval=1, title="Pivot Lookback Left", group="Divergence Settings", tooltip="Bars to the left for pivot detection")
lookRight = input.int(5, minval=1, title="Pivot Lookback Right", group="Divergence Settings", tooltip="Bars to the right for pivot detection")
rangeLower = input.int(5, minval=1, title="Min Bars Between Pivots", group="Divergence Settings", tooltip="Minimum bars between pivots to validate divergence")
rangeUpper = input.int(60, minval=1, title="Max Bars Between Pivots", group="Divergence Settings", tooltip="Maximum bars between pivots to validate divergence")
// === SL/TP Method ===
method = input.string("Swing", title="SL/TP Method", options=["Swing", "ATR"], group="SL/TP Settings", tooltip="Choose between swing-based or ATR-based stop and target")
// === Swing Settings ===
swingLook = input.int(20, minval=1, title="Swing Lookback (bars)", group="Swing Settings", tooltip="Bars to look back for swing high/low")
swingMarginPct = input.float(1.0, minval=0.0, title="Swing Margin (%)", group="Swing Settings", tooltip="Margin around swing levels as percentage of price")
rrSwing = input.float(2.0, title="R/R Ratio (Swing)", group="Swing Settings", tooltip="Risk/reward ratio when using swing-based method")
// === ATR Settings ===
atrLen = input.int(14, minval=1, title="ATR Length", group="ATR Settings", tooltip="Number of periods for ATR calculation")
atrMult = input.float(1.5, minval=0.1, title="ATR SL Multiplier", group="ATR Settings", tooltip="Multiplier for ATR-based stop loss calculation")
rrAtr = input.float(2.0, title="R/R Ratio (ATR)", group="ATR Settings", tooltip="Risk/reward ratio when using ATR-based method")
// === RSI Calculation ===
_d = ta.change(rsiSource)
up = ta.rma(math.max(_d, 0), rsiLength)
down = ta.rma(-math.min(_d, 0), rsiLength)
rsi = down == 0 ? 100 : up == 0 ? 0 : 100 - (100 / (1 + up / down))
// === Divergence Detection ===
defPl = not na(ta.pivotlow(rsi, lookLeft, lookRight))
defPh = not na(ta.pivothigh(rsi, lookLeft, lookRight))
rsiAtRR = rsi[lookRight]
barsPl = ta.barssince(defPl)
barsPl1 = barsPl[1]
inRangePL = barsPl1 >= rangeLower and barsPl1 <= rangeUpper
barsPh = ta.barssince(defPh)
barsPh1 = barsPh[1]
inRangePH = barsPh1 >= rangeLower and barsPh1 <= rangeUpper
prevPlRsi = ta.valuewhen(defPl, rsiAtRR, 1)
prevPhRsi = ta.valuewhen(defPh, rsiAtRR, 1)
prevPlPrice = ta.valuewhen(defPl, low[lookRight], 1)
prevPhPrice = ta.valuewhen(defPh, high[lookRight], 1)
bullCond = defPl and low[lookRight] < prevPlPrice and rsiAtRR > prevPlRsi and inRangePL
bearCond = defPh and high[lookRight] > prevPhPrice and rsiAtRR < prevPhRsi and inRangePH
plotshape(bullCond, title="Bullish Divergence", style=shape.triangleup, location=location.belowbar, color=color.green, size=size.tiny)
plotshape(bearCond, title="Bearish Divergence", style=shape.triangledown, location=location.abovebar, color=color.red, size=size.tiny)
// === Entries ===
if bullCond
strategy.entry("Long", strategy.long)
if bearCond
strategy.entry("Short", strategy.short)
// === Pre-calculate SL/TP components ===
swingLow = ta.lowest(low, swingLook)
swingHigh = ta.highest(high, swingLook)
atrValue = ta.atr(atrLen)
// === SL/TP Calculation & Exits ===
var float slPrice = na
var float tpPrice = na
var float rr = na
// Long exits
if strategy.position_size > 0
entryPrice = strategy.position_avg_price
if method == "Swing"
slPrice := swingLow * (1 - swingMarginPct / 100)
rr := rrSwing
else
slPrice := entryPrice - atrValue * atrMult
rr := rrAtr
risk = entryPrice - slPrice
tpPrice := entryPrice + risk * rr
strategy.exit("Exit Long", from_entry="Long", stop=slPrice, limit=tpPrice)
// Short exits
if strategy.position_size < 0
entryPrice = strategy.position_avg_price
if method == "Swing"
slPrice := swingHigh * (1 + swingMarginPct / 100)
rr := rrSwing
else
slPrice := entryPrice + atrValue * atrMult
rr := rrAtr
risk = slPrice - entryPrice
tpPrice := entryPrice - risk * rr
strategy.exit("Exit Short", from_entry="Short", stop=slPrice, limit=tpPrice)
// === Plot SL/TP Levels ===
plot(strategy.position_size != 0 ? slPrice : na, title="Stop Loss", style=plot.style_linebr, color=color.red)
plot(strategy.position_size != 0 ? tpPrice : na, title="Take Profit", style=plot.style_linebr, color=color.green)
// === Alerts ===
alertcondition(bullCond, title="Bull RSI Divergence", message="Bullish RSI divergence detected")
alertcondition(bearCond, title="Bear RSI Divergence", message="Bearish RSI divergence detected")