बहु-कारक रणनीतियाँ


निर्माण तिथि: 2023-10-31 15:45:39 अंत में संशोधित करें: 2023-10-31 15:45:39
कॉपी: 0 क्लिक्स: 709
1
ध्यान केंद्रित करना
1617
समर्थक

बहु-कारक रणनीतियाँ

अवलोकन

मल्टीफैक्टर रणनीतियाँ तीन अलग-अलग प्रकार की रणनीतियों को जोड़ती हैं, जैसे कि आघात, प्रवृत्ति-अनुसरण और ब्रेकआउट रणनीतियाँ, जो संयोजन के माध्यम से बेहतर रणनीतिक प्रभाव प्राप्त करती हैं।

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

बहु-कारक रणनीति को मुख्य रूप से निम्नलिखित पहलुओं के आधार पर मॉडलिंग की जाती हैः

  • आघात रणनीति भाग में यादृच्छिक संकेतकों को खरीदने और बेचने के समय का आकलन करने के लिए उपयोग किया जाता है। विशेष रूप से, जब यादृच्छिक सूचक% K लाइन ओवरसोल्ड क्षेत्र से% D लाइन को पार करती है तो एक खरीद संकेत उत्पन्न होता है; जब% K लाइन ओवरसोल्ड क्षेत्र से% D लाइन को पार करती है तो एक बेचने का संकेत उत्पन्न होता है।

  • प्रवृत्ति रणनीति भाग एसएमए औसत रेखा के गोल्डन क्रॉस का उपयोग प्रवृत्ति की दिशा का न्याय करने के लिए करता है। जब तेज़ रेखा नीचे से धीमी रेखा को पार करती है तो यह एक खरीद संकेत उत्पन्न करती है; जब तेज़ रेखा ऊपर से नीचे से धीमी रेखा को पार करती है तो यह एक बेचने का संकेत उत्पन्न करती है।

  • ब्रेकआउट रणनीति का हिस्सा यह निगरानी करता है कि क्या कीमतें निर्दिष्ट अवधि के भीतर उच्चतम या निम्नतम मूल्य को तोड़ती हैं। जब कीमत उच्चतम मूल्य से अधिक हो तो खरीदें; जब कीमत निम्नतम मूल्य से कम हो तो बेचें।

  • प्रवृत्ति की ताकत का आकलन करने के लिए ADX सूचक के साथ संयोजन में, केवल जब प्रवृत्ति पर्याप्त मजबूत हो तो प्रवृत्ति व्यापार में भाग लें।

  • स्टॉप और स्टॉप लाइन स्थापित करें और उचित स्टॉप और स्टॉप अनुपात सेट करें

इन सभी को मिलाकर, एक बहु-कारक रणनीति मुख्य रूप से निम्नलिखित तर्क का पालन करती हैः

  1. जब ADX सेट थ्रेशोल्ड से बड़ा होता है, तो यह माना जाता है कि प्रवृत्ति पर्याप्त मजबूत है, और प्रवृत्ति रणनीति को निष्पादित करना शुरू कर दिया जाता है; जब ADX थ्रेशोल्ड से कम होता है, तो इसे समेकित माना जाता है, और केवल आघात रणनीति को निष्पादित किया जाता है।

  2. प्रवृत्ति में, जब एसएमए तेज धीमी रेखा में सोना पार हो जाता है, तो स्थिति को खोलें और जब यह मर जाता है, तो स्थिति को बंद करें।

  3. अस्थिरता के दौरान, यादृच्छिक संकेतक के लिए ट्रेडिंग सिग्नल निष्पादित करें।

  4. ब्रेकआउट रणनीतियाँ दोनों प्रकार के बाजार परिवेशों में उपयोग की जाती हैं।

  5. स्टॉपलॉस स्टॉपलाइन सेट करें और लाभ को अनुकूलित करें।

श्रेष्ठता विश्लेषण

बहु-कारक रणनीतियों का सबसे बड़ा लाभ यह है कि विभिन्न प्रकार की रणनीतियों के संयोजन से दोनों प्रकार के बाजार वातावरण में बेहतर रणनीतिक प्रभाव प्राप्त किया जा सकता है। विशेष रूप से, मुख्य रूप से निम्नलिखित फायदे हैंः

  1. ट्रेंडिंग में जीतने के लिए ट्रेंडिंग में जीतने के लिए ट्रेंडिंग में जीतने के लिए।

  2. इस तरह के निवेशकों के लिए यह एक अच्छा अवसर है कि वे किसी भी अस्थिर स्थिति में लाभ कमा सकें, न कि किसी भी स्थिति में फंसे रहें।

  3. उच्च लाभ कारक के साथ, स्टॉप-स्टॉप-लॉस सेटिंग उचित है।

  4. इस प्रकार, हम अपने व्यापार को कम करने के लिए प्रवृत्ति की ताकत को ध्यान में रखते हुए, नुकसान को कम कर सकते हैं।

  5. कई संकेतकों के संयोजन से मजबूत व्यापारिक संकेत मिल सकते हैं।

  6. पैरामीटर अनुकूलन के माध्यम से बेहतर पैरामीटर संयोजन प्राप्त किया जा सकता है।

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

मल्टीफैक्टर रणनीतियों में कुछ जोखिम भी होते हैं, जिनमें मुख्य रूप से शामिल हैंः

  1. गलत बहु-कारक संयोजन से ट्रेडिंग सिग्नल में गड़बड़ी हो सकती है और इष्टतम कारक संयोजन खोजने के लिए बार-बार परीक्षण की आवश्यकता होती है।

  2. कई मापदंडों को अनुकूलित करने की आवश्यकता है, अनुकूलन की कठिनाई अधिक है, और पर्याप्त ऐतिहासिक डेटा समर्थन की आवश्यकता है।

  3. प्रवृत्ति के उलट होने पर, समय पर बंद नहीं किया जा सकता है, जिससे बड़ी हानि हो सकती है।

  4. ADX सूचकांक में देरी है, और यह एक रुझान मोड़ को याद कर सकता है।

  5. ब्रेकआउट ट्रेडों को आसानी से पकड़ा जा सकता है और उचित स्टॉप-लॉस रणनीतियों की आवश्यकता होती है।

इन जोखिमों के लिए, निम्नलिखित बिंदुओं पर अनुकूलन किया जा सकता हैः

  1. ऐतिहासिक डेटा में विभिन्न कारकों की स्थिरता का परीक्षण करें और स्थिरता कारक चुनें।

  2. आनुवंशिक एल्गोरिदम जैसे बुद्धिमान अनुकूलन विधियों का उपयोग करके इष्टतम पैरामीटर की तलाश करना।

  3. अधिकतम वापसी को नियंत्रित करने के लिए उचित स्टॉप लॉस लाइन सेट करें।

  4. यह एक अतिरिक्त संकेत है कि रुझान उलट रहा है।

  5. ब्रेकआउट ट्रेडों के लिए स्टॉप लॉस रणनीति को अनुकूलित करें, ताकि बहुत अधिक नुकसान से बचा जा सके।

अनुकूलन दिशा

मल्टी फैक्टर रणनीतियों में और अधिक अनुकूलन के लिए जगह हैः

  1. अधिक प्रकार के कारकों का परीक्षण करें, बेहतर संयोजन की तलाश करें। अन्य कारकों जैसे कि अस्थिरता, लेनदेन की मात्रा आदि को ध्यान में रखा जा सकता है।

  2. मशीन लर्निंग के माध्यम से इष्टतम रणनीतिक भार का पता लगाना।

  3. पैरामीटर अनुकूलन एक बुद्धिमान एल्गोरिथ्म का उपयोग करके किया जा सकता है, जो तेजी से अनुकूलन की तलाश करता है।

  4. विभिन्न अवधि के लिए रिटर्न का परीक्षण किया जा सकता है।

  5. स्टॉप-लॉस लाइन को गतिशील रूप से समायोजित करने पर विचार किया जा सकता है।

  6. अधिक फ़िल्टरिंग शर्तों को पेश किया जा सकता है, जैसे कि यातायात में वृद्धि, सिग्नल की गुणवत्ता में सुधार।

  7. ADX सूचकांक को अनुकूलन मापदंडों के रूप में माना जा सकता है या इसे अधिक उन्नत प्रवृत्ति-निर्णय सूचकांकों के साथ प्रतिस्थापित किया जा सकता है।

संक्षेप

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

रणनीति स्रोत कोड
/*backtest
start: 2023-09-30 00:00:00
end: 2023-10-30 00:00:00
period: 1h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=4

// strategy("Strategy_1", shorttitle="Strategy1",overlay=true ,pyramiding = 12, initial_capital=25000, currency='EUR', commission_type = strategy.commission.cash_per_order, commission_value = 3, default_qty_type = strategy.percent_of_equity, default_qty_value = 20)
	
// Revision:        1
// Author:          Jonas

// === INPUT ===
    //   > BACKTEST RANGE <
FromMonth = input(defval=1, title="From Month", minval=1, maxval=12)
FromDay = input(defval=1, title="From Day", minval=1, maxval=31)
FromYear = input(defval=2017, title="From Year", minval=2010)
ToMonth = input(defval=1, title="To Month", minval=1, maxval=12)
ToDay = input(defval=1, title="To Day", minval=1, maxval=31)
ToYear = input(defval=9999, title="To Year", minval=2010)

    //   > STRATEGY SETTINGS <
bolOS = input(defval = false, type=input.bool, title="Oscillating Strategy")
bolTS = input(defval = true, type=input.bool, title="Trend Strategy")
bolBO = input(defval = false, type=input.bool, title="Breakout Strategy")

strStrategy = input(defval = "Long", type=input.string, title="Trade Strategy",options = ["Long", "Short","Long & Short"])

flStopLoss = input(defval = 2.0, title="Stop Loss %", type=input.float)/100
flTakeProfit = input(defval = 4.0, title="Take Profit %", type=input.float)/100

    //   > SMA <

fastMA = input(defval=8, type=input.integer, title="FastMA length", minval=1, step=1)
slowMA = input(defval=21, type=input.integer, title="SlowMA length", minval=1, step=1)

    //  > ADX <
adx_len = input(defval=10, type=input.integer, title="ADX length", minval=1, step=1)
adx_trend = input(defval=30, type=input.integer, title="ADX Tr", minval=1, step=1)
adx_choppy = adx_trend
adx_limit = adx_trend

    //  > TRENDSCORE <
ts_fromIndex = input(title="From", type=input.integer, minval=1, defval=10)
ts_toIndex = input(title="To", type=input.integer, minval=1, defval=14)
ts_src = input(title="Source", type=input.source, defval=close)

    // > Oscillator <
stoch_length = 14
stoch_OverBought = 75
stoch_OverSold = 25
stoch_smoothK = 3
stoch_smoothD = 3

// === BACK TEST RANGE FUNCTION ===
window_start = timestamp(FromYear, FromMonth, FromDay, 00, 00)  // backtest start window
window_finish = timestamp(ToYear, ToMonth, ToDay, 23, 59)  // backtest finish window
window() =>  // create function "within window of time"
    time >= window_start and time <= window_finish ? true : false

//plot(stop_level_Long, title="TEST",color=color.red, style=plot.style_linebr, linewidth=2)
//plot(take_level_Long, color=color.green, style=plot.style_linebr, linewidth=2)

// === ADX ===
adx_up = change(high)
adx_down = -change(low)
adx_trur = rma(tr, adx_len)
adx_plus = fixnan(100 * rma(adx_up > adx_down and adx_up > 0 ? adx_up : 0, adx_len) / adx_trur)
adx_minus = fixnan(100 * rma(adx_down > adx_up and adx_down > 0 ? adx_down : 0, adx_len) / adx_trur)
adx_sum = adx_plus + adx_minus

ADX = 100 * rma(abs(adx_plus - adx_minus) / (adx_sum == 0 ? 1 : adx_sum), adx_len)

//=== TRENDSCORE ===
trendscore(ts_src, ts_fromIndex, ts_toIndex) =>
	ts_sum = 0.0
	for i = ts_fromIndex to ts_toIndex
        ts_sum := ts_sum + (ts_src >= nz(ts_src[i]) ? 1 : -1)
    ts_sum

intTS = trendscore(ts_src, ts_fromIndex, ts_toIndex)
// Long if  TrendDirection = 1, Short if TrendDirection = -1; Indifferent if TrendDirection = 0
intTrendDirection = (intTS > (ts_toIndex-ts_fromIndex)) ? 1 : (intTS < (ts_fromIndex-ts_toIndex)) ? -1 : 0

    //  > TREND CONDITION <
adx_growing = ADX > highest(ADX[1],3)
intTrend = ((ADX >= adx_limit) and (ADX[1] >= adx_limit) and adx_growing) ? intTrendDirection : 0

// === ATR ===
ATR = sma(tr,10)
ATR_100 = ATR /abs(high - low)


// === STOCHASTICS ===

stoch_k = sma(stoch(close, high, low, stoch_length), stoch_smoothK)
stoch_d = sma(stoch_k, stoch_smoothD)

// === FILTER & CONDITIONS ===
    //  > STOCHASTICS <
bolFilter_OS1 = close[1] > hl2[1]



bolSigOsc_long_1 = (na(stoch_k) or na(stoch_d)) ? false : (crossover(stoch_d,stoch_OverSold) and stoch_k > stoch_d) ? true:false
bolSigOsc_short_1 = (na(stoch_k) or na(stoch_d)) ? false : (crossunder(stoch_d,stoch_OverBought) and stoch_k < stoch_d) ? true:false

bolLongOpenOS = bolSigOsc_long_1 and bolFilter_OS1
bolLongCloseOS = bolSigOsc_short_1

bolShortOpenOS = bolSigOsc_short_1 and bolFilter_OS1
bolShortCloseOS = bolSigOsc_long_1

    //  > TREND <

bolFilter_TS1 = close[1] > hl2[1] and open[1] < hl2[1]
bolFilter_TS2 = sma(close,50)>sma(close,50)[10]
bolFilter_TS3 = close[1] < hl2[1] and open[1] > hl2[1]

bolSigTrendLO1 = sma(close, fastMA) > sma(close, slowMA)
bolSigTrendLO2 = close > sma(close,fastMA)
bolSigTrendLO3 = bolSigTrendLO1 and bolSigTrendLO2

bolSigTrendLC1 = sma(close, fastMA) < sma(close, slowMA)
bolSigTrendLC2 = close < sma(close, fastMA)
bolSigTrendLC3 = bolSigTrendLC1 and bolSigTrendLC2

bolSigTrendSO1 = bolSigTrendLC3
bolSigTrendSC1 = bolSigTrendLO1

bolLongOpenTS = bolSigTrendLO3 and bolFilter_TS1
bolLongCloseTS = bolSigTrendLC3 and bolFilter_TS3

bolShortOpenTS = bolSigTrendSO1 and bolFilter_TS3
bolShortCloseTS = bolLongOpenTS and bolFilter_TS1

plot(sma(close, fastMA), title='FastMA', color=color.green, linewidth=2, style=plot.style_line)  // plot FastMA
plot(sma(close, slowMA), title='SlowMA', color=color.red, linewidth=2, style=plot.style_line)  // plot SlowMA



    //  > BREAKOUT <
flFilter_BS1 = 0.5 * stdev(close,slowMA)[1]
bolFilter_BS2 = volume > sma(volume,slowMA)*1.25

bolSigBreakoutLO1 = close > (highestbars(high,slowMA)[1] + flFilter_BS1)
bolSigBreakoutLC1 = barssince(bolSigBreakoutLO1)==5

bolSigBreakoutSO1 = close < lowestbars(low,slowMA)[1] - flFilter_BS1
bolSigBreakoutSC1 = barssince(bolSigBreakoutSO1)==5


bolLongOpenBO = bolSigBreakoutLO1 and bolFilter_BS2
bolLongCloseBO = bolSigBreakoutLC1

bolShortOpenBO = bolSigBreakoutSO1 and bolFilter_BS2
bolShortCloseBO = bolSigBreakoutSC1

//=== STRATEGIES ENTRIES & EXITS ===
    //  > STOPS & LIMITS <
stop_level_Long = strategy.position_avg_price * (1 - flStopLoss)
take_level_Long = strategy.position_avg_price * (1 + flTakeProfit)
stop_level_Short = strategy.position_avg_price * (1 + flStopLoss)
take_level_Short = strategy.position_avg_price * (1 - flTakeProfit)

    //  > ENTRIES / CLOSES / EXITS <
if window() //only in backtest-window
    if (bolOS == true)
        if (intTrend == 0)
            if(strStrategy == "Long" or strStrategy == "Long & Short")
                strategy.entry("Lng Osc", strategy.long, when=bolLongOpenOS)  // buy long when "within window of time" AND crossover
            if(strStrategy == "Short" or strStrategy == "Long & Short")
                strategy.entry("Short Osc", strategy.short, when=bolShortOpenOS)
        strategy.close("Lng Osc", when=(bolLongCloseOS))
        //strategy.exit("Exit L OS/STD", "Lng Osc", stop = strategy.position_avg_price - 2*stdev(close,10))
        strategy.exit("Exit L OS/%", "Lng Osc", stop=stop_level_Long)
        strategy.close("Short Osc", when=(bolShortCloseOS))
        //strategy.exit("Exit S OS/STD", "Short Osc", stop = strategy.position_avg_price + 2*stdev(strategy.position_avg_price,10))
        strategy.exit("Exit S OS/%", "Short Osc", stop=stop_level_Short)
    if (bolTS == true)
        if (not(intTrend == 0))
            if((strStrategy == "Long") or (strStrategy == "Long & Short"))
                strategy.entry("Lng TD", strategy.long, when=bolLongOpenTS)  // buy long when "within window of time" AND crossover
            if((strStrategy == "Short") or (strStrategy == "Long & Short"))
                strategy.entry("Short TD", strategy.short, when=(bolShortOpenTS and bolTS))  // buy long when "within window of time" AND crossover
        strategy.exit("Exit L TD", "Lng TD", stop=stop_level_Long)
        strategy.close("Lng TD", when=bolLongCloseTS)
        strategy.exit("Exit S TD", "Short TD", stop=stop_level_Short)
        strategy.close("Short TD", when=bolShortCloseTS)
    if (bolBO == true)
        if((strStrategy == "Long") or (strStrategy == "Long & Short"))
            strategy.entry("Lng BO", strategy.long, when=bolLongOpenBO)  // buy long when "within window of time" AND crossover
            strategy.close("Lng BO", when=bolLongCloseBO)
            //strategy.exit("Exit L BO/STD", "Lng BO", stop = strategy.position_avg_price - 2*stdev(strategy.position_avg_price,10))
            strategy.exit("Exit L BO/2.5%", "Lng BO", stop=stop_level_Long)
        if((strStrategy == "Short") or (strStrategy == "Long & Short"))
            strategy.entry("Short BO", strategy.short, when=bolShortOpenBO)  // buy long when "within window of time" AND crossover
            strategy.close("Short BO", when=bolShortCloseBO)
            //strategy.exit("Exit S BO/STD", "Short BO", stop = strategy.position_avg_price - 2*stdev(strategy.position_avg_price,10))
            strategy.exit("Exit S BO/%", "Short BO", stop=stop_level_Short)