यह रणनीति एमएसीडी संकेतक के दोहरी चलती औसत के क्रॉसओवर की गणना करके खरीद और बिक्री संकेतों की पहचान करती है। यह ट्रेडिंग संकेतों को इंगित करने के लिए चार्ट पर तीरों को प्लॉट करती है।
यह रणनीति पहले फास्ट लाइन (12 पीरियड ईएमए), स्लो लाइन (26 पीरियड ईएमए) और एमएसीडी अंतर की गणना करती है। फिर यह फास्ट और स्लो लाइनों के क्रॉसओवर के साथ-साथ एमएसीडी अंतर के सकारात्मक/नकारात्मक मूल्य के आधार पर लंबे और छोटे संकेतों का निर्धारण करती हैः
झूठे संकेतों को फ़िल्टर करने के लिए, कोड पिछले कैंडलस्टिक के संकेत की भी जांच करता है। वर्तमान संकेत तभी ट्रिगर होता है जब पिछले कैंडलस्टिक में विपरीत संकेत (खरीद बनाम बिक्री या इसके विपरीत) होता है।
इसके अतिरिक्त, चार्ट पर खरीदारी और बिक्री संकेतों को इंगित करने के लिए तीर के आकार को चित्रित किया गया है।
इस रणनीति के लाभों में निम्नलिखित शामिल हैंः
इस रणनीति के कुछ जोखिमः
रणनीति में सुधार के कुछ तरीके:
दोहरी चलती औसत क्रॉसओवर तीर रणनीति काफी सरल और व्यावहारिक है। दो चलती औसत और एमएसीडी अंतर फ़िल्टरिंग के क्रॉसओवर का उपयोग करके, यह मध्य और दीर्घकालिक रुझानों के दौरान प्रविष्टियों और निकास की पहचान करता है, छूटने वाले मूल्य उलटों से बचता है। तीर संकेत स्पष्ट संचालन मार्गदर्शन भी प्रदान करते हैं। पैरामीटर ट्यूनिंग, अतिरिक्त फिल्टर और अनुकूली अनुकूलन के माध्यम से स्थिरता और लाभप्रदता में और सुधार हासिल किया जा सकता है।
/*backtest start: 2022-11-14 00:00:00 end: 2023-11-20 00:00:00 period: 1d basePeriod: 1h exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=3 //Daniels stolen code strategy(shorttitle="Daniels Stolen Code", title="Daniels Stolen Code", overlay=true, calc_on_order_fills=true, pyramiding=0) //Define MACD Variables fast = 12, slow = 26 fastMACD = ema(hlc3, fast) slowMACD = ema(hlc3, slow) macd = fastMACD - slowMACD signal = sma(macd, 9) hist = macd - signal currMacd = hist[0] prevMacd = hist[1] currPrice = hl2[0] prevPrice = hl2[1] buy = currPrice > prevPrice and currMacd > prevMacd sell = currPrice < prevPrice and currMacd < prevMacd neutral = (currPrice < prevPrice and currMacd > prevMacd) or (currPrice > prevPrice and currMacd < prevMacd) //Plot Arrows timetobuy = buy==1 and (sell[1]==1 or (neutral[1]==1 and sell[2]==1) or (neutral[1]==1 and neutral[2]==1 and sell[3]==1) or (neutral[1]==1 and neutral[2]==1 and neutral[3]==1 and sell[4]==1) or (neutral[1]==1 and neutral[2]==1 and neutral[3]==1 and neutral[4]==1 and sell[5]==1) or (neutral[1]==1 and neutral[2]==1 and neutral[3]==1 and neutral[4]==1 and neutral[5]==1 and sell[6]==1)) timetosell = sell==1 and (buy[1]==1 or (neutral[1]==1 and buy[2]==1) or (neutral[1]==1 and neutral[2]==1 and buy[3]==1) or (neutral[1]==1 and neutral[2]==1 and neutral[3]==1 and buy[4]==1) or (neutral[1]==1 and neutral[2]==1 and neutral[3]==1 and neutral[4]==1 and buy[5]==1) or (neutral[1]==1 and neutral[2]==1 and neutral[3]==1 and neutral[4]==1 and neutral[5]==1 and buy[6]==1)) plotshape(timetobuy, color=blue, location=location.belowbar, style=shape.arrowup) plotshape(timetosell, color=red, location=location.abovebar, style=shape.arrowdown) //plotshape(neutral, color=black, location=location.belowbar, style=shape.circle) //Test Strategy // strategy.entry("long", true, 1, when = timetobuy and time > timestamp(2017, 01, 01, 01, 01)) // buy by market if current open great then previous high // strategy.close("long", when = timetosell and time > timestamp(2017, 01, 01, 01, 01)) strategy.order("buy", true, 1, when=timetobuy==1 and time > timestamp(2019, 01, 01, 01, 01)) strategy.order("sell", false, 1, when=timetosell==1 and time > timestamp(2019, 01, 01, 01, 01)) // strategy.entry(id = "Short", long = false, when = enterShort()) // strategy.close(id = "Short", when = exitShort()) //strategy.entry("long", true, 1, when = open > high[1]) // enter long by market if current open great then previous high // strategy.exit("exit", "long", profit = 10, loss = 5) // ge