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

ईएमए क्रॉस एडीआर रणनीति - सख्त जोखिम प्रबंधन के साथ एक बहुआयामी तकनीकी संकेतक-आधारित ट्रेडिंग पद्धति

लेखक:चाओझांग, दिनांकः 2024-03-28 16:46:29
टैगः

img

अवलोकन

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

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

  1. ड्यूल ईएमए क्रॉसओवरः रणनीति प्रवृत्ति निर्धारित करने के लिए अलग-अलग अवधि के साथ दो ईएमए का उपयोग करती है। जब अल्पकालिक ईएमए दीर्घकालिक ईएमए से ऊपर जाता है, तो इसे एक अपट्रेंड माना जाता है, जो एक लंबा संकेत उत्पन्न करता है; इसके विपरीत, जब अल्पकालिक ईएमए दीर्घकालिक ईएमए से नीचे जाता है, तो इसे एक डाउनट्रेंड माना जाता है, जो एक छोटा संकेत उत्पन्न करता है।

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

  3. ट्रेडिंग टाइम विंडोः यह रणनीति उपयोगकर्ताओं को दैनिक ट्रेडिंग के लिए प्रारंभ और समाप्ति समय निर्धारित करने की अनुमति देती है। ट्रेडों को केवल निर्दिष्ट समय विंडो के भीतर निष्पादित किया जाता है, जो illiquid या अत्यधिक अस्थिर अवधि से बचने में मदद करता है।

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

  5. ब्रेक-ईवन स्टॉप्स: जब कोई पद एक निश्चित लाभ स्तर (उपयोगकर्ता द्वारा परिभाषित जोखिम-लाभ अनुपात) तक पहुंचता है, तो रणनीति स्टॉप-लॉस को ब्रेक-ईवन बिंदु (प्रवेश मूल्य) पर ले जाती है। इससे पहले से अर्जित लाभ की रक्षा करने में मदद मिलती है।

  6. अधिकतम दैनिक हानि सीमाः प्रति दिन अधिकतम हानि को नियंत्रित करने के लिए, रणनीति एक दैनिक हानि सीमा निर्धारित करती है। एक बार दैनिक हानि इस सीमा तक पहुँच जाती है, तो रणनीति अगले दिन के खुलने तक व्यापार करना बंद कर देती है।

  7. दिन के अंत में सभी पदों को बंद करें: चाहे पदों ने लाभ लेने या स्टॉप-लॉस स्तरों को छू लिया हो, रणनीति हर ट्रेडिंग दिन के एक निश्चित समय (जैसे, 16:00) पर सभी पदों को बंद करती है ताकि ओवरनाइट जोखिम से बचा जा सके।

लाभ विश्लेषण

  1. प्रवृत्ति का पालन करने की क्षमताः प्रवृत्तियों को निर्धारित करने के लिए दोहरे ईएमए क्रॉसओवर का उपयोग करके, रणनीति मुख्य बाजार प्रवृत्तियों को प्रभावी ढंग से पकड़ सकती है, जिससे जीत दर और लाभ क्षमता में सुधार होता है।

  2. अस्थिरता अनुकूलन क्षमताः अस्थिरता फिल्टर के रूप में एडीआर संकेतक की शुरूआत कम अस्थिरता वाले वातावरण में लगातार व्यापार करने से बचा सकती है, अमान्य संकेतों और झूठे ब्रेकआउट के कारण होने वाले नुकसान को कम कर सकती है।

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

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

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

जोखिम विश्लेषण

  1. पैरामीटर अनुकूलन जोखिम: यद्यपि रणनीति के मापदंडों को लचीले ढंग से समायोजित किया जा सकता है, अत्यधिक अनुकूलन से ओवरफिटिंग और खराब आउट-ऑफ-सैंपल प्रदर्शन हो सकता है। इसलिए, पैरामीटर निर्धारित करते समय, रणनीति की मजबूती सुनिश्चित करने के लिए पर्याप्त बैकटेस्टिंग और विश्लेषण की आवश्यकता होती है।

  2. अचानक घटना जोखिमः रणनीति मुख्य रूप से तकनीकी संकेतकों के आधार पर व्यापार करती है और कुछ अचानक प्रमुख मौलिक घटनाओं पर पर्याप्त प्रतिक्रिया नहीं दे सकती है, जैसे नीतिगत परिवर्तन या महत्वपूर्ण आर्थिक डेटा उतार-चढ़ाव, जिसके परिणामस्वरूप बड़े ड्रॉडाउन होते हैं।

  3. रुझान उलटने का जोखिमः रुझान उलटने के महत्वपूर्ण अवधियों के दौरान, दोहरे ईएमए क्रॉसओवर संकेतों में देरी हो सकती है, जिससे रणनीति रुझान उलटने की शुरुआत में पदों की स्थापना के लिए सबसे अच्छा समय याद कर सकती है या नुकसान का सामना कर सकती है।

  4. तरलता जोखिम: यद्यपि रणनीति एक व्यापारिक समय खिड़की निर्धारित करती है, यदि कारोबार किए जाने वाले साधनों की तरलता खराब है, तो उसे अभी भी स्लिप और व्यापार में देरी जैसे जोखिमों का सामना करना पड़ सकता है, जो रणनीति के प्रदर्शन को प्रभावित करता है।

  5. तकनीकी संकेतक विफलता जोखिमः रणनीति तकनीकी संकेतकों पर बहुत निर्भर करती है। यदि बाजार की स्थिति में महत्वपूर्ण बदलाव होता है, जिससे संकेतकों का मूल अर्थ खो जाता है, तो रणनीति की प्रभावशीलता में गिरावट आ सकती है।

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

  1. अधिक आयामी संकेतक पेश करेंः मौजूदा दोहरे ईएमए और एडीआर के आधार पर, संकेतों की विश्वसनीयता और मजबूती में सुधार के लिए अधिक प्रभावी तकनीकी संकेतक, जैसे एमएसीडी और आरएसआई पेश करने पर विचार करें।

  2. गतिशील मापदंड अनुकूलन: मापदंड अनुकूलन के लिए एक तंत्र स्थापित करें जो गतिशील रूप से विभिन्न बाजार स्थितियों (जैसे प्रवृत्ति या दोलन) के आधार पर प्रमुख रणनीति मापदंडों को समायोजित करता है ताकि बाजार में परिवर्तन के अनुकूल हो सके।

  3. मौलिक कारकों को शामिल करेंः कुछ महत्वपूर्ण मौलिक संकेतकों पर उचित विचार करें, जैसे आर्थिक आंकड़े और नीतिगत दिशाएं, जो रणनीति को बाजार के रुझानों को बेहतर ढंग से समझने और समय पर प्रणालीगत जोखिमों से बचने में मदद कर सकती हैं।

  4. स्टॉप-लॉस और टेक-प्रॉफिट तंत्र में सुधारः लाभों की बेहतर सुरक्षा और जोखिमों को नियंत्रित करने के लिए मौजूदा गतिशील स्टॉप-लॉस और टेक-प्रॉफिट के आधार पर स्टॉप-लॉस और टेक-प्रॉफिट के तर्क को और अधिक अनुकूलित करना, जैसे कि ट्रेलिंग स्टॉप और आंशिक टेक-प्रॉफिट की शुरूआत करना।

  5. कई साधन और समय सीमाएंः रणनीति को कई व्यापारिक साधनों और समय सीमाओं तक विस्तारित करें और विविध निवेश और समय सीमा अनुकूलन के माध्यम से रणनीति की अनुकूलन क्षमता और स्थिरता में सुधार करें।

सारांश

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


/*backtest
start: 2024-02-26 00:00:00
end: 2024-03-27 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/
// © Sameh_Hussein

//@version=5
strategy('EMA Cross ADR Strategy with Stats', overlay=true)

// Adjustable Parameters
shortEmaLength = input(10, title='Short EMA Length')
longEmaLength = input(50, title='Long EMA Length')
adrLength = input(14, title='ADR Length')
riskRewardRatio = input(2.0, title='Risk/Reward Ratio')
lookbackCandles = input(10, title='Lookback Candles for Stop Loss')
startTime = input(0900, title='Start Time')
endTime = input(1600, title='End Time')
minAdrValue = input(10, title='Minimum ADR Value for Entry')
breakEvenProfit = input.float(1.0, title='Break-Even Profit', minval=0.0)
breakEvenRR = input.float(1.0, title='Break-Even Risk-Reward Ratio', minval=0.0)
dailyLossLimit = input(-2000.0, title='Daily Loss Limit')

// Exponential Moving Averages
shortEma = ta.ema(close, shortEmaLength)
longEma = ta.ema(close, longEmaLength)

// Average Daily Range
adr = ta.sma(ta.tr, adrLength)

// Time Filter Function
timeFilter() => true

// Entry Conditions with ADR filter
longCondition = ta.crossover(shortEma, longEma) and timeFilter() and adr > minAdrValue
shortCondition = ta.crossunder(shortEma, longEma) and timeFilter() and adr > minAdrValue

// Calculate the average low and average high of the previous 'lookbackCandles' candles
averageLow = ta.sma(low, lookbackCandles)
averageHigh = ta.sma(high, lookbackCandles)

// Risk and Reward Calculation
stopLossLong = averageLow
takeProfitLong = close + (close - averageLow) * riskRewardRatio
stopLossShort = averageHigh
takeProfitShort = close - (averageHigh - close) * riskRewardRatio

// Entry Control Variables
var longEntryAllowed = true
var shortEntryAllowed = true

// Update entry price on trade execution
var float entryPriceLong = na
var float entryPriceShort = na

if (strategy.position_size > 0)
    if (strategy.position_size[1] <= 0)
        entryPriceLong := strategy.opentrades.entry_price(strategy.opentrades - 1)
    else
        entryPriceLong := entryPriceLong
else
    entryPriceLong := na

if (strategy.position_size < 0)
    if (strategy.position_size[1] >= 0)
        entryPriceShort := strategy.opentrades.entry_price(strategy.opentrades - 1)
    else
        entryPriceShort := entryPriceShort
else
    entryPriceShort := na

// Adjust stop loss to break-even plus the defined profit when the specified risk-reward ratio is reached
breakEvenTriggerLong = entryPriceLong + (entryPriceLong - stopLossLong) * breakEvenRR
breakEvenTriggerShort = entryPriceShort - (stopLossShort - entryPriceShort) * breakEvenRR

if (longEntryAllowed and close >= breakEvenTriggerLong)
    stopLossLong := entryPriceLong + breakEvenProfit

if (shortEntryAllowed and close <= breakEvenTriggerShort)
    stopLossShort := entryPriceShort - breakEvenProfit

// Close all trades at 1600
if (hour == 15 and minute == 59)
    strategy.close_all(comment='Close at 1600')

// Define the daily loss variable and last trade day
var float[] dailyLossArray = array.new_float(1, 0.0)
var int[] lastTradeDayArray = array.new_int(1, na)

// Function to update the daily loss
updateDailyLoss() =>
    _dailyLoss = array.get(dailyLossArray, 0)
    _lastTradeDay = array.get(lastTradeDayArray, 0)
    if na(_lastTradeDay) or dayofmonth != _lastTradeDay
        _dailyLoss := 0.0
        array.set(lastTradeDayArray, 0, dayofmonth)
    if not na(strategy.closedtrades.entry_bar_index(strategy.closedtrades - 1))
        _dailyLoss += strategy.closedtrades.profit(strategy.closedtrades - 1)
    array.set(dailyLossArray, 0, _dailyLoss)

// Call the function to update the daily loss
updateDailyLoss()

// Execute Strategy
if longCondition and longEntryAllowed
    strategy.entry('Long', strategy.long)
    strategy.exit('Take Profit/Stop Loss', 'Long', stop=stopLossLong, limit=takeProfitLong)
    longEntryAllowed := false

if shortCondition and shortEntryAllowed
    strategy.entry('Short', strategy.short)
    strategy.exit('Take Profit/Stop Loss', 'Short', stop=stopLossShort, limit=takeProfitShort)
    shortEntryAllowed := false

// Reset entry control variables on position close
if strategy.position_size == 0
    longEntryAllowed := true
    shortEntryAllowed := true

// // Statistics
// winRate = strategy.wintrades / strategy.closedtrades * 100
// totalTrades = strategy.closedtrades
// averageProfit = strategy.grossprofit / strategy.wintrades
// averageLoss = strategy.grossloss / strategy.losstrades

// // Plotting
// plot(shortEma, color=color.new(color.red, 0), title='Short EMA')
// plot(longEma, color=color.new(color.blue, 0), title='Long EMA')

// // Display Table
// table statsTable = table.new(position=position.top_right, columns=2, rows=4, bgcolor=color.gray, border_width=1)
// table.cell(statsTable, column=0, row=0, text='Win Rate (%)', bgcolor=color.blue)
// table.cell(statsTable, column=1, row=0, text=str.tostring(winRate), bgcolor=color.blue)
// table.cell(statsTable, column=0, row=1, text='Total Trades', bgcolor=color.blue)
// table.cell(statsTable, column=1, row=1, text=str.tostring(totalTrades), bgcolor=color.blue)
// table.cell(statsTable, column=0, row=2, text='Average Profit', bgcolor=color.blue)
// table.cell(statsTable, column=1, row=2, text=str.tostring(averageProfit), bgcolor=color.blue)
// table.cell(statsTable, column=0, row=3, text='Average Loss', bgcolor=color.blue)
// table.cell(statsTable, column=1, row=3, text=str.tostring(averageLoss), bgcolor=color.blue)


अधिक