गति अनुकूली गौसियन चैनल बहु-अवधि रणनीति

ATR RSI HLC3 TR
निर्माण तिथि: 2025-02-08 14:49:15 अंत में संशोधित करें: 2025-02-08 14:49:15
कॉपी: 1 क्लिक्स: 360
1
ध्यान केंद्रित करना
1617
समर्थक

गति अनुकूली गौसियन चैनल बहु-अवधि रणनीति

अवलोकन

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

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

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

  1. कीमतों में तेजी आई और मुख्य लहरें बढ़ीं
  2. यादृच्छिक आरएसआई सूचक ओवरबॉट दिखाता है
  3. पूर्वनिर्धारित मौसमी विंडो में वर्तमान समय
  4. एटीआर गतिशील गणना के आधार पर स्थिति का आकार

समतल स्थिति संकेतों को कीमतों के गिरने से ट्रिगर किया जाता है। पूरे सिस्टम में कई फ़िल्टरिंग तंत्र हैं जो व्यापार की स्थिरता को बढ़ाते हैं।

रणनीतिक लाभ

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

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

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

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

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

संक्षेप

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

रणनीति स्रोत कोड
/*backtest
start: 2024-02-08 00:00:00
end: 2025-02-06 08:00:00
period: 4h
basePeriod: 4h
exchanges: [{"eid":"Futures_Binance","currency":"DIA_USDT"}]
*/

//@version=6
strategy("Demo GPT - Gold Gaussian Strategy", overlay=true, commission_type=strategy.commission.percent, commission_value=0.1)

// ====== INPUTS ======
// Gaussian Channel
lengthGC = input.int(144, "Gaussian Period", minval=20)
poles = input.int(4, "Poles", minval=1, maxval=9)
multiplier = input.float(1.414, "Volatility Multiplier", minval=1)

// Stochastic RSI
smoothK = input.int(3, "Stoch K", minval=1)
lengthRSI = input.int(14, "RSI Length", minval=1)
lengthStoch = input.int(14, "Stoch Length", minval=1)
overbought = input.int(80, "Overbought Level", minval=50)

// Seasonal Filter (corrected)
startMonth = input.int(9, "Start Month (1-12)", minval=1, maxval=12)
endMonth = input.int(2, "End Month (1-12)", minval=1, maxval=12)

// Volatility Management
atrLength = input.int(22, "ATR Length", minval=5)
riskPercent = input.float(0.5, "Risk per Trade (%)", minval=0.1, step=0.1)

// ====== GAUSSIAN CHANNEL ======
f_filt9x(alpha, source, iterations) =>
    float f = 0.0
    float x = 1 - alpha
    int m2 = iterations == 9 ? 36 : iterations == 8 ? 28 : iterations == 7 ? 21 : 
           iterations == 6 ? 15 : iterations == 5 ? 10 : iterations == 4 ? 6 : 
           iterations == 3 ? 3 : iterations == 2 ? 1 : 0
    
    int m3 = iterations == 9 ? 84 : iterations == 8 ? 56 : iterations == 7 ? 35 : 
           iterations == 6 ? 20 : iterations == 5 ? 10 : iterations == 4 ? 4 : 
           iterations == 3 ? 1 : 0
    
    int m4 = iterations == 9 ? 126 : iterations == 8 ? 70 : iterations == 7 ? 35 : 
           iterations == 6 ? 15 : iterations == 5 ? 5 : iterations == 4 ? 1 : 0
    
    int m5 = iterations == 9 ? 126 : iterations == 8 ? 56 : iterations == 7 ? 21 : 
           iterations == 6 ? 6 : iterations == 5 ? 1 : 0
    
    int m6 = iterations == 9 ? 84 : iterations == 8 ? 28 : iterations == 7 ? 7 : 
           iterations == 6 ? 1 : 0
    
    int m7 = iterations == 9 ? 36 : iterations == 8 ? 8 : iterations == 7 ? 1 : 0
    
    int m8 = iterations == 9 ? 9 : iterations == 8 ? 1 : 0
    int m9 = iterations == 9 ? 1 : 0
    
    f := math.pow(alpha, iterations) * nz(source) +
      iterations * x * nz(f[1]) -
      (iterations >= 2 ? m2 * math.pow(x, 2) * nz(f[2]) : 0) +
      (iterations >= 3 ? m3 * math.pow(x, 3) * nz(f[3]) : 0) -
      (iterations >= 4 ? m4 * math.pow(x, 4) * nz(f[4]) : 0) +
      (iterations >= 5 ? m5 * math.pow(x, 5) * nz(f[5]) : 0) -
      (iterations >= 6 ? m6 * math.pow(x, 6) * nz(f[6]) : 0) +
      (iterations >= 7 ? m7 * math.pow(x, 7) * nz(f[7]) : 0) -
      (iterations >= 8 ? m8 * math.pow(x, 8) * nz(f[8]) : 0) +
      (iterations == 9 ? m9 * math.pow(x, 9) * nz(f[9]) : 0)
    f

f_pole(alpha, source, iterations) =>
    float fn = na
    float f1 = f_filt9x(alpha, source, 1)
    float f2 = iterations >= 2 ? f_filt9x(alpha, source, 2) : na
    float f3 = iterations >= 3 ? f_filt9x(alpha, source, 3) : na
    float f4 = iterations >= 4 ? f_filt9x(alpha, source, 4) : na
    float f5 = iterations >= 5 ? f_filt9x(alpha, source, 5) : na
    float f6 = iterations >= 6 ? f_filt9x(alpha, source, 6) : na
    float f7 = iterations >= 7 ? f_filt9x(alpha, source, 7) : na
    float f8 = iterations >= 8 ? f_filt9x(alpha, source, 8) : na
    float f9 = iterations == 9 ? f_filt9x(alpha, source, 9) : na
    
    fn := iterations == 1 ? f1 : 
         iterations == 2 ? f2 : 
         iterations == 3 ? f3 : 
         iterations == 4 ? f4 : 
         iterations == 5 ? f5 : 
         iterations == 6 ? f6 : 
         iterations == 7 ? f7 : 
         iterations == 8 ? f8 : 
         iterations == 9 ? f9 : na
    [fn, f1]

beta = (1 - math.cos(4 * math.asin(1) / lengthGC)) / (math.pow(1.414, 2 / poles) - 1)
alpha = -beta + math.sqrt(math.pow(beta, 2) + 2 * beta)
lag = int((lengthGC - 1) / (2 * poles))

srcAdjusted = hlc3 + (hlc3 - hlc3[lag])
[mainFilter, filt1] = f_pole(alpha, srcAdjusted, poles)
[trFilter, tr1] = f_pole(alpha, ta.tr(true), poles)

upperBand = mainFilter + trFilter * multiplier
lowerBand = mainFilter - trFilter * multiplier

// ====== STOCHASTIC RSI ======
rsiValue = ta.rsi(close, lengthRSI)
k = ta.sma(ta.stoch(rsiValue, rsiValue, rsiValue, lengthStoch), smoothK)
stochSignal = k >= overbought

// ====== SEASONAL FILTER (FIXED) ======
currentMonth = month(time)
inSeason = (currentMonth >= startMonth and currentMonth <= 12) or 
         (currentMonth >= 1 and currentMonth <= endMonth)

// ====== VOLATILITY MANAGEMENT ======
atr = ta.atr(atrLength)
positionSize = math.min((strategy.equity * riskPercent/100) / atr, strategy.equity * 0.5 / close)

// ====== TRADING LOGIC ======
trendUp = mainFilter > mainFilter[1]
priceAbove = close > upperBand
longCondition = trendUp and priceAbove and stochSignal and inSeason

exitCondition = ta.crossunder(close, lowerBand)

// ====== EXECUTION ======
if longCondition
    strategy.entry("Long", strategy.long, qty=positionSize)
    
if exitCondition
    strategy.close("Long")

// ====== VISUALIZATION ======
plot(upperBand, "Upper Band", color=color.new(#00FF00, 0))
plot(lowerBand, "Lower Band", color=color.new(#FF0000, 0))
bgcolor(inSeason ? color.new(color.blue, 90) : na, title="Season Filter")