यह रणनीति ट्रेंड की दिशा निर्धारित करने के लिए मल्टी टाइमफ्रेम एक्सपोनेंशियल मूविंग एवरेज (एमटीएफ ईएमए) और ट्रेडिंग सिग्नल उत्पन्न करने के लिए एमएसीडी संकेतक के कार्यों का पूरा लाभ उठाती है, जबकि एटीआर संकेतक के साथ स्टॉप लॉस और ले लाभ की कीमतें निर्धारित करती है। यह रणनीति मजबूत रुझान वाले डिजिटल और फिएट मुद्रा जोड़े के लिए उपयुक्त है और मजबूत रुझान वाले बाजारों में बेहतर प्रदर्शन करती है।
मल्टी टाइमफ्रेम एक्सपोनेंशियल मूविंग एवरेज (एमटीएफ ईएमए) एक ही चार्ट पर कई टाइमफ्रेम के मूविंग एवरेज प्रदर्शित कर सकता है ताकि किसी परिसंपत्ति की समग्र लंबी/छोटी स्थिति निर्धारित की जा सके। यह रणनीति 1 घंटे और 15 मिनट के एमटीएफ ईएमए को अपनाती है।
जब कीमत 1-घंटे के एमटीएफ ईएमए से ऊपर होती है और 1-घंटे के एमटीएफ ईएमए 15-मिनट के एमटीएफ ईएमए से नीचे होता है, तो इसे अपट्रेंड के रूप में परिभाषित किया जाता है। जब कीमत 1-घंटे के एमटीएफ ईएमए से नीचे होती है और 1-घंटे के एमटीएफ ईएमए 15-मिनट के एमटीएफ ईएमए से ऊपर होता है, तो इसे डाउनट्रेंड के रूप में परिभाषित किया जाता है।
जब एमएसीडी रेखा नीचे से सिग्नल लाइन के ऊपर से पार करती है, तो एक खरीद संकेत उत्पन्न होता है। जब यह ऊपर से नीचे से पार करती है, तो एक बिक्री संकेत उत्पन्न होता है। उसी समय, झूठे संकेतों से बचने के लिए एमएसीडी लाइन और सिग्नल लाइन के लिए एक क्रॉसओवर सीमा निर्धारित की जाती है।
एटीआर संकेतक का उपयोग स्टॉप लॉस और ले लाभ की कीमतों को सेट करने के लिए किया जाता है। एटीआर गतिशील रूप से उचित स्टॉप लॉस सेट कर सकता है और बाजार की अस्थिरता के आधार पर लाभ दूरी ले सकता है। उसी समय, स्टॉप लॉस और ले लाभ के गुणकों को उच्च और निम्न के बैकटेस्ट के आधार पर सेट किया जाता है ताकि उन्हें अधिक लचीला बनाया जा सके।
लंबा संकेतः ऊर्ध्वाधर प्रवृत्ति और एमएसीडी सीमा से ऊपर संकेत रेखा और क्रॉसओवर मूल्य से कम संक्षिप्त संकेतः डाउनट्रेंड और एमएसीडी सीमा से अधिक संकेत रेखा और क्रॉसओवर मूल्य से नीचे पार करना
दीर्घ लाभ लेनाः एटीआर के माध्यम से मूल्य ब्रेक लेना लाभ मूल्य लंबी स्टॉप लॉस: कीमत एटीआर स्टॉप लॉस की कीमत के माध्यम से टूट जाती है शॉर्ट टेक प्रॉफिटः एटीआर के माध्यम से मूल्य ब्रेक ले लो लाभ मूल्य शॉर्ट स्टॉप लॉस: कीमत एटीआर स्टॉप लॉस की कीमत के माध्यम से टूट जाती है
इस रणनीति का सबसे बड़ा लाभ यह है कि यह रुझानों को निर्धारित करने में एमटीएफ ईएमए और ट्रेडिंग सिग्नल उत्पन्न करने में एमएसीडी की ताकत का पूरी तरह से उपयोग करता है। एमटीएफ ईएमए समग्र प्रवृत्ति की दिशा का स्पष्ट रूप से न्याय कर सकता है और चंचल बाजारों में लगातार व्यापार से बच सकता है। एमएसीडी संकेतक मूल्य पैटर्न में अल्पकालिक परिवर्तनों को बेहतर ढंग से पकड़ सकता है और ट्रेडिंग संकेत उत्पन्न कर सकता है। दोनों का एक साथ उपयोग करने से अधिक ट्रेडिंग अवसर प्राप्त करते हुए प्रवृत्ति को पकड़ना सुनिश्चित होता है। इसके अलावा, गतिशील रूप से स्टॉप लॉस ट्रैक करने और लाभ लेने के लिए एटीआर संकेतक का उपयोग करके व्यक्तिगत ट्रेडों के जोखिम को प्रभावी ढंग से नियंत्रित किया जा सकता है।
इस रणनीति के दो मुख्य जोखिम हैंः पहला, एक स्पष्ट प्रवृत्ति के अभाव में, एमटीएफ ईएमए गलत संकेत उत्पन्न कर सकता है, जिससे नुकसान हो सकता है; दूसरा, एमएसीडी संकेतक अक्सर भ्रामक संकेत उत्पन्न करता है जब कीमतें नाटकीय रूप से बदलती हैं, जिससे ओवर-ट्रेडिंग हो सकती है। पहले जोखिम के लिए, एमटीएफ ईएमए मापदंडों को उचित रूप से समायोजित किया जा सकता है ताकि मूल्य प्रवृत्ति परिवर्तनों से बेहतर मेल खा सके; दूसरे जोखिम को एमएसीडी संकेतक के लिए क्रॉसओवर सीमाएं निर्धारित करके कम किया जा सकता है।
रणनीति के निम्नलिखित पहलुओं को अनुकूलित किया जा सकता हैः
एमटीएफ ईएमए के चक्र मापदंडों को विभिन्न व्यापारिक साधनों की मूल्य विशेषताओं से बेहतर ढंग से मेल खाने के लिए समायोजित करें
बेहतर संकेतों के लिए एमएसीडी संकेतक के तेज और धीमे चलती औसत और संकेत रेखा मापदंडों का अनुकूलन करें
सर्वोत्तम रिटर्न के लिए विभिन्न एटीआर चक्र मापदंडों और स्टॉप लॉस/टेक प्रॉफिट गुणकों का परीक्षण करें
फ़िल्टर संकेतों के लिए अन्य सहायक संकेतक जोड़ें
यह लंबी और छोटी खोलने की रणनीति ट्रेंड जजमेंट के लिए एमटीएफ ईएमए, ट्रेडिंग सिग्नल जनरेशन के लिए एमएसीडी और गतिशील स्टॉप लॉस और लाभ लेने के लिए एटीआर के तरीकों को जोड़ती है। यह स्पष्ट रुझान वाले बाजारों में अच्छे रिटर्न प्राप्त कर सकती है। बेहतर प्रदर्शन प्राप्त करने के लिए इस रणनीति के मापदंडों और अनुकूलन के अनुकूलन के लिए बहुत जगह है। हालांकि, जोखिमों को नियंत्रित करना और अस्थिर बाजारों में अंधेरे व्यापार से बचना आवश्यक है।
/*backtest start: 2023-12-01 00:00:00 end: 2023-12-31 23:59:59 period: 1h basePeriod: 15m exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ // This source code is subject to the terms of the Mozilla Public License 2.0 at https://mozilla.org/MPL/2.0/ // © Steven A. Zmuda Burke / stevenz17 //@version=4 // From Date Inputs fromDay = input(defval = 01, title = "From Day", minval = 1, maxval = 31) fromMonth = input(defval = 04, title = "From Month", minval = 1, maxval = 12) fromYear = input(defval = 2022, title = "From Year", minval = 1970) // To Date Inputs toDay = input(defval = 01, title = "To Day", minval = 1, maxval = 31) toMonth = input(defval = 05, title = "To Month", minval = 1, maxval = 12) toYear = input(defval = 2022, title = "To Year", minval = 1970) // Calculate start/end date and time condition startDate = timestamp(fromYear, fromMonth, fromDay, 00, 00) finishDate = timestamp(toYear, toMonth, toDay, 00, 00) time_cond = true // Input strategy("LONG", overlay=true, initial_capital=1000, default_qty_type=strategy.percent_of_equity, default_qty_value=100, slippage=1, commission_type=strategy.commission.percent, commission_value=0.015) SOURCE = input(title = "═════════════════════ SOURCE ═════════════════════", defval = false, type = input.bool) sourcehl2 = input(title="Source hl2 or (open+close)/2 ?",type=input.bool,defval=true) source = sourcehl2 ? hl2 : ((open+close)/2) //MTF EMA MTFEMA = input(title = "════════════════════ MTF EMA ════════════════════", defval = false, type = input.bool) res1=input(title="MTF EMA 1", type=input.resolution, defval="60") len1 = input(title = "EMA Period 1", type=input.integer, defval=70, minval=1) ema1 = ema(source, len1) emaStep1 = security (syminfo.tickerid, res1, ema1, barmerge.gaps_off, barmerge.lookahead_off) mtf1 = emaStep1 res2=input(title="MTF EMA 2", type=input.resolution, defval="15") len2 = input(title = "EMA Period 2", type=input.integer, defval=68, minval=1) ema2 = ema(source, len2) emaStep2 = security (syminfo.tickerid, res2, ema2, barmerge.gaps_off, barmerge.lookahead_off) mtf2 = emaStep2 t1 = plot(mtf1, linewidth=4, color= color.aqua, title="EMA") t2 = plot(mtf2, linewidth=4, color= color.navy, title="EMA") fill(t1, t2, transp = 70, color = mtf1 > mtf2 ? color.red : color.green) ///MACD MACD= input(title = "═════════════════════ MACD ══════════════════════", defval = false, type = input.bool) MACDsource=close fastLength = input(13, minval=1, title="MACD fast moving average") slowLength=input(18,minval=1, title="MACD slow moving average") signalLength=input(24,minval=1, title="MACD signal line moving average") MacdEmaLength =input(9, title="MACD EMA period", minval=1) useEma = input(true, title="Use EMA (otherwise SMA)") useOldAlgo = input(false, title="Use normal MACD") Lmacsig=input(title="LONG MACD and signal crossover limit",type=input.integer,defval=180) // Fast line ma1= useEma ? ema(MACDsource, fastLength) : sma(MACDsource, fastLength) ma2 = useEma ? ema(ma1,fastLength) : sma(ma1,fastLength) fastMA = ((2 * ma1) - ma2) // Slow line mas1= useEma ? ema(MACDsource , slowLength) : sma(MACDsource , slowLength) mas2 = useEma ? ema(mas1 , slowLength): sma(mas1 , slowLength) slowMA = ((2 * mas1) - mas2) // MACD line macd = fastMA - slowMA // Signal line emasig1 = ema(macd, signalLength) emasig2 = ema(emasig1, signalLength) signal = useOldAlgo ? sma(macd, signalLength) : (2 * emasig1) - emasig2 hist = macd - signal histline = hist > 0 ? color.green : color.red //MACD ribbon macdribbon=input(title="Show MACD ribbon?",type=input.bool,defval=false) macdx=input(title="MACD ribbon multiplier", type=input.integer, defval=3, minval=1) leadLine1 = macdribbon ? macd*macdx + source : na leadLine2 = macdribbon ? signal*macdx + source : na leadLine3 = hist + source //MACD plot p3 = plot(leadLine1, color= color.green, title="MACD", transp = 100, linewidth = 8) p4 = plot(leadLine2, color= color.red, title="Signal", transp = 100, linewidth = 8) fill(p3, p4, transp = 20, color = leadLine1 > leadLine2 ? #53b987 : #eb4d5c) plot((leadLine3), color = histline, title="Histogram", linewidth = 3) l="TEst" upHist = (hist > 0) ? hist : 0 downHist = (hist <= 0) ? hist : 0 p1 = plot(upHist, color=color.green, transp=40, style=plot.style_columns, title='Positive delta') p2 = plot(downHist, color=color.green, transp=40, style=plot.style_columns, title='Negative delta') zeroLine = plot(macd, color=color.black, transp=0, linewidth=2, title='MACD line') signalLine = plot(signal, color=color.gray, transp=0, linewidth=2, title='Signal') ribbonDiff = color.green fill(zeroLine, signalLine, color=ribbonDiff) circleYPosition = signal plot(ema(macd,MacdEmaLength) , color=color.red, transp=0, linewidth=2, title='EMA on MACD line') ribbonDiff2 = hist > 0 ? color.green : color.red plot(crossunder(signal,macd) ? circleYPosition : na,style=plot.style_circles, linewidth=4, color=ribbonDiff, title='Dots') //STOCHASTIC stochchch= input(title = "═══════════════════ STOCHASTIC ════════════════════", defval = false, type = input.bool) StochOn = input(title="Stochastic On?",type=input.bool,defval=true) periodK = input(10, title="K", minval=1) periodD = input(1, title="D", minval=1) smoothK = input(3, title="Smooth", minval=1) stochlimit = input(30, title="Stoch value crossover", minval=1) k = sma(stoch(close, high, low, periodK), smoothK) d = sma(k, periodD) stochSignal = StochOn ? (d < stochlimit ? true : false) : true pp= input(1, title="avg price length", minval=1) p = ema (source, pp) K = k + p plot(k, title="%K", color=#0094FF) plot(d, title="%D", color=#FF6A00) h0 = hline(72, "Upper Band", color=#606060) h1 = hline(20, "Lower Band", color=#606060) fill(h0, h1, color=#9915FF, transp=80, title="Background") //Long LS= "════════════════════════════════ LONG CONDITIONS ═══════════════════════════" uptrend = close > mtf1 and mtf1 < mtf2 downtrend = close < mtf1 and mtf1 > mtf2 crossMACD = crossunder(macd,signal) LongBuy = uptrend and stochSignal? crossMACD and signal < Lmacsig and macd < Lmacsig : na LONG = strategy.position_size > 0 SHORT = strategy.position_size < 0 FLAT = strategy.position_size == 0 plotshape(LongBuy, style=shape.xcross, text="LONG", color=color.green) //ATR & TP/SL ATRTPSLX= input(title = "═════════════════ LONG SL ═════════════════", defval = false, type = input.bool) maxIdLossPcnt = input(5, "Max Intraday Loss(%)", type=input.float, minval=0.0, step=0.1) // strategy.risk.max_intraday_loss(maxIdLossPcnt, strategy.percent_of_equity) SSL2=input(title="Long Stop Loss when MTF EMA cross?",type=input.bool,defval=false) SSLOP = LONG and crossunder(source, mtf1) SlossPercOn = input(title="Long Stop Loss (%) on?",type=input.bool,defval=false) SlossPerc = input(title="Long Stop Loss (%)", type=input.float, minval=0.0, step=0.1, defval=4.7) * 0.01 SSpricePerc = LONG and SlossPercOn? strategy.position_avg_price * (-1 - SlossPerc) : na plot(series = SSpricePerc, linewidth=2, color= color.maroon,style=plot.style_linebr, title="Long Stop Loss %") SSLX = LONG and crossunder(source, SSpricePerc) SSLatr= input(title="Long Stop Loss ATR?",type=input.bool,defval=true) useStructure=input(title="Look back for High/Lows?",type=input.bool,defval=true) Slookback=input(title="How far to look back for High/Lows:",type=input.integer,defval=18,minval=1) SatrLenghth=input(title="Long ATR Lenghth",type=input.integer,defval=9,minval=1) SatrStopMultiplier=input(title="Long ATR Stop x ?", type=input.float,defval=4.3, minval=0.1,step=0.1) Satr = atr(SatrLenghth) LongStop = SSLatr ? ((useStructure ? lowest(low, Slookback) : source) - Satr * SatrStopMultiplier) : na SStop = crossunder(source,LongStop) plot(Satr, color=color.blue, title="ATR", transp=100) plot(series = uptrend ? LongStop : na, color=color.red, style=plot.style_linebr, title="Long Trailing Stop", transp=0) ATRTPSLXX= input(title = "═════════════════ LONG TP ═════════════════", defval = false, type = input.bool) TpPercOn = input(title="Long Take Profit (%) on?",type=input.bool,defval=true) TpPerc = input(title="Long Take Profit (%)", type=input.float, minval=0.0, step=0.1, defval=5.3) * 0.01 TppricePerc = LONG and TpPercOn? strategy.position_avg_price * (-1 + TpPerc) : na plot(series = TppricePerc, linewidth=2, color= color.lime,style=plot.style_linebr, title="Long Take Profit %") TPLX = LONG and crossunder(source, TppricePerc) TP1=input(title="1 Long Take Profit On?",type=input.bool,defval=true) useStructure1=input(title="Look back for High/Lows?",type=input.bool,defval=true) STplookback=input(title="How far to look back for High/Lows for 1 TP",type=input.integer,defval=12,minval=1) STpatrLenghth=input(title="Long ATR Lenghth 1 TP",type=input.integer,defval=24,minval=1) SatrProfitMultiplier = input(title="First Long ATR Take Profit x ?", type=input.float,defval=5.5, minval=0.1,step=0.1) STpatr = atr(STpatrLenghth) LongTakeProfit = (useStructure1 ? highest(high, STplookback) : source) + STpatr * SatrProfitMultiplier LongTP = TP1 ? crossover(source, LongTakeProfit): false plot(series = uptrend ? LongTakeProfit: na , color=color.green, style=plot.style_linebr, title="Long Trailing Take Profit", transp=0) // Bar color barcolor(cross(macd, signal) ? (macd - signal > 0 ? (uptrend and macd < 0 and signal < 0 ? color.yellow : na) : (downtrend and macd > 0 and signal > 0 ? color.blue : na)) : na) // Strategy ATR GOLONG = LongBuy and SSLatr and FLAT if GOLONG and TP1 strategy.entry(id="Entry LONG 1TP", long=true,comment="Entry Long") strategy.exit("Long Profit or Loss 1TP","Entry LONG 1TP", limit=LongTakeProfit, stop=LongStop) if SSLX strategy.close(id="Entry LONG 1TP", comment="% Long SL EXIT") if TPLX strategy.close(id="Entry LONG 1TP", comment="% Long TP EXIT") if SSLOP and SSL2 strategy.close(id="Entry LONG 1TP", comment="MTF EMA cross EXIT") if (not time_cond) strategy.close_all() strategy.cancel_all() //plot(strategy.equity, title="equity", color=red, linewidth=2, style=areabr) //@version=4