কন্ট্রাকশন ব্যান্ড বলিঙ্গার এবং আরএসআই কম্বিনেশন স্ট্র্যাটেজি


সৃষ্টির তারিখ: 2024-01-30 15:15:32 অবশেষে সংশোধন করুন: 2024-01-30 15:15:32
অনুলিপি: 0 ক্লিকের সংখ্যা: 661
1
ফোকাস
1617
অনুসারী

কন্ট্রাকশন ব্যান্ড বলিঙ্গার এবং আরএসআই কম্বিনেশন স্ট্র্যাটেজি

ওভারভিউ

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

কৌশল নীতি

এই কৌশলটির ট্রেডিং লজিকের মূলটি হল বুয়েন ব্যান্ডের সংকোচন সনাক্ত করা এবং RSI যখন উত্থানমুখী হয় তখন ট্রেন্ডটি উত্থানের প্রথম দিকে থাকে। বিশেষত, যখন 20 তম বুয়েন ব্যান্ডের মধ্যবর্তী ট্র্যাকের মানটি ATR এর চেয়ে কম হয়*2 এ, আমরা সিদ্ধান্ত নিই যে বুইলিন ব্যান্ড সংকীর্ণ হয়েছে; একই সময়ে, যদি 10 এবং 14 তারিখের RSI উভয়ই উত্থানের দিকে থাকে, তবে আমরা পূর্বাভাস দিচ্ছি যে দামগুলি বুইলিন ব্যান্ডটি ভেঙে ফেলার পথে রয়েছে এবং একাধিক কৌশল গ্রহণ করবে।

যখন আমরা মাঠে প্রবেশ করি, আমরা ATR নিরাপদ দূরত্ব + দাম বাড়ার সাথে সাথে স্টপ লস ব্যবহার করে মুনাফা লক করি এবং ঝুঁকি নিয়ন্ত্রণ করি। যখন দাম স্টপ লাইন অতিক্রম করে বা RSI overheats (যেমন 14 দিনের RSI 70 এর বেশি, 10 দিনের RSI 14 দিনের RSI এর বেশি) তখন আমরা পজিশনটি বন্ধ করি।

সামর্থ্য বিশ্লেষণ

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

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

এই কৌশলটির প্রধান ঝুঁকি হল বুইলিন-ব্যান্ড সংকোচন এবং RSI উত্থান সনাক্ত করা, যখন বাজারটি মিথ্যা ব্রেকডাউন হতে পারে। এছাড়াও, স্টপ-এর ক্ষেত্রে, অত্যধিক ওঠানামা হলে অভিযোজিত স্টপ সময়মত বন্ধ হতে পারে না। এই ঝুঁকিটি স্টপ-এর পদ্ধতির উন্নতি করে হ্রাস করা যেতে পারে (যেমন কার্ভ স্টপ) ।

অপ্টিমাইজেশান দিক

এই কৌশলটি নিম্নলিখিত দিকগুলি থেকে উন্নত করা যেতে পারেঃ

  1. ব্রিন-ব্যান্ড প্যারামিটার সেটিং উন্নত করা হয়েছে, যাতে সংকোচনের প্রভাবের বিচার করা যায়

  2. বিভিন্ন RSI প্যারামিটার চেষ্টা করুন

  3. অন্যান্য ক্ষতি বন্ধ করার পদ্ধতির পরীক্ষা করা হচ্ছে (যেমন কার্ভ স্টপ, রিভিউ স্টপ)

  4. বিভিন্ন জাতের বৈশিষ্ট্য অনুসারে প্যারামিটারগুলি সামঞ্জস্য করুন

সারসংক্ষেপ

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

কৌশল সোর্স কোড
/*backtest
start: 2023-12-01 00:00:00
end: 2023-12-31 23:59:59
period: 1h
basePeriod: 15m
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/
// © DojiEmoji
// 

//@version=4
strategy("[KL] BOLL + RSI Strategy",overlay=true,pyramiding=1)

// Timeframe {
backtest_timeframe_start = input(defval = timestamp("01 Apr 2016 13:30 +0000"), title = "Backtest Start Time", type = input.time)
USE_ENDTIME = input(false,title="Define backtest end-time (If false, will test up to most recent candle)")
backtest_timeframe_end = input(defval = timestamp("01 May 2021 19:30 +0000"), title = "Backtest End Time (if checked above)", type = input.time)
within_timeframe = true
// }

// Bollinger bands (sdv=2, len=20) {
BOLL_length = 20, BOLL_src = close, SMA20 = sma(BOLL_src, BOLL_length), BOLL_sDEV_x2 = 2 * stdev(BOLL_src, BOLL_length)
BOLL_upper = SMA20 + BOLL_sDEV_x2, BOLL_lower = SMA20 - BOLL_sDEV_x2
plot(SMA20, "Basis", color=#872323, offset = 0)
BOLL_p1 = plot(BOLL_upper, "BOLL Upper", color=color.navy, offset = 0, transp=50)
BOLL_p2 = plot(BOLL_lower, "BOLL Lower", color=color.navy, offset = 0, transp=50)
fill(BOLL_p1, BOLL_p2, title = "Background", color=#198787, transp=85)
// }

// Volatility Indicators {
ATR_x2 = atr(BOLL_length) * 2 // multiplier aligns with BOLL
avg_atr = sma(ATR_x2, input(1,title="No. of candles to lookback when determining ATR is decreasing"))
plot(SMA20+ATR_x2, "SMA20 + ATR_x2", color=color.gray, offset = 0, transp=50)
plot(SMA20-ATR_x2, "SMA20 - ATR_x2", color=color.gray, offset = 0, transp=50)
plotchar(ATR_x2, "ATR_x2", "", location = location.bottom)
//}

// Trailing stop loss {
TSL_source = low
var entry_price = float(0), var stop_loss_price = float(0)

trail_profit_line_color = color.green
if strategy.position_size == 0 or not within_timeframe
    trail_profit_line_color := color.black
    stop_loss_price := TSL_source - ATR_x2
else if strategy.position_size > 0
    stop_loss_price := max(stop_loss_price, TSL_source - ATR_x2)
plot(stop_loss_price, color=trail_profit_line_color)

if strategy.position_size > 0 and stop_loss_price > stop_loss_price[1]
	alert("Stop loss limit raised", alert.freq_once_per_bar)

// } end of Trailing stop loss

//Buy setup - Long positions {
is_squeezing = ATR_x2 > BOLL_sDEV_x2
if is_squeezing and within_timeframe and not is_squeezing[1]
	alert("BOLL bands are squeezing", alert.freq_once_per_bar)
else if not is_squeezing and within_timeframe and is_squeezing[1]
	alert("BOLL bands stopped squeezing", alert.freq_once_per_bar)

ema_trend = ema(close, 20)

concat(a, b) =>
	concat = a
	if a != ""
		concat := concat + ", "
	concat := concat + b
	concat
// }

// Sell setup - Long position {
rsi_10 = rsi(close, 10), rsi_14 = rsi(close, 14)
overbought = rsi_14 > input(70,title="[Exit] RSI(14) value considered as overbought") and rsi_10 > rsi_14
// } end of Sell setup - Long position

// MAIN: {
if within_timeframe
	entry_msg = ""
	exit_msg = ""

    // ENTRY {
	conf_count = 0	
    volat_decr = avg_atr <= avg_atr[1]
	rsi_upslope = rsi_10 > rsi_10[1] and rsi_14 > rsi_14[1]

	if volat_decr and rsi_upslope and is_squeezing and strategy.position_size == 0
		strategy.entry("Long",strategy.long, comment=entry_msg)
		entry_price := close
		stop_loss_price := TSL_source - ATR_x2
	// }

    // EXIT	{
	if strategy.position_size > 0
		bExit = false
		if close <= entry_price and TSL_source <= stop_loss_price
            exit_msg := concat(exit_msg, "stop loss [TSL]")
			bExit := true
        else if close > entry_price and TSL_source <= stop_loss_price
            exit_msg := concat(exit_msg, "take profit [TSL]")
            bExit := true
		else if overbought
			exit_msg := concat(exit_msg, "overbought")
			bExit := true

        strategy.close("Long", when=bExit, comment=exit_msg)
	// }
// }

// CLEAN UP:
if strategy.position_size == 0 and not is_squeezing
	entry_price := 0
	stop_loss_price := float(0)