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

बोलिंगर बैंड और आरएसआई पर आधारित गतिशील लागत औसतकरण रणनीति प्रणाली

लेखक:चाओझांग, दिनांकः 2024-11-27 16:37:12
टैगःबीबीआरएसआईDCAएसएमएटीपी

img

अवलोकन

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

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

यह रणनीति निम्नलिखित मुख्य घटकों पर आधारित है:

  1. मूल्य अस्थिरता सीमाओं को निर्धारित करने के लिए बोलिंगर बैंड, निचले बैंड पर खरीद और ऊपरी बैंड पर बिक्री पर विचार करना
  2. ओवरबॉट/ओवरसोल्ड स्थितियों की पुष्टि करने के लिए आरएसआई, 25 से नीचे ओवरसोल्ड और 75 से ऊपर ओवरसोल्ड की पुष्टि
  3. डीसीए मॉड्यूल अनुकूलनशील पूंजी प्रबंधन के लिए खाता स्वामित्व के आधार पर गतिशील रूप से स्थिति आकारों की गणना करता है
  4. लाभ लेने के मॉड्यूल ने स्वचालित स्थिति बंद करने के लिए 5% लाभ लक्ष्य निर्धारित किया है
  5. बाजार की स्थिति की निगरानी समग्र रुझानों का आकलन करने के लिए 90 दिनों के बाजार परिवर्तनों की गणना करती है
  6. रणनीतिक प्रदर्शन मूल्यांकन के लिए संचयी लाभ ट्रैकिंग प्रत्येक व्यापार के लाभ/हानि को रिकॉर्ड करता है

रणनीतिक लाभ

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

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

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

रणनीति अनुकूलन दिशाएं

  1. पैरामीटर गतिशील अनुकूलनः
  • बोलिंगर बैंड्स पैरामीटर अस्थिरता के अनुकूल होते हैं
  • आरएसआई की सीमाएं बाजार चक्रों के अनुसार भिन्न होती हैं
  • डीसीए आवंटन खाते के आकार के साथ समायोजित होता है
  1. सिग्नल प्रणाली में सुधारः
  • वॉल्यूम पुष्टिकरण जोड़ें
  • रुझान रेखा विश्लेषण शामिल करें
  • अतिरिक्त तकनीकी संकेतक क्रॉस-वैलिडेशन को एकीकृत करें
  1. जोखिम नियंत्रण में सुधारः
  • गतिशील स्टॉप-लॉस लागू करें
  • अधिकतम निकासी नियंत्रण जोड़ें
  • दैनिक हानि सीमाएँ निर्धारित करें

सारांश

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


/*backtest
start: 2023-11-27 00:00:00
end: 2024-11-26 00:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=5
strategy("Combined BB RSI with Cumulative Profit, Market Change, and Futures Strategy (DCA)", shorttitle="BB RSI Combined DCA Strategy", overlay=true)

// Input Parameters
length = input.int(20, title="BB Length")  // Adjusted BB length
mult = input.float(2.5, title="BB Multiplier")  // Adjusted BB multiplier
rsiLength = input.int(14, title="RSI Length")  // Adjusted RSI length
rsiBuyLevel = input.int(25, title="RSI Buy Level")  // Adjusted RSI Buy Level
rsiSellLevel = input.int(75, title="RSI Sell Level")  // Adjusted RSI Sell Level
dcaPositionSizePercent = input.float(1, title="DCA Position Size (%)", tooltip="Percentage of equity to use in each DCA step")
takeProfitPercentage = input.float(5, title="Take Profit (%)", tooltip="Take profit percentage for DCA strategy")

// Calculate DCA position size
equity = strategy.equity  // Account equity
dcaPositionSize = (equity * dcaPositionSizePercent) / 100  // DCA position size as percentage of equity

// Bollinger Bands Calculation
basis = ta.sma(close, length)
dev = mult * ta.stdev(close, length)
upper = basis + dev
lower = basis - dev

// RSI Calculation
rsi = ta.rsi(close, rsiLength)

// Plotting Bollinger Bands and RSI levels
plot(upper, color=color.red, title="Bollinger Upper")
plot(lower, color=color.green, title="Bollinger Lower")
hline(rsiBuyLevel, "RSI Buy Level", color=color.green)
hline(rsiSellLevel, "RSI Sell Level", color=color.red)

// Buy and Sell Signals
buySignal = (rsi < rsiBuyLevel and close <= lower)
sellSignal = (rsi > rsiSellLevel and close >= upper)

// DCA Strategy: Enter Long or Short based on signals with calculated position size
if (buySignal)
    strategy.entry("DCA Buy", strategy.long)

if (sellSignal)
    strategy.entry("DCA Sell", strategy.short)

// Take Profit Logic
if (strategy.position_size > 0)  // If long
    strategy.exit("Take Profit Long", from_entry="DCA Buy", limit=close * (1 + takeProfitPercentage / 100))

if (strategy.position_size < 0)  // If short
    strategy.exit("Take Profit Short", from_entry="DCA Sell", limit=close * (1 - takeProfitPercentage / 100))

// Plot Buy/Sell Signals on the chart
plotshape(buySignal, title="Buy Signal", location=location.belowbar, color=color.green, style=shape.labelup, text="BUY", textcolor=color.white)
plotshape(sellSignal, title="Sell Signal", location=location.abovebar, color=color.red, style=shape.labeldown, text="SELL", textcolor=color.white)

// Alerts for Buy/Sell Signals
alertcondition(buySignal, title="Buy Alert", message="Buy Signal Detected")
alertcondition(sellSignal, title="Sell Alert", message="Sell Signal Detected")

// Cumulative Profit Calculation
var float buyPrice = na
var float profit = na
var float cumulativeProfit = 0.0  // Cumulative profit tracker

if (buySignal)
    buyPrice := close
if (sellSignal and not na(buyPrice))
    profit := (close - buyPrice) / buyPrice * 100
    cumulativeProfit := cumulativeProfit + profit  // Update cumulative profit
    label.new(bar_index, high, text="P: " + str.tostring(profit, "#.##") + "%", color=color.blue, style=label.style_label_down)
    buyPrice := na  // Reset buyPrice after sell

// Plot cumulative profit on the chart
var label cumulativeLabel = na
if (not na(cumulativeProfit))
    if not na(cumulativeLabel)
        label.delete(cumulativeLabel)
    cumulativeLabel := label.new(bar_index, high + 10, text="Cumulative Profit: " + str.tostring(cumulativeProfit, "#.##") + "%", color=color.purple, style=label.style_label_up)

// Market Change over 3 months Calculation
threeMonthsBars = 3 * 30 * 24  // Approximation of 3 months in bars (assuming 1 hour per bar)
priceThreeMonthsAgo = request.security(syminfo.tickerid, "D", close[threeMonthsBars])
marketChange = (close - priceThreeMonthsAgo) / priceThreeMonthsAgo * 100

// Plot market change over 3 months
var label marketChangeLabel = na
if (not na(marketChange))
    if not na(marketChangeLabel)
        label.delete(marketChangeLabel)
    marketChangeLabel := label.new(bar_index, high + 20, text="Market Change (3 months): " + str.tostring(marketChange, "#.##") + "%", color=color.orange, style=label.style_label_up)

// Both labels (cumulative profit and market change) are displayed simultaneously
var label infoLabel = na
if (not na(cumulativeProfit) and not na(marketChange))
    if not na(infoLabel)
        label.delete(infoLabel)
    infoLabel := label.new(bar_index, high + 30, text="Cumulative Profit: " + str.tostring(cumulativeProfit, "#.##") + "% | Market Change (3 months): " + str.tostring(marketChange, "#.##") + "%", color=color.purple, style=label.style_label_upper_right)


संबंधित

अधिक