संसाधन लोड हो रहा है... लोड करना...

बोलिंगर बैंड और वुडीज सीसीआई के साथ बहु-निर्देशक फ़िल्टर्ड ट्रेडिंग रणनीति

लेखक:चाओझांग, दिनांकः 2024-12-27 15:32:30
टैगःबीबीसीसीआईएमएओबीवीएटीआरएसएमएटीपीSL

img

अवलोकन

यह रणनीति बोलिंगर बैंड्स, वुडीज सीसीआई (कमोडिटी चैनल इंडेक्स), मूविंग एवरेज (एमए), और ऑन-बैलेंस वॉल्यूम (ओबीवी) को मिलाकर एक मल्टी-इंडिकेटर ट्रेडिंग सिस्टम है। यह बाजार अस्थिरता रेंज, सिग्नल फ़िल्टरिंग के लिए सीसीआई संकेतक प्रदान करने के लिए बोलिंगर बैंड का उपयोग करता है, और बाजार के रुझान स्पष्ट होने पर ट्रेडों को निष्पादित करने के लिए वॉल्यूम पुष्टि के साथ एमए सिस्टम को जोड़ता है। इसके अलावा, यह जोखिम को प्रभावी ढंग से नियंत्रित करने के लिए गतिशील स्टॉप-लॉस और ले-प्रॉफिट प्लेसमेंट के लिए एटीआर का उपयोग करता है।

रणनीतिक सिद्धांत

मूल तर्क निम्नलिखित प्रमुख तत्वों पर आधारित हैः

  1. मूल्य अस्थिरता चैनलों का निर्माण करने के लिए दो मानक विचलन बोलिंगर बैंड (1x और 2x) का उपयोग करता है
  2. सिग्नल फिल्टर के रूप में 6-पीरियड और 14-पीरियड सीसीआई संकेतकों का उपयोग करता है, दोनों अवधि से पुष्टि की आवश्यकता होती है
  3. बाजार के रुझानों को निर्धारित करने के लिए 50-अवधि और 200-अवधि चलती औसत को जोड़ती है
  4. 10-अवधि समतल ओबीवी के माध्यम से मात्रा के रुझानों की पुष्टि करता है
  5. गतिशील स्टॉप-लॉस और ले-प्रॉफिट स्तरों के लिए 14-पीरियड एटीआर का प्रयोग करता है

रणनीतिक लाभ

  1. कई संकेतकों का क्रॉस-वैलिडेशन गलत संकेतों को काफी कम करता है
  2. बोलिंगर बैंड और सीसीआई संयोजन बाजार अस्थिरता का सटीक आकलन प्रदान करता है
  3. दीर्घकालिक और अल्पकालिक एमए प्रणाली प्रभावी रूप से प्रमुख रुझानों को पकड़ती है
  4. ओबीवी वॉल्यूम समर्थन की पुष्टि करता है, सिग्नल विश्वसनीयता बढ़ाता है
  5. गतिशील स्टॉप-लॉस और टेक-प्रॉफिट सेटिंग्स विभिन्न बाजार स्थितियों के अनुकूल हैं
  6. मानक निष्पादन के साथ स्पष्ट व्यापार संकेत, मात्रात्मक कार्यान्वयन के लिए उपयुक्त

रणनीतिक जोखिम

  1. कई संकेतकों से संकेतों में देरी हो सकती है
  2. रेंजिंग बाजारों में लगातार स्टॉप-लॉस
  3. पैरामीटर अनुकूलन के अति अनुकूलन का जोखिम
  4. स्टॉप-लॉस अस्थिर अवधि में पर्याप्त रूप से जल्दी नहीं हो सकता है न्यूनीकरण उपाय:
  • विभिन्न बाजार चक्रों के लिए संकेतक मापदंडों को गतिशील रूप से समायोजित करें
  • स्थिति नियंत्रण के लिए ड्रॉडाउन की निगरानी करें
  • नियमित पैरामीटर सत्यापन
  • अधिकतम हानि सीमाएँ निर्धारित करें

अनुकूलन दिशाएँ

  1. उच्च अस्थिरता की अवधि में पदों को समायोजित करने के लिए अस्थिरता संकेतक पेश करना
  2. बाजार के व्यापारों में भिन्नता से बचने के लिए प्रवृत्ति शक्ति फ़िल्टरिंग जोड़ें
  3. बेहतर सिग्नल संवेदनशीलता के लिए सीसीआई अवधि चयन को अनुकूलित करें
  4. आंशिक लाभ लेने के साथ लाभ/हानि प्रबंधन में सुधार
  5. वॉल्यूम विसंगति चेतावनी प्रणाली लागू करें

सारांश

यह तकनीकी संकेतक संयोजनों पर आधारित एक पूर्ण ट्रेडिंग प्रणाली है जो कई संकेत पुष्टि के माध्यम से व्यापार सटीकता में सुधार करती है। रणनीति डिजाइन उचित जोखिम नियंत्रण के साथ उचित है और इसका अच्छा व्यावहारिक अनुप्रयोग मूल्य है। लाइव ट्रेडिंग में रूढ़िवादी पदों के साथ परीक्षण करने और बाजार की स्थिति के आधार पर लगातार मापदंडों का अनुकूलन करने की सिफारिश की जाती है।


/*backtest
start: 2019-12-23 08:00:00
end: 2024-12-25 08:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=6
strategy(shorttitle="BB Debug + Woodies CCI Filter", title="Debug Buy/Sell Signals with Woodies CCI Filter", overlay=true)

// Input Parameters
length = input.int(20, minval=1, title="BB MA Length")
src = input.source(close, title="BB Source")
mult1 = input.float(1.0, minval=0.001, maxval=50, title="BB Multiplier 1 (Std Dev 1)")
mult2 = input.float(2.0, minval=0.001, maxval=50, title="BB Multiplier 2 (Std Dev 2)")
ma_length = input.int(50, minval=1, title="MA Length")
ma_long_length = input.int(200, minval=1, title="Long MA Length")
obv_smoothing = input.int(10, minval=1, title="OBV Smoothing Length")
atr_length = input.int(14, minval=1, title="ATR Length") // ATR Length for TP/SL

// Bollinger Bands
basis = ta.sma(src, length)
dev1 = mult1 * ta.stdev(src, length)
dev2 = mult2 * ta.stdev(src, length)

upper_1 = basis + dev1
lower_1 = basis - dev1
upper_2 = basis + dev2
lower_2 = basis - dev2

plot(basis, color=color.blue, title="BB MA")
p1 = plot(upper_1, color=color.new(color.green, 80), title="BB Upper 1")
p2 = plot(lower_1, color=color.new(color.green, 80), title="BB Lower 1")
p3 = plot(upper_2, color=color.new(color.red, 80), title="BB Upper 2")
p4 = plot(lower_2, color=color.new(color.red, 80), title="BB Lower 2")

fill(p1, p2, color=color.new(color.green, 90))
fill(p3, p4, color=color.new(color.red, 90))

// Moving Averages
ma_short = ta.sma(close, ma_length)
ma_long = ta.sma(close, ma_long_length)
plot(ma_short, color=color.orange, title="MA Short")
plot(ma_long, color=color.yellow, title="MA Long")

// OBV and Smoothing
obv = ta.cum(ta.change(close) > 0 ? volume : ta.change(close) < 0 ? -volume : 0)
obv_smooth = ta.sma(obv, obv_smoothing)

// Debugging: Buy/Sell Signals
debugBuy = ta.crossover(close, ma_short)
debugSell = ta.crossunder(close, ma_short)

// Woodies CCI
cciTurboLength = 6
cci14Length = 14
cciTurbo = ta.cci(src, cciTurboLength)
cci14 = ta.cci(src, cci14Length)

// Filter: Only allow trades when CCI confirms the signal
cciBuyFilter = cciTurbo > 0 and cci14 > 0
cciSellFilter = cciTurbo < 0 and cci14 < 0

finalBuySignal = debugBuy and cciBuyFilter
finalSellSignal = debugSell and cciSellFilter

// Plot Debug Buy/Sell Signals
plotshape(finalBuySignal, title="Filtered Buy", location=location.belowbar, color=color.lime, style=shape.triangleup, size=size.normal)
plotshape(finalSellSignal, title="Filtered Sell", location=location.abovebar, color=color.red, style=shape.triangledown, size=size.normal)

// Change candle color based on filtered signals
barcolor(finalBuySignal ? color.lime : finalSellSignal ? color.red : na)

// ATR for Stop Loss and Take Profit
atr = ta.atr(atr_length)
tp_long = close + 2 * atr  // Take Profit for Long = 2x ATR
sl_long = close - 1 * atr  // Stop Loss for Long = 1x ATR
tp_short = close - 2 * atr // Take Profit for Short = 2x ATR
sl_short = close + 1 * atr // Stop Loss for Short = 1x ATR

// Strategy Execution
if (finalBuySignal)
    strategy.entry("Buy", strategy.long)
    strategy.exit("Take Profit/Stop Loss", "Buy", limit=tp_long, stop=sl_long)

if (finalSellSignal)
    strategy.entry("Sell", strategy.short)
    strategy.exit("Take Profit/Stop Loss", "Sell", limit=tp_short, stop=sl_short)

// Check for BTC/USDT pair
isBTCUSDT = syminfo.ticker == "BTCUSDT"

// Add alerts only for BTC/USDT
alertcondition(isBTCUSDT and finalBuySignal, title="BTCUSDT Buy Signal", message="Buy signal detected for BTCUSDT!")
alertcondition(isBTCUSDT and finalSellSignal, title="BTCUSDT Sell Signal", message="Sell signal detected for BTCUSDT!")

संबंधित

अधिक