इस रणनीति का मुख्य विचार बाजार की वापसी के बाद रिबाउंड अवसर को पकड़ने के लिए अलग-अलग अवधि के साथ दो चलती औसत का उपयोग करना है। जब कीमत दीर्घकालिक चलती औसत से ऊपर होती है और अल्पकालिक चलती औसत पर वापस खींचती है, तो रणनीति एक लंबी स्थिति खोलती है और स्थिति को बंद कर देती है जब कीमत अल्पकालिक चलती औसत से ऊपर उठती है या स्टॉप-लॉस मूल्य को हिट करती है। एक प्रवृत्ति में वापसी के दौरान खरीदने के अवसरों की तलाश करके, रणनीति का उद्देश्य ट्रेंडिंग बाजारों से लाभ उठाना है।
मूविंग एवरेज पुलबैक ट्रैकिंग रणनीति विभिन्न अवधियों के साथ दो मूविंग एवरेज की सापेक्ष स्थिति का उपयोग करके एक अपट्रेंड में मूल्य pullbacks के दौरान लंबे व्यापार के अवसरों को पकड़ती है। यह रणनीति ट्रेंडिंग बाजारों के लिए उपयुक्त है, और उचित पैरामीटर सेटिंग्स और स्टॉप-लॉस के साथ, यह ट्रेंडिंग स्थितियों में स्थिर रिटर्न उत्पन्न कर सकती है। हालांकि, रणनीति को चंचल बाजारों में और ट्रेंड रिवर्स के दौरान कुछ जोखिमों का सामना करना पड़ता है। अधिक संकेतकों को पेश करके, स्थिति आकार को अनुकूलित करके, गतिशील स्टॉप-लॉस और अन्य तरीकों को लागू करके, इस रणनीति के प्रदर्शन और स्थिरता में और सुधार किया जा सकता है।
/*backtest start: 2023-03-22 00:00:00 end: 2024-03-27 00:00:00 period: 1d 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/ // © contapessoal_ivan // @version=5 strategy("Pullback Strategy", overlay=true, initial_capital=1000, default_qty_type=strategy.percent_of_equity, default_qty_value=100, // 100% of balance invested on each trade commission_type=strategy.commission.cash_per_contract, commission_value=0.005) // Interactive Brokers rate // Get user input i_ma1 = input.int(title="MA 1 Length", defval=200, step=10, group="Strategy Parameters", tooltip="Long-term MA") i_ma2 = input.int(title="MA 2 Length", defval=10, step=10, group="Strategy Parameters", tooltip="Short-term MA") i_stopPercent = input.float(title="Stop Loss Percent", defval=0.10, step=0.1, group="Strategy Parameters", tooltip="Failsafe Stop Loss Percent Decline") i_lowerClose = input.bool(title="Exit On Lower Close", defval=false, group="Strategy Parameters", tooltip="Wait for a lower-close before exiting above MA2") i_startTime = input(title="Start Filter", defval=timestamp("26 Jan 2023 00:00 +0000"), group="Time Filter", tooltip="Start date & time to begin searching for setups") i_endTime = input(title="End Filter", defval=timestamp("26 Mar 2024 23:59 +0000"), group="Time Filter", tooltip="End date & time to stop searching for setups") // Get indicator values ma1 = ta.sma(close, i_ma1) ma2 = ta.sma(close, i_ma2) // Check filter(s) f_dateFilter = true // Check buy/sell conditions var float buyPrice = 0 buyCondition = close > ma1 and close < ma2 and strategy.position_size == 0 and f_dateFilter sellCondition = close > ma2 and strategy.position_size > 0 and (not i_lowerClose or close < low[1]) stopDistance = strategy.position_size > 0 ? ((buyPrice - close) / close) : na stopPrice = strategy.position_size > 0 ? buyPrice - (buyPrice * i_stopPercent) : na stopCondition = strategy.position_size > 0 and stopDistance > i_stopPercent // Enter positions if buyCondition strategy.entry(id="Long", direction=strategy.long) if buyCondition[1] buyPrice := open // Exit positions if sellCondition or stopCondition strategy.close(id="Long", comment="Exit" + (stopCondition ? "SL=true" : "")) buyPrice := na // Draw pretty colors plot(buyPrice, color=color.lime, style=plot.style_linebr) plot(stopPrice, color=color.red, style=plot.style_linebr, offset=-1) plot(ma1, color=color.blue) plot(ma2, color=color.orange)