শূন্য লেগ ওভারল্যাপিং মুভিং মিডিয়ার সাথে চ্যান্ডেলিয়ার এক্সট্রিড ট্রেডিং কৌশল

লেখক:চাওঝাং, তারিখঃ ২০২৪-০১-২২ ১০ঃ০৩ঃ০৫
ট্যাগঃ

img

সারসংক্ষেপ

এই কৌশলটির মূল ধারণা হ'ল ট্রেন্ডের দিক নির্ধারণের জন্য জিরো লেগ ওভারল্যাপিং মুভিং এভারেজ (জেডএলএসএমএ) সূচক এবং আরও সুনির্দিষ্ট প্রবেশ এবং প্রস্থান পয়েন্টগুলি সন্ধানের জন্য চ্যান্ডেলিয়ার প্রস্থান (সিই) সূচককে একত্রিত করা। জেডএলএসএমএ এমন একটি প্রবণতা সূচক যা প্রবণতা পরিবর্তনগুলি আগে সনাক্ত করতে পারে। এই কৌশলটি কার্যকরভাবে স্টপ লস নিয়ন্ত্রণের জন্য এটিআর গণনা করে প্রস্থান পয়েন্টগুলিকে গতিশীলভাবে সামঞ্জস্য করে। এই কৌশলটি মূলত মাঝারি-স্বল্পমেয়াদী অপারেশনগুলির জন্য উপযুক্ত।

কৌশল নীতি

  1. ZLSMA অংশঃ

    • যথাক্রমে ১৩০-অবধি এলএমএ লাইন গণনা করতে লিনিয়ার রিগ্রেশন পদ্ধতি ব্যবহার করুন।
    • তারপর দুইটি LMA রেখাকে ওভারল্যাপ করুন যাতে eq এর জন্য পার্থক্যের মান নির্ধারণ করা যায়।
    • অবশেষে, মূল এলএমএ রেখার মাধ্যমে শূন্য বিলম্ব ওভারল্যাপিং মুভিং গড় ZLSMA নির্মাণ করুন।
  2. সিই অংশঃ

    • এটিআর সূচকটি গণনা করুন এবং এটি একটি ফ্যাক্টর দ্বারা গুণ করুন (ডিফল্ট 2) সাম্প্রতিক সর্বোচ্চ বা নিম্নতম বিন্দু থেকে গতিশীল দূরত্ব নির্ধারণ করতে।
    • যখন বন্ধের মূল্য সর্বশেষ দীর্ঘ বা সংক্ষিপ্ত স্টপ লস লাইন অতিক্রম করে, তখন স্টপ লস লাইন সংশোধন করুন।
    • স্টপ লস লাইনের তুলনায় ক্লোজিং প্রাইসের পরিবর্তনের উপর ভিত্তি করে লং বা শর্ট দিক নির্ধারণ করুন।
  3. প্রবেশ সংকেতঃ

    • ZLSMA প্রবণতা দিক বিচার করে, যখন সিই ইস্যু সংকেত প্রবেশ করান।
  4. এক্সট্রাস্ট স্টপ লসঃ

    • লং পজিশনের জন্য স্থায়ী স্টপ লস এবং লভ্যাংশ নিন।
    • শর্ট পজিশনের জন্য, স্থির স্টপ লস প্রতিস্থাপনের জন্য সিই এর ডাইনামিক আউটপুট ব্যবহার করুন।

সুবিধা বিশ্লেষণ

  1. ZLSMA মিথ্যা ব্রেকআউট এড়ানোর জন্য প্রবণতাকে আগে সনাক্ত করতে পারে।
  2. সিই বাজারের অস্থিরতার উপর নির্ভর করে প্রান্তিককরণ পয়েন্টগুলি নমনীয়ভাবে সামঞ্জস্য করতে পারে।
  3. কৌশলটির স্বনির্ধারিত ঝুঁকি-প্রতিফলন অনুপাত।
  4. ঝুঁকি নিয়ন্ত্রণের জন্য লং এবং শর্ট পজিশনের জন্য স্টপ লস এবং লাভ নেওয়ার বিভিন্ন পদ্ধতি।

ঝুঁকি বিশ্লেষণ

  1. অনুপযুক্ত প্যারামিটার সেটিং হ্রাস হার বৃদ্ধি বা স্টপ হ্রাস পরিসীমা প্রসারিত করতে পারে।
  2. বাজারে দ্রুত বিপর্যয়ের ক্ষেত্রে স্টপ লস ভাঙার ঝুঁকি এখনও রয়েছে।

অপ্টিমাইজেশান নির্দেশাবলী

  1. বিভিন্ন বাজার এবং সময়সীমার জন্য পরামিতিগুলি অপ্টিমাইজ করা যেতে পারে।
  2. অস্থিরতা বা নির্দিষ্ট চক্রের উপর ভিত্তি করে মুনাফা/স্টপ পরামিতিগুলি সামঞ্জস্য করার বিষয়টি বিবেচনা করুন।
  3. মুনাফা হার বাড়ানোর জন্য অন্য সূচক বা মডেলের সাথে সংযুক্ত করার চেষ্টা করুন।

সংক্ষিপ্তসার

এই কৌশলটি মূলত ট্রেন্ডের দিক নির্ধারণের জন্য জিরো লেগ ওভারল্যাপিং মুভিং এভারেজ ব্যবহার করে, আরও সুনির্দিষ্ট প্রবেশ এবং প্রস্থান পয়েন্টগুলি খুঁজে পেতে চ্যান্ডেলিয়ার প্রস্থান সূচকের সাথে মিলিত। সুবিধাগুলি কাস্টমাইজযোগ্য স্টপ / লাভের অনুপাতের মধ্যে রয়েছে এবং চ্যান্ডেলিয়ার প্রস্থানের গতিশীল সমন্বয় বাজারের অবস্থার সাথে সামঞ্জস্য রেখে ঝুঁকিগুলি নিয়ন্ত্রণ করতে পারে। পরবর্তী পদক্ষেপগুলি স্থিতিশীলতা এবং লাভজনকতা আরও উন্নত করতে প্যারামিটার অপ্টিমাইজেশন এবং কৌশল সংমিশ্রণ হতে পারে।


/*backtest
start: 2024-01-14 00:00:00
end: 2024-01-21 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/
// © GGkurg

//@version=5

strategy(title = "ZLSMA + Chandelier Exit", shorttitle="ZLSMA + CE", overlay=true)


var GRP1 = "take profit / stop loss"
TP = input(title='long TP%', defval=2.0,   inline = "1", group = GRP1) 
SL = input(title='long SL%', defval=2.0,    inline = "1", group = GRP1) 
TP2 = input(title='short TP', defval=2.0,    inline = "2", group = GRP1) 
SL2 = input(title='short SL', defval=2.0,    inline = "2", group = GRP1) 
//-------------------------------------------------calculations
takeProfitPrice = strategy.position_avg_price * (1+(TP/100))
stopLossPrice = strategy.position_avg_price * (1-(SL/100))
takeProfitPrice2 = strategy.position_avg_price * (1-(TP2/100))
stopLossPrice2 = strategy.position_avg_price * (1+(SL2/100))


//---------------------------------------ZLSMA - Zero Lag LSMA
var GRP2 = "ZLSMA settings"
length1 = input(title='Length', defval=130, inline = "1", group = GRP2) 
offset1 = input(title='Offset', defval=0, inline = "2", group = GRP2) 
src = input(close, title='Source', inline = "3", group = GRP2) 
lsma = ta.linreg(src, length1, offset1)
lsma2 = ta.linreg(lsma, length1, offset1)
eq = lsma - lsma2
zlsma = lsma + eq

plot(zlsma, color=color.new(color.yellow, 0), linewidth=3)


//---------------------------------------ZLSMA conditisions 
//---------long
longc1 = close > zlsma
longclose1 = close < zlsma
//---------short
shortc1 = close < zlsma
shortclose1 = close > zlsma


//---------------------------------------Chandelier Exit
var string calcGroup = 'Chandelier exit settings'
length = input.int(title='ATR Period', defval=1, group=calcGroup)
mult = input.float(title='ATR Multiplier', step=0.1, defval=2.0, group=calcGroup)
useClose = input.bool(title='Use Close Price for Extremums', defval=true, group=calcGroup)

var string visualGroup = 'Visuals'
showLabels = input.bool(title='Show Buy/Sell Labels', defval=true, group=visualGroup)
highlightState = input.bool(title='Highlight State', defval=true, group=visualGroup)

var string alertGroup = 'Alerts'
awaitBarConfirmation = input.bool(title="Await Bar Confirmation", defval=true, group=alertGroup)

atr = mult * ta.atr(length)

longStop = (useClose ? ta.highest(close, length) : ta.highest(length)) - atr
longStopPrev = nz(longStop[1], longStop)
longStop := close[1] > longStopPrev ? math.max(longStop, longStopPrev) : longStop

shortStop = (useClose ? ta.lowest(close, length) : ta.lowest(length)) + atr
shortStopPrev = nz(shortStop[1], shortStop)
shortStop := close[1] < shortStopPrev ? math.min(shortStop, shortStopPrev) : shortStop

var int dir = 1
dir := close > shortStopPrev ? 1 : close < longStopPrev ? -1 : dir

var color longColor = color.green
var color shortColor = color.red
var color longFillColor = color.new(color.green, 90)
var color shortFillColor = color.new(color.red, 90)
var color textColor = color.new(color.white, 0)

longStopPlot = plot(dir == 1 ? longStop : na, title='Long Stop', style=plot.style_linebr, linewidth=2, color=color.new(longColor, 0))
buySignal = dir == 1 and dir[1] == -1
plotshape(buySignal ? longStop : na, title='Long Stop Start', location=location.absolute, style=shape.circle, size=size.tiny, color=color.new(longColor, 0))
plotshape(buySignal and showLabels ? longStop : na, title='Buy Label', text='Buy', location=location.absolute, style=shape.labelup, size=size.tiny, color=color.new(longColor, 0), textcolor=textColor)

shortStopPlot = plot(dir == 1 ? na : shortStop, title='Short Stop', style=plot.style_linebr, linewidth=2, color=color.new(shortColor, 0))
sellSignal = dir == -1 and dir[1] == 1
plotshape(sellSignal ? shortStop : na, title='Short Stop Start', location=location.absolute, style=shape.circle, size=size.tiny, color=color.new(shortColor, 0))
plotshape(sellSignal and showLabels ? shortStop : na, title='Sell Label', text='Sell', location=location.absolute, style=shape.labeldown, size=size.tiny, color=color.new(shortColor, 0), textcolor=textColor)

midPricePlot = plot(ohlc4, title='', style=plot.style_circles, linewidth=0, display=display.none, editable=false)

longStateFillColor = highlightState ? dir == 1 ? longFillColor : na : na
shortStateFillColor = highlightState ? dir == -1 ? shortFillColor : na : na
fill(midPricePlot, longStopPlot, title='Long State Filling', color=longStateFillColor)
fill(midPricePlot, shortStopPlot, title='Short State Filling', color=shortStateFillColor)

await = awaitBarConfirmation ? barstate.isconfirmed : true
alertcondition(dir != dir[1] and await, title='Alert: CE Direction Change', message='Chandelier Exit has changed direction!')
alertcondition(buySignal and await, title='Alert: CE Buy', message='Chandelier Exit Buy!')
alertcondition(sellSignal and await, title='Alert: CE Sell', message='Chandelier Exit Sell!')




//---------------------------------------Chandelier Exit conditisions 
//---------long
longc2 = buySignal
longclose2 = sellSignal
//---------short
shortc2 = sellSignal
shortclose2 = buySignal



//---------------------------------------Long entry and exit
if longc1 and longc2 
    strategy.entry("long", strategy.long)

if strategy.position_avg_price > 0
    strategy.exit("close long", "long", limit = takeProfitPrice, stop = stopLossPrice, alert_message = "close all orders")

if longclose1 and longclose2 and strategy.opentrades == 1
    strategy.close("long","ema long cross", alert_message = "close all orders")


//---------------------------------------Short entry and exit
if shortc1 and shortc2 
    strategy.entry("short", strategy.short)

if strategy.position_avg_price > 0
    strategy.exit("close short", "short", limit = takeProfitPrice2, stop = stopLossPrice2, alert_message = "close all orders")

if shortclose1 and shortclose2 and strategy.opentrades == 1
    strategy.close("close short","short", alert_message = "close all orders")




আরো