
यह रणनीति सापेक्ष शक्ति सूचकांक (RSI) पर आधारित एक ट्रेंड रिवर्सल ट्रेडिंग सिस्टम है। यह ओवरबॉट और ओवरसोल्ड रेंज सेट करके बाजार के टर्निंग पॉइंट को कैप्चर करता है, और जोखिम नियंत्रण के लिए ATR डायनेमिक स्टॉप लॉस को जोड़ता है। इस रणनीति की विशिष्टता “निषिद्ध व्यापार सीमा” की अवधारणा की शुरूआत में निहित है, जो अस्थिर बाजार में बार-बार व्यापार करने से प्रभावी रूप से बचाती है। यह रणनीति अधिक अस्थिरता वाले बाजार परिवेशों के लिए उपयुक्त है, विशेष रूप से स्पष्ट प्रवृत्ति विशेषताओं वाले उत्पादों के व्यापार के लिए।
यह रणनीति मुख्यतः निम्नलिखित मूल तर्क के आधार पर क्रियान्वित की जाती है:
यह रणनीति आरएसआई रिवर्सल सिग्नल और निषिद्ध ट्रेडिंग रेंज के अभिनव संयोजन के माध्यम से ट्रेंड ट्रेडिंग में टाइमिंग की समस्या को हल करती है। एटीआर डायनेमिक स्टॉप लॉस की शुरूआत रणनीति के लिए एक विश्वसनीय जोखिम नियंत्रण तंत्र प्रदान करती है। यद्यपि रणनीति में अभी भी कुछ संभावित जोखिम हैं, लेकिन अनुशंसित अनुकूलन निर्देशों के माध्यम से रणनीति की स्थिरता और लाभप्रदता को और बेहतर बनाया जा सकता है। कुल मिलाकर, यह स्पष्ट तर्क और मजबूत व्यावहारिकता के साथ एक प्रवृत्ति उलट ट्रेडिंग रणनीति है।
/*backtest
start: 2024-12-19 00:00:00
end: 2024-12-26 00:00:00
period: 2h
basePeriod: 2h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=5
strategy("RSI-Based Trading Strategy with No Trading Zone and ATR Stop Loss", overlay=true)
// Input parameters
rsiPeriod = input(14, title="RSI Period")
rsiOverbought = input(60, title="RSI Overbought Level")
rsiOversold = input(40, title="RSI Oversold Level")
rsiExitBuy = input(45, title="RSI Exit Buy Level")
rsiExitSell = input(55, title="RSI Exit Sell Level")
atrPeriod = input(14, title="ATR Period")
atrMultiplier = input(1.5, title="ATR Stop Loss Multiplier")
// Calculate RSI and ATR
rsi = ta.rsi(close, rsiPeriod)
atr = ta.atr(atrPeriod)
// Buy conditions
buyCondition = ta.crossover(rsi, rsiOverbought) and close > high[1]
if (buyCondition and not strategy.position_size)
stopLossLevel = close - atr * atrMultiplier
strategy.entry("Buy", strategy.long, stop=stopLossLevel)
// Exit conditions for buy
exitBuyCondition = rsi < rsiExitBuy
if (exitBuyCondition and strategy.position_size > 0)
strategy.close("Buy")
// Sell conditions
sellCondition = ta.crossunder(rsi, rsiOversold) and close < low[1]
if (sellCondition and not strategy.position_size)
stopLossLevel = close + atr * atrMultiplier
strategy.entry("Sell", strategy.short, stop=stopLossLevel)
// Exit conditions for sell
exitSellCondition = rsi > rsiExitSell
if (exitSellCondition and strategy.position_size < 0)
strategy.close("Sell")
// Plotting RSI for visualization
hline(rsiOverbought, "Overbought", color=color.red)
hline(rsiOversold, "Oversold", color=color.green)
hline(rsiExitBuy, "Exit Buy", color=color.blue)
hline(rsiExitSell, "Exit Sell", color=color.orange)
plot(rsi, title="RSI", color=color.purple)
// // No Trading Zone
// var box noTradingZone = na
// // Create a rectangle for the no trading zone
// if (rsi >= rsiExitBuy and rsi <= rsiExitSell)
// // If the no trading zone box does not exist, create it
// if (na(noTradingZone))
// noTradingZone := box.new(bar_index, high, bar_index + 1, low, bgcolor=color.new(color.gray, 90), border_color=color.new(color.gray, 90))
// else
// // Update the existing box to cover the current candle
// box.set_left(noTradingZone, bar_index)
// box.set_right(noTradingZone, bar_index + 1)
// box.set_top(noTradingZone, high)
// box.set_bottom(noTradingZone, low)
// else
// // If the RSI is outside the no trading zone, delete the box
// if (not na(noTradingZone))
// box.delete(noTradingZone)
// noTradingZone := na