यह रणनीति इचिमोकू क्लाउड संकेतक के आधार पर एक मात्रात्मक ट्रेडिंग प्रणाली डिजाइन करती है, मुख्य रूप से अच्छी प्रवृत्तियों वाली परिसंपत्तियों के लिए। रणनीति स्थिर लाभ प्राप्त करने के लिए स्टॉप लॉस, ले लाभ और ट्रेलिंग स्टॉप लॉस जैसे कार्यों को एकीकृत करती है।
इचिमोकू क्लाउड में रूपांतरण रेखा, आधार रेखा, अग्रणी स्पैन 1, अग्रणी स्पैन 2 और क्लाउड चार्ट होते हैं। इस रणनीति के ट्रेडिंग सिग्नल मूल्य और क्लाउड चार्ट के बीच संबंध से आते हैं। विशेष रूप से, एक खरीद संकेत तब उत्पन्न होता है जब मूल्य अग्रणी स्पैन 1 से ऊपर पार हो जाता है; एक बिक्री संकेत तब उत्पन्न होता है जब मूल्य अग्रणी स्पैन 1 से नीचे पार हो जाता है। इसके अलावा, अग्रणी स्पैन 2 एक सहायक निर्णय संकेतक के रूप में भी कार्य करता है।
यह रणनीति एटीआर संकेतक के आधार पर स्टॉप लॉस और टेक प्रॉफिट भी सेट करती है। एटीआर संकेतक प्रभावी रूप से बाजार में उतार-चढ़ाव की डिग्री को पकड़ सकता है। स्टॉप लॉस एटीआर के 2 गुना और टेक प्रॉफिट एटीआर के 4 गुना पर सेट किया गया है। यह प्रभावी रूप से एकल नुकसान को नियंत्रित कर सकता है और कुछ मुनाफे में लॉक कर सकता है।
अंत में, रणनीति एक ट्रेलिंग स्टॉप लॉस तंत्र को अपनाती है। विशेष रूप से, लंबी पदों के लिए, यह लाभ में लॉक करने के लिए वास्तविक समय में स्टॉप लॉस लाइन को समायोजित करने के लिए कॉलबैक आयाम के रूप में एटीआर का 2 गुना उपयोग करेगा; शॉर्ट पदों के लिए, यह लाभ में लॉक करने के लिए वास्तविक समय में स्टॉप लॉस लाइन को समायोजित करने के लिए कॉलबैक आयाम के रूप में एटीआर का 2 गुना उपयोग करेगा।
संबंधित जोखिमों के समाधानः
सामान्य तौर पर, यह रणनीति एक स्थिर प्रवृत्ति ट्रैकिंग रणनीति है। इचिमोकू क्लाउड संकेतक के आधार पर प्रवृत्ति की दिशा का न्याय करें; एटीआर संकेतक का उपयोग करके स्टॉप लॉस सेट करें और लाभ लें; लाभ में लॉक करने के लिए ट्रैलिंग स्टॉप लॉस का उपयोग करें। फायदे सरल तर्क, समझने में आसान हैं; एकल नुकसान को नियंत्रित किया जा सकता है; प्रवृत्ति को प्रभावी ढंग से ट्रैक किया जा सकता है। लेकिन पैरामीटर संवेदनशीलता और स्टॉप लॉस के माध्यम से टूटने के कुछ जोखिम भी हैं। पैरामीटर और रणनीति को लगातार अनुकूलित करके, बेहतर प्रदर्शन प्राप्त किया जा सकता है।
/*backtest start: 2023-01-05 00:00:00 end: 2024-01-11 00:00:00 period: 1d basePeriod: 1h exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=5 strategy("Ichimoku Cloud Strategy with SL, TP, and Trailing Stop", overlay=true) conversionPeriods = input(9, "Conversion Line Length") basePeriods = input(26, "Base Line Length") laggingSpan2Periods = input(52, "Leading Span B Length") displacement = input(26, "Lagging Span") atrLength = input(14, title="ATR Length") donchian(len) => math.avg(ta.lowest(len), ta.highest(len)) conversionLine = donchian(conversionPeriods) baseLine = donchian(basePeriods) leadLine1 = math.avg(conversionLine, baseLine) leadLine2 = donchian(laggingSpan2Periods) // Plot the Ichimoku Cloud components plot(conversionLine, color=color.blue, title="Conversion Line") plot(baseLine, color=color.red, title="Base Line") plot(leadLine1, color=color.green, title="Leading Span A") plot(leadLine2, color=color.orange, title="Leading Span B") plot(leadLine1 > leadLine2 ? leadLine1 : leadLine2, color=color.green, title="Kumo Cloud Upper Line") plot(leadLine1 < leadLine2 ? leadLine1 : leadLine2, color=color.red, title="Kumo Cloud Lower Line") // ATR for stop loss and take profit atrValue = ta.atr(atrLength) stopLoss = atrValue * 2 takeProfit = atrValue * 4 // Strategy entry and exit conditions longCondition = ta.crossover(close, leadLine1) and close > leadLine2 shortCondition = ta.crossunder(close, leadLine1) and close < leadLine2 // Plot buy and sell signals plotshape(series=longCondition ? leadLine1 : na, title="Buy Signal", location=location.belowbar, color=color.green, style=shape.triangleup, size=size.small) plotshape(series=shortCondition ? leadLine1 : na, title="Sell Signal", location=location.abovebar, color=color.red, style=shape.triangledown, size=size.small) // Execute strategy orders with stop loss and take profit strategy.entry("Buy", strategy.long, when=longCondition) strategy.close("Buy", when=shortCondition) // Close buy position when sell condition is met strategy.entry("Sell", strategy.short, when=shortCondition) strategy.close("Sell", when=longCondition) // Close sell position when buy condition is met // Trailing stop strategy.cancel("Trailing Stop") var float trailingStopPrice = na if (longCondition) trailingStopPrice := math.max(trailingStopPrice, close - atrValue * 2) strategy.exit("Trailing Stop", from_entry="Buy", trail_offset=atrValue * 2, trail_price=trailingStopPrice) else if (shortCondition) trailingStopPrice := math.min(trailingStopPrice, close + atrValue * 2) strategy.exit("Trailing Stop", from_entry="Sell", trail_offset=atrValue * 2, trail_price=trailingStopPrice)