आंशिक लाभ लेने की रणनीति के साथ चरणबद्ध ट्रैलिंग स्टॉप

लेखक:चाओझांग, दिनांकः 2023-11-28 16:05:24
टैगः

img

अवलोकन

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

रणनीति तर्क

इस रणनीति के प्रमुख घटक निम्नलिखित हैंः

  1. स्टॉप लॉस और 3 सेट करने से मुनाफे का स्तर अंक में होता है।
  2. अंकों में वर्तमान लाभ और स्टॉप लॉस मूल्य की गणना करने के लिए कार्यों को परिभाषित करना।
  3. वर्तमान लाभ स्तर को निर्धारित करने के लिए एक कार्य को परिभाषित करना।
  4. लाभ चरण के आधार पर स्टॉप लॉस मूल्य को ट्रेल मूल्य में संशोधित करना।

विशेष रूप से, यह पहले 100 अंक का स्टॉप लॉस सेट करता है और 100/200/300 अंक पर लाभ लेता है।curProfitInPtsवर्तमान मूल्य और प्रवेश मूल्य के आधार पर वर्तमान लाभ की गणना करता है।calcStopLossPriceफ़ंक्शन बिंदु दूरी के आधार पर स्टॉप लॉस मूल्य की गणना करता है।

मुख्य तर्कgetCurrentStageउदाहरण के लिए चरण 2 100 अंक लाभ के बाद और चरण 3 200 अंक लाभ के बाद प्राप्त किया जाता है।

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

लाभ विश्लेषण

इस चरणबद्ध ट्रेलिंग स्टॉप रणनीति के फायदे:

  1. आगे की लाभ क्षमता बनाए रखते हुए कुछ लाभों को लॉक करने की अनुमति देता है।
  2. ट्रेलिंग स्टॉप लॉस कीमत का अनुसरण करता है और ड्रॉडाउन की संभावना को कम करता है।
  3. बहु-चरण लाभ लेने का नियंत्रण एक लाभ लेने की तुलना में जोखिम लेने से बेहतर है।
  4. सरल और स्पष्ट तर्क।

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

विचार करने के लिए कुछ जोखिम हैंः

  1. चरणबद्ध लाभ लेने से बेहतर निकास के अवसर चूक सकते हैं। लाभ लेने के स्तर को अनुकूलित कर सकते हैं।
  2. यदि ट्रेल स्टॉप दूरी बहुत अधिक है, तो स्टॉप समय से पहले ट्रिगर हो सकता है। विभिन्न दूरी का परीक्षण कर सकता है।
  3. घाटे में कटौती करने में असमर्थता भी अधिक घाटे का कारण बन सकती है। विशिष्ट मामलों में त्वरित स्टॉप लॉस पर विचार करें।

अनुकूलन

इस रणनीति में सुधार करने के कुछ तरीके हैंः

  1. मापदंडों को अनुकूलित करने के लिए विभिन्न लाभ और रोक दूरी का परीक्षण करें।
  2. विशिष्ट स्थितियों के लिए त्वरित स्टॉप लॉस तंत्र पर विचार करें।
  3. लाभ लक्ष्यों और स्टॉप स्तरों को निर्धारित करने के लिए तकनीकी संकेतकों का उपयोग करें।
  4. लाभदायक निकास और रोक दूरी को संतुलित करें।

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

// This source code is subject to the terms of the Mozilla Public License 2.0 at https://mozilla.org/MPL/2.0/
// © adolgov

// @description
// when tp1 is reached, sl is moved to break-even
// when tp2 is reached, sl is moved to tp1
// when tp3 is reached - exit

//@version=4
strategy("Stepped trailing strategy example", overlay=true)

// random entry condition
longCondition = crossover(sma(close, 14), sma(close, 28))
if (longCondition)
    strategy.entry("My Long Entry Id", strategy.long)

// sl & tp in points
sl = input(100)
tp1 = input(100)
tp2 = input(200)
tp3 = input(300)

curProfitInPts() =>
    if strategy.position_size > 0
        (high - strategy.position_avg_price) / syminfo.mintick
    else if strategy.position_size < 0
        (strategy.position_avg_price - low) / syminfo.mintick
    else
        0
        
calcStopLossPrice(OffsetPts) =>
    if strategy.position_size > 0
        strategy.position_avg_price - OffsetPts * syminfo.mintick
    else if strategy.position_size < 0
        strategy.position_avg_price + OffsetPts * syminfo.mintick
    else
        0
        
calcProfitTrgtPrice(OffsetPts) =>
    calcStopLossPrice(-OffsetPts)

getCurrentStage() =>
    var stage = 0
    if strategy.position_size == 0 
        stage := 0
    if stage == 0 and strategy.position_size != 0
        stage := 1
    else if stage == 1 and curProfitInPts() >= tp1
        stage := 2
    else if stage == 2 and curProfitInPts() >= tp2
        stage := 3
    stage

stopLevel = -1.
profitLevel = calcProfitTrgtPrice(tp3)

// based on current stage set up exit
// note: we use same exit ids ("x") consciously, for MODIFY the exit's parameters
curStage = getCurrentStage()
if curStage == 1
    stopLevel := calcStopLossPrice(sl)
    strategy.exit("x", loss = sl, profit = tp3, comment = "sl or tp3")
else if curStage == 2
    stopLevel := calcStopLossPrice(0)
    strategy.exit("x", stop = stopLevel, profit = tp3, comment = "breakeven or tp3")
else if curStage == 3
    stopLevel := calcStopLossPrice(-tp1)
    strategy.exit("x", stop = stopLevel, profit = tp3, comment = "tp1 or tp3")
else
    strategy.cancel("x")
    
// this is debug plots for visulalize TP & SL levels
plot(stopLevel > 0 ? stopLevel : na, style = plot.style_linebr)
plot(profitLevel > 0 ? profitLevel : na, style = plot.style_linebr)

अधिक