समर्थन और प्रतिरोध उत्क्रमण पैटर्न पर आधारित मात्रात्मक ट्रेडिंग रणनीति


निर्माण तिथि: 2024-06-07 16:45:09 अंत में संशोधित करें: 2024-06-07 16:45:09
कॉपी: 3 क्लिक्स: 611
1
ध्यान केंद्रित करना
1617
समर्थक

समर्थन और प्रतिरोध उत्क्रमण पैटर्न पर आधारित मात्रात्मक ट्रेडिंग रणनीति

अवलोकन

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

इस रणनीति का मुख्य विचार समर्थन की स्थिति के पास एक bullish उलटफेर के रूप में (जैसे कि हेडलाइन, bullish डूब या क्रॉसस्टार) के आसपास अधिक पदों को खोलना है, और प्रतिरोध की स्थिति के पास एक bearish उलटफेर के रूप में (जैसे कि हेडलाइन, bullish डूब या क्रॉसस्टार) के आसपास खाली पदों को खोलना है। साथ ही साथ जोखिम को नियंत्रित करने और मुनाफे को लॉक करने के लिए स्टॉप और स्टॉप-लॉस स्तर सेट करें।

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

  1. ta.lowest() और ta.highest() फ़ंक्शन के माध्यम से समर्थन और प्रतिरोध बिंदुओं को निर्धारित करने के लिए निर्दिष्ट प्रत्यावर्तन अवधि में न्यूनतम और उच्चतम मूल्य की गणना की जाती है।
  2. यह निर्धारित करने के लिए कि क्या वर्तमान आरेख एक सिर रेखा, एक निगल या एक क्रॉसस्टार बनाता है।
  3. यदि समर्थन के पास एक bullish उलटफेर होता है, तो अधिक स्थिति खोलें; यदि प्रतिरोध के पास एक bearish उलटफेर होता है, तो एक खाली स्थिति खोलें।
  4. स्टॉप मूल्य को स्टॉप मूल्य के 3% और स्टॉप मूल्य को स्टॉप मूल्य के 1% पर सेट करें।
  5. जब कीमत स्टॉप या स्टॉप लॉस स्तर तक पहुंच जाती है, तो प्वालपोस्ट।

रणनीतिक लाभ

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

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

  1. अस्थिर बाजारों में, अक्सर उलटा संकेत होता है, जिससे ओवर-ट्रेडिंग और कमीशन की हानि हो सकती है।
  2. समर्थन और प्रतिरोध का निर्धारण प्रत्याशा अवधि के चयन पर निर्भर करता है, और विभिन्न प्रत्याशा अवधि अलग-अलग परिणामों का कारण बन सकती है।
  3. रिवर्स मोड की विश्वसनीयता पूर्ण नहीं है, झूठे संकेतों से नुकसान हो सकता है।

समाधान:

  1. झूठे सिग्नल को कम करने के लिए, उलटा रूप के पैरामीटर और पुष्टि की शर्तों को समायोजित करें।
  2. अन्य तकनीकी संकेतकों या बाजार की भावना के संकेतकों के साथ संयोजन में, संकेतों की विश्वसनीयता में सुधार।
  3. विभिन्न बाजार स्थितियों के लिए स्टॉप और लॉस लेवल को उचित रूप से समायोजित करें।

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

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

संक्षेप

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

रणनीति स्रोत कोड
/*backtest
start: 2024-05-07 00:00:00
end: 2024-06-06 00:00:00
period: 2h
basePeriod: 15m
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/
// © Kingcoinmilioner

//@version=5
strategy("Reversal Patterns at Support and Resistance", overlay=true, default_qty_type=strategy.percent_of_equity, default_qty_value=100)

// Parameters
support_resistance_lookback = input.int(50, title="Support/Resistance Lookback Period")
reversal_tolerance = input.float(0.01, title="Reversal Tolerance (percent)", step=0.01) / 100
take_profit_percent = input.float(3, title="Take Profit (%)") / 100
stop_loss_percent = input.float(1, title="Stop Loss (%)") / 100

// Functions to identify key support and resistance levels
findSupport() =>
    ta.lowest(low, support_resistance_lookback)

findResistance() =>
    ta.highest(high, support_resistance_lookback)

// Identify reversal patterns
isHammer() =>
    body = math.abs(close - open)
    lowerWick = open > close ? (low < close ? close - low : open - low) : (low < open ? open - low : close - low)
    upperWick = high - math.max(open, close)
    lowerWick > body * 2 and upperWick < body

isEngulfing() =>
    (close[1] < open[1] and close > open and close > open[1] and open < close[1]) 
    (close[1] > open[1] and close < open and close < open[1] and open > close[1])

isDoji() =>
    math.abs(open - close) <= (high - low) * 0.1

// Identify support and resistance levels
support = findSupport()
resistance = findResistance()

// Check for reversal patterns at support and resistance
hammerAtSupport = isHammer() and (low <= support * (1 + reversal_tolerance))
engulfingAtSupport = isEngulfing() and (low <= support * (1 + reversal_tolerance))
dojiAtSupport = isDoji() and (low <= support * (1 + reversal_tolerance))

hammerAtResistance = isHammer() and (high >= resistance * (1 - reversal_tolerance))
engulfingAtResistance = isEngulfing() and (high >= resistance * (1 - reversal_tolerance))
dojiAtResistance = isDoji() and (high >= resistance * (1 - reversal_tolerance))

// Trading logic
if (hammerAtSupport or engulfingAtSupport or dojiAtSupport)
    strategy.entry("Long", strategy.long)
    stop_level = low * (1 - stop_loss_percent)
    take_profit_level = close * (1 + take_profit_percent)
    strategy.exit("Take Profit/Stop Loss", from_entry="Long", stop=stop_level, limit=take_profit_level)

if (hammerAtResistance or engulfingAtResistance or dojiAtResistance)
    strategy.entry("Short", strategy.short)
    stop_level = high * (1 + stop_loss_percent)
    take_profit_level = close * (1 - take_profit_percent)
    strategy.exit("Take Profit/Stop Loss", from_entry="Short", stop=stop_level, limit=take_profit_level)

// Plot support and resistance levels for visualization
plot(support, color=color.green, linewidth=1, title="Support Level")
plot(resistance, color=color.red, linewidth=1, title="Resistance Level")

// Plot reversal patterns on the chart for visualization
plotshape(series=hammerAtSupport, location=location.belowbar, color=color.green, style=shape.labelup, text="Hammer at Support")
plotshape(series=engulfingAtSupport, location=location.belowbar, color=color.green, style=shape.labelup, text="Engulfing at Support")
plotshape(series=dojiAtSupport, location=location.belowbar, color=color.green, style=shape.labelup, text="Doji at Support")

plotshape(series=hammerAtResistance, location=location.abovebar, color=color.red, style=shape.labeldown, text="Hammer at Resistance")
plotshape(series=engulfingAtResistance, location=location.abovebar, color=color.red, style=shape.labeldown, text="Engulfing at Resistance")
plotshape(series=dojiAtResistance, location=location.abovebar, color=color.red, style=shape.labeldown, text="Doji at Resistance")