यह रणनीति तीन फ्लैट चलती औसत, अपेक्षाकृत मजबूत सूचकांक (आरएसआई) और विलियम सूचकांक के संयोजन के माध्यम से स्टॉक की कीमतों की प्रवृत्ति की दिशा की पहचान करती है, और प्रवृत्ति के उलट होने पर प्रवेश के अवसरों की तलाश करती है। जब तीन धीमी गति से चलती औसत ऊपर (नीचे) संरेखित होते हैं, तो आरएसआई 50 से ऊपर (नीचे) होता है, और नीचे (ऊपर) विलियम सूचकांक संकेत होता है।
इस रणनीति में तीन अलग-अलग चक्रों की स्लाइडिंग मूविंग एवरेज का उपयोग किया जाता है, जिसमें फास्ट लाइन, मिडलाइन और स्लो लाइन शामिल हैं। जब फास्ट लाइन मध्य रेखा को पार करती है, तो शेयर की कीमत एक ऊंची प्रवृत्ति में प्रवेश करती है; जब फास्ट लाइन मध्य रेखा को पार करती है, तो शेयर की कीमत एक नीचे की प्रवृत्ति में प्रवेश करती है। यह निर्धारित करने के बाद कि शेयर की कीमत ऊपर या नीचे की प्रवृत्ति में है, रणनीति पहले व्यापार के अवसर की प्रतीक्षा करती है।
विशेष रूप से, एक बार जब शेयरों की कीमतें बढ़ जाती हैं, तो रणनीति निम्नलिखित पांच शर्तों के पूरा होने तक इंतजार करती है, और फिर अधिक स्थिति खोलने के लिएः
शेयरों की कीमतों में गिरावट के बाद, रणनीति निम्नलिखित पांच शर्तों के एक साथ मिलने का इंतजार करती है, जो कि स्थिति को खोलने से पहले होती हैः
अधिक खोलने के बाद, रणनीति जोखिम को नियंत्रित करने के लिए स्टॉपलॉस और स्टॉपबॉक्स सेट करती है। विशेष रूप से, स्टॉपलॉस प्रवेश मूल्य का एक निश्चित प्रतिशत है, और स्टॉपबॉक्स प्रवेश मूल्य के लाभप्रद दिशा में एक निश्चित प्रतिशत के बाद की कीमत है।
कई संकेतकों के संयोजन से प्रवेश की पुष्टि की जा सकती है, जिससे झूठे ब्रेक को प्रभावी ढंग से रोका जा सकता है। तीन समान रेखाएं प्रवृत्ति की दिशा निर्धारित करती हैं, विलियम संकेतक रिवर्स सिग्नल को पकड़ते हैं, आरएसआई फ़िल्टर उतार-चढ़ाव की स्थिति, एक साथ प्रवेश की सटीकता में सुधार करते हैं।
स्टॉप-स्टॉप-लॉस सेट करें, जो प्रति-प्रदान जोखिम-लाभ अनुपात को अच्छी तरह से नियंत्रित करता है, जिससे यह सुनिश्चित होता है कि लाभदायक ट्रेड घाटे वाले ट्रेडों की तुलना में अधिक हैं।
रणनीति तर्क स्पष्ट और समझने में आसान है, पैरामीटर सेट तर्कसंगत है, और विभिन्न स्तरों के व्यापारियों के लिए उपयुक्त है।
अस्थिर स्थिति में, सूचक गलत संकेत दे सकता है, जिससे अनावश्यक प्रवेश होता है। आरएसआई के पैरामीटर को अनुकूलित करके कुछ अस्थिरता को फ़िल्टर किया जा सकता है।
फास्ट लाइन और मध्य लाइन क्रॉसिंग में झूठी दरारें हो सकती हैं और इसे अन्य संकेतकों के साथ संयोजन में उपयोग किया जाना चाहिए।
स्टॉप लॉस को प्रवेश मूल्य के बहुत करीब रखा जाता है और स्टॉप लॉस को बाहर निकाला जा सकता है। स्टॉप लॉस की सेटिंग को उचित स्थान पर समायोजित करने की आवश्यकता होती है।
प्रवेश मूल्य से बहुत दूर होने पर, प्रवेश और निकास को रोकना संभव नहीं है, और इसे उचित स्थान पर समायोजित करने की आवश्यकता है।
विभिन्न चक्रों के लिए पैरामीटर संयोजनों का परीक्षण करने के लिए, त्रि-मध्य रेखा और आरएसआई के पैरामीटर का अनुकूलन करें।
अन्य संकेतकों को जोड़ा जा सकता है, जैसे कि लेनदेन का सूचक, यह निर्धारित करने के लिए कि क्या लेनदेन ब्रीच से पहले प्रमुख है।
इस रणनीति के लिए पैरामीटर सेटिंग्स को विभिन्न नस्लों के अनुसार परीक्षण किया जा सकता है।
लाभ वक्रों को वापस मापने के परिणामों के आधार पर तैयार किया जा सकता है, स्टॉप-लॉस-स्टॉप पैरामीटर की सेटिंग्स का परीक्षण किया जा सकता है।
आप शुरू करने से पहले अनुकरण ट्रेडिंग का प्रयास कर सकते हैं, पैरामीटर सेटिंग को अनुकूलित कर सकते हैं।
इस रणनीति के लिए समग्र तर्क स्पष्ट है, सूचक संयोजन का उपयोग करने के लिए प्रवेश और बाहर निकलने के लिए, जोखिम को प्रभावी ढंग से नियंत्रित कर सकते हैं. रणनीति के पैरामीटर अनुकूलन के लिए जगह बहुत बड़ी है, विभिन्न पैरामीटर सेटिंग्स का परीक्षण करके, इस रणनीति एक स्थिर लाभ के लिए एक मात्रात्मक व्यापार रणनीति बन सकता है. लेकिन किसी भी रणनीति पूरी तरह से नुकसान से बचने के लिए नहीं कर सकते हैं, व्यापारियों को व्यापार अनुशासन बनाए रखने की आवश्यकता है, लाभ के लिए बंद करो, नुकसान के लिए बंद करो.
/*backtest
start: 2023-08-28 00:00:00
end: 2023-09-27 00:00:00
period: 3h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//This script is a combination of 3 smoothed moving averages, and RSI. When moving averages are aligned upward (downward) and RSI is above (below) 50 and a down (up) William fractal appears, it enters long (short) position. Exiting from long and short entries are defined by StopLoss and TargetProfit.
//@version=5
strategy(title="3SmmaCrossUp + Fractal + RSI", overlay=true, default_qty_type=strategy.percent_of_equity, default_qty_value=100, currency=currency.USD, commission_type=strategy.commission.percent, commission_value=0.03)
///////////////////////////////////////////////////////////////////////////////////////////////////////////////// inputs
// Global
src = input(close, title="Source")
stopLoss = input.float(defval = 0.1, title = "Stop Loss %", minval = 0, maxval=100, step = 0.1)
targetProfit = input.float(defval = 0.4, title = "Target Profit %", minval = 0, maxval=100, step = 0.1)
// Smooth Moving Average
fastSmmaLen = input.int(21, minval=1, title="Fast Length", group = "Smooth Moving Average")
midSmmaLen = input.int(50, minval=1, title="Mid Length",group = "Smooth Moving Average")
slowSmmaLen = input.int(200, minval=1, title="Slow Length",group = "Smooth Moving Average")
// RSI
rsiLen = input.int(defval=14, title="length", minval=1, maxval=1000, step=1, group="RSI")
// Fractals
n = input.int(title="Periods", defval=2, minval=2, group = "Fractals")
///////////////////////////////////////////////////////////////////////////////////////////////////////////////// initialization
var waitingFirstTradeInUpwardTrend = false
var waitingFirstTradeInDownwardTrend = false
///////////////////////////////////////////////////////////////////////////////////////////////////////////////// functions
smma(ma, src, len) =>
smma = 0.0
smma := na(smma[1]) ? ma : (smma[1] * (len - 1) + src) / len
smma
fractals(n, highs, lows) =>
// UpFractal
bool upflagDownFrontier = true
bool upflagUpFrontier0 = true
bool upflagUpFrontier1 = true
bool upflagUpFrontier2 = true
bool upflagUpFrontier3 = true
bool upflagUpFrontier4 = true
for i = 1 to n
upflagDownFrontier := upflagDownFrontier and (highs[n-i] < highs[n])
upflagUpFrontier0 := upflagUpFrontier0 and (highs[n+i] < highs[n])
upflagUpFrontier1 := upflagUpFrontier1 and (highs[n+1] <= highs[n] and highs[n+i + 1] < highs[n])
upflagUpFrontier2 := upflagUpFrontier2 and (highs[n+1] <= highs[n] and highs[n+2] <= highs[n] and highs[n+i + 2] < highs[n])
upflagUpFrontier3 := upflagUpFrontier3 and (highs[n+1] <= highs[n] and highs[n+2] <= highs[n] and highs[n+3] <= highs[n] and highs[n+i + 3] < highs[n])
upflagUpFrontier4 := upflagUpFrontier4 and (highs[n+1] <= highs[n] and highs[n+2] <= highs[n] and highs[n+3] <= highs[n] and highs[n+4] <= highs[n] and highs[n+i + 4] < highs[n])
flagUpFrontier = upflagUpFrontier0 or upflagUpFrontier1 or upflagUpFrontier2 or upflagUpFrontier3 or upflagUpFrontier4
upFractal = (upflagDownFrontier and flagUpFrontier)
// downFractal
bool downflagDownFrontier = true
bool downflagUpFrontier0 = true
bool downflagUpFrontier1 = true
bool downflagUpFrontier2 = true
bool downflagUpFrontier3 = true
bool downflagUpFrontier4 = true
for i = 1 to n
downflagDownFrontier := downflagDownFrontier and (lows[n-i] > lows[n])
downflagUpFrontier0 := downflagUpFrontier0 and (lows[n+i] > lows[n])
downflagUpFrontier1 := downflagUpFrontier1 and (lows[n+1] >= lows[n] and lows[n+i + 1] > lows[n])
downflagUpFrontier2 := downflagUpFrontier2 and (lows[n+1] >= lows[n] and lows[n+2] >= lows[n] and lows[n+i + 2] > lows[n])
downflagUpFrontier3 := downflagUpFrontier3 and (lows[n+1] >= lows[n] and lows[n+2] >= lows[n] and lows[n+3] >= lows[n] and lows[n+i + 3] > lows[n])
downflagUpFrontier4 := downflagUpFrontier4 and (lows[n+1] >= lows[n] and lows[n+2] >= lows[n] and lows[n+3] >= lows[n] and lows[n+4] >= lows[n] and lows[n+i + 4] > lows[n])
flagDownFrontier = downflagUpFrontier0 or downflagUpFrontier1 or downflagUpFrontier2 or downflagUpFrontier3 or downflagUpFrontier4
downFractal = (downflagDownFrontier and flagDownFrontier)
[upFractal, downFractal]
///////////////////////////////////////////////////////////////////////////////////////////////////////////////// calcs
[upFractal, downFractal] = fractals(n, high, low)
rsiIsHigh = ta.rsi(src, rsiLen) >= 50
slowMa = ta.sma(src, slowSmmaLen)
midMa = ta.sma(src, midSmmaLen)
fastMa = ta.sma(src, fastSmmaLen)
slowSmma = smma(slowMa ,src, slowSmmaLen)
midSmma = smma(midMa, src, midSmmaLen)
fastSmma = smma(fastMa, src, fastSmmaLen)
isFastSmmaUpward = ta.rising(fastSmma, 1)
isMidSmmaUpward = ta.rising(midSmma, 1)
isSlowSmmaUpward = ta.rising(slowSmma, 1)
isFastSmmaDownward = ta.falling(fastSmma, 1)
isMidSmmaDownward = ta.falling(midSmma, 1)
isSlowSmmaDownward = ta.falling(slowSmma, 1)
slowMovingAveragesAreUpward = isMidSmmaUpward and isSlowSmmaUpward
slowMovingAveragesAreDownward = isMidSmmaDownward and isSlowSmmaDownward
justEnteredUpwardTrend = ta.crossover(fastSmma, midSmma) ? true : false
justEnteredDownwardTrend = ta.crossunder(fastSmma, midSmma) ? true : false
waitingFirstTradeInUpwardTrend := justEnteredUpwardTrend == true ? true : (isFastSmmaDownward or isMidSmmaDownward or isSlowSmmaDownward ? false : waitingFirstTradeInUpwardTrend)
waitingFirstTradeInDownwardTrend := justEnteredDownwardTrend == true ? true : (isFastSmmaUpward or isMidSmmaUpward or isSlowSmmaUpward ? false : waitingFirstTradeInDownwardTrend)
priceCrossedOverSlowMa = ta.crossover(close, slowSmma)
priceCrossedUnderSlowMa = ta.crossunder(close, slowSmma)
enterLongCondition = barstate.isconfirmed and low > fastSmma and rsiIsHigh and (downFractal or priceCrossedOverSlowMa) and waitingFirstTradeInUpwardTrend and strategy.position_size == 0
enterShortCondition = barstate.isconfirmed and high < fastSmma and (not rsiIsHigh) and (upFractal or priceCrossedUnderSlowMa) and waitingFirstTradeInDownwardTrend and strategy.position_size == 0
///////////////////////////////////////////////////////////////////////////////////////////////////////////////// strategy
if(enterLongCondition)
strategy.entry(id="L", direction=strategy.long)
waitingFirstTradeInUpwardTrend := false
if(enterShortCondition)
strategy.entry(id="S", direction=strategy.short)
waitingFirstTradeInDownwardTrend := false
if(strategy.position_size > 0)
strategy.exit(id="EL", stop=strategy.position_avg_price * (1 - stopLoss/100), limit=strategy.position_avg_price * (1+targetProfit/100))
if(strategy.position_size < 0)
strategy.exit(id="ES", stop=strategy.position_avg_price * (1 + stopLoss/100), limit=strategy.position_avg_price * (1-targetProfit/100))
///////////////////////////////////////////////////////////////////////////////////////////////////////////////// plots
plot(series = slowSmma, title="Slow SMMA", linewidth=3)
plot(series = midSmma, title="Mid SMMA", linewidth=2)
plot(series = fastSmma, title="Fast SMMA", linewidth=1)
plotchar(series=rsiIsHigh, title='rsiIsHigh', char='')
plotchar(series=justEnteredUpwardTrend, title='justEnteredUpwardTrend', char='')
plotchar(series=justEnteredDownwardTrend, title='justEnteredDownwardTrend', char='')
plotchar(series=waitingFirstTradeInUpwardTrend, title='waitingFirstTradeInUpwardTrend', char='')
plotchar(series=waitingFirstTradeInDownwardTrend, title='waitingFirstTradeInDownwardTrend', char='')
plotchar(series=enterLongCondition, title='enterLongCondition' , char='')
plotchar(series=enterShortCondition, title='enterShortCondition' , char='')
plotshape(series=upFractal, title='upFractal', style=shape.triangleup, location=location.abovebar, color=#009688, size = size.tiny)
plotshape(series=downFractal, title='downFractal', style=shape.triangledown, location=location.belowbar, color=color.red, size = size.tiny)