यह रणनीति एक ट्रेंड फॉलोइंग सिस्टम है जो ड्यूल मूविंग एवरेज और एमएसीडी इंडिकेटर को जोड़ती है। यह विशिष्ट प्रवेश समय के लिए एमएसीडी इंडिकेटर का उपयोग करते हुए ट्रेंड की दिशा निर्धारित करने के लिए 50-पीरियड और 200-पीरियड मूविंग एवरेज का उपयोग करती है। यह रणनीति गतिशील स्टॉप-लॉस और टेक-प्रॉफिट तंत्र का उपयोग करती है, साथ ही व्यापार की गुणवत्ता को बढ़ाने के लिए कई फ़िल्टरिंग स्थितियों के साथ। यह एक पूर्ण ट्रेडिंग सिस्टम है जो 15 मिनट के समय सीमा पर परिचालन करता है, जिसमें सटीक प्रवेश और निकास नियम हैं।
मूल तर्क कई प्रमुख तत्वों पर आधारित हैः 1. रुझान निर्धारण: समग्र रुझान का न्याय करने के लिए 50MA और 200MA की सापेक्ष स्थिति का उपयोग करता है, जब तेजी से एमए धीमी एमए से ऊपर होता है और डाउनट्रेंड इसके विपरीत होता है तो अपट्रेंड की पुष्टि होती है। 2. प्रवेश संकेतः प्रवृत्ति की पुष्टि के बाद, विशिष्ट प्रवेश संकेतों के लिए एमएसीडी क्रॉसओवर का उपयोग करता है। जब एमएसीडी लाइन अपट्रेंड में सिग्नल लाइन से ऊपर पार करती है तो लंबी होती है; जब एमएसीडी लाइन डाउनट्रेंड में सिग्नल लाइन से नीचे पार करती है तो छोटी होती है। 3. व्यापार फ़िल्टरिंग: अस्थिर बाजार स्थितियों में ओवरट्रेडिंग से बचने के लिए न्यूनतम व्यापार अंतराल, प्रवृत्ति शक्ति और एमएसीडी सीमा सहित कई फ़िल्टरिंग तंत्र शामिल करता है। 4. जोखिम नियंत्रण: गतिशील निकास स्थितियों के रूप में चलती औसत और एमएसीडी रिवर्स संकेतों के साथ संयुक्त, निश्चित बिंदु स्टॉप-लॉस और समायोज्य ले-प्रॉफिट तंत्र का उपयोग करता है।
यह पूरी तरह से तर्क के साथ एक अच्छी तरह से डिज़ाइन की गई प्रवृत्ति ट्रेडिंग प्रणाली है। आधुनिक जोखिम प्रबंधन विधियों के साथ क्लासिक तकनीकी संकेतकों को जोड़कर, रणनीति जोखिम नियंत्रण के साथ प्रवृत्ति कैप्चर को संतुलित करती है। जबकि अनुकूलन के लिए क्षेत्र हैं, यह समग्र रूप से व्यावहारिक रूप से मूल्यवान ट्रेडिंग रणनीति है। व्यापारियों को लाइव कार्यान्वयन से पहले गहन बैकटेस्टिंग करने और विशिष्ट ट्रेडिंग उपकरणों और बाजार वातावरण के अनुसार मापदंडों को समायोजित करने की सलाह दी जाती है।
/*backtest start: 2024-11-12 00:00:00 end: 2024-12-11 08:00:00 period: 1h basePeriod: 1h exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ // This Pine Script™ code is subject to the terms of the Mozilla Public License 2.0 at https://mozilla.org/MPL/2.0/ // © WolfofAlgo //@version=5 strategy("Trend Following Scalping Strategy", overlay=true, initial_capital=10000, default_qty_type=strategy.percent_of_equity, default_qty_value=200) // Input Parameters stopLossPips = input.float(5.0, "Stop Loss in Pips", minval=1.0) takeProfitPips = input.float(10.0, "Take Profit in Pips", minval=1.0) useFixedTakeProfit = input.bool(true, "Use Fixed Take Profit") // Moving Average Parameters fastMA = input.int(50, "Fast MA Period") slowMA = input.int(200, "Slow MA Period") // MACD Parameters macdFastLength = input.int(12, "MACD Fast Length") macdSlowLength = input.int(26, "MACD Slow Length") macdSignalLength = input.int(9, "MACD Signal Length") // Trade Filter Parameters (Adjusted to be less strict) minBarsBetweenTrades = input.int(5, "Minimum Bars Between Trades", minval=1) trendStrengthPeriod = input.int(10, "Trend Strength Period") minTrendStrength = input.float(0.4, "Minimum Trend Strength", minval=0.1, maxval=1.0) macdThreshold = input.float(0.00005, "MACD Threshold", minval=0.0) // Variables for trade management var int barsLastTrade = 0 barsLastTrade := nz(barsLastTrade[1]) + 1 // Calculate Moving Averages ma50 = ta.sma(close, fastMA) ma200 = ta.sma(close, slowMA) // Calculate MACD [macdLine, signalLine, _] = ta.macd(close, macdFastLength, macdSlowLength, macdSignalLength) // Calculate trend strength (simplified) trendDirection = ta.ema(close, trendStrengthPeriod) > ta.ema(close, trendStrengthPeriod * 2) isUptrend = close > ma50 and ma50 > ma200 isDowntrend = close < ma50 and ma50 < ma200 // Calculate pip value pointsPerPip = syminfo.mintick * 10 // Entry Conditions with Less Strict Filters macdCrossUp = ta.crossover(macdLine, signalLine) and math.abs(macdLine - signalLine) > macdThreshold macdCrossDown = ta.crossunder(macdLine, signalLine) and math.abs(macdLine - signalLine) > macdThreshold // Long and Short Conditions longCondition = close > ma50 and macdCrossUp and barsLastTrade >= minBarsBetweenTrades and isUptrend shortCondition = close < ma50 and macdCrossDown and barsLastTrade >= minBarsBetweenTrades and isDowntrend // Exit Conditions (made more lenient) exitLongCondition = macdCrossDown or close < ma50 exitShortCondition = macdCrossUp or close > ma50 // Reset bars counter on new trade if (longCondition or shortCondition) barsLastTrade := 0 // Calculate stop loss and take profit levels longStopPrice = strategy.position_avg_price - (stopLossPips * pointsPerPip) longTakeProfitPrice = strategy.position_avg_price + (takeProfitPips * pointsPerPip) shortStopPrice = strategy.position_avg_price + (stopLossPips * pointsPerPip) shortTakeProfitPrice = strategy.position_avg_price - (takeProfitPips * pointsPerPip) // Plot Moving Averages plot(ma50, "50 MA", color=color.blue) plot(ma200, "200 MA", color=color.red) // Plot Entry Signals plotshape(longCondition, "Long Signal", shape.triangleup, location.belowbar, color.green, size=size.small) plotshape(shortCondition, "Short Signal", shape.triangledown, location.abovebar, color.red, size=size.small) // Strategy Entry Rules if (longCondition and strategy.position_size == 0) strategy.entry("Long", strategy.long) if (shortCondition and strategy.position_size == 0) strategy.entry("Short", strategy.short) // Strategy Exit Rules if (strategy.position_size > 0 and exitLongCondition) strategy.close("Long") if (strategy.position_size < 0 and exitShortCondition) strategy.close("Short") // Stop Loss and Take Profit Management if (strategy.position_size > 0) strategy.exit("Long TP/SL", "Long", stop=longStopPrice, limit=useFixedTakeProfit ? longTakeProfitPrice : na) if (strategy.position_size < 0) strategy.exit("Short TP/SL", "Short", stop=shortStopPrice, limit=useFixedTakeProfit ? shortTakeProfitPrice : na) // Performance Metrics var float totalTrades = 0 var float winningTrades = 0 var float totalProfitPips = 0 var float totalLossPips = 0 if (strategy.closedtrades > 0) totalTrades := strategy.closedtrades winningTrades := strategy.wintrades totalProfitPips := strategy.grossprofit / pointsPerPip totalLossPips := math.abs(strategy.grossloss) / pointsPerPip // Display Stats var label statsLabel = na label.delete(statsLabel[1]) // Create performance stats text var string stats = "" if (strategy.closedtrades > 0) winRate = (winningTrades / math.max(totalTrades, 1)) * 100 avgWin = totalProfitPips / math.max(winningTrades, 1) avgLoss = totalLossPips / math.max(totalTrades - winningTrades, 1) plRatio = avgWin / math.max(avgLoss, 1) stats := "Win Rate: " + str.tostring(winRate, "#.##") + "%\n" + "Avg Win: " + str.tostring(avgWin, "#.##") + " pips\n" + "Avg Loss: " + str.tostring(avgLoss, "#.##") + " pips\n" + "P/L Ratio: " + str.tostring(plRatio, "#.##") + "\n" + "Total Trades: " + str.tostring(totalTrades, "#") statsLabel := label.new(x=bar_index, y=high, text=stats, style=label.style_label_down, color=color.new(color.blue, 80))