আপেক্ষিক ভলিউম এবং ট্রেন্ডের উপর ভিত্তি করে ট্রেডিং কৌশল


সৃষ্টির তারিখ: 2023-10-17 16:19:59 অবশেষে সংশোধন করুন: 2023-10-17 16:19:59
অনুলিপি: 0 ক্লিকের সংখ্যা: 648
1
ফোকাস
1617
অনুসারী

আপেক্ষিক ভলিউম এবং ট্রেন্ডের উপর ভিত্তি করে ট্রেডিং কৌশল

ওভারভিউ

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

কৌশল নীতি

  1. Bollinger Bands ব্যবহার করে দামের সামান্য ওঠানামা কিনা তা নির্ধারণ করুন। এটি এটিআর এবং BOLL চ্যানেলের ব্যান্ডউইথের তুলনা করে।

  2. গত N দিনের গড় লেনদেনের পরিমাণ গণনা করুন এবং বর্তমান ভলিউমের সাথে তুলনা করে দেখুন যে লেনদেনের পরিমাণ বৃদ্ধি পেয়েছে কিনা।

  3. যখন দাম কম থাকে, তখন লেনদেনের পরিমাণ বৃদ্ধি পায় এবং যখন দাম কম থাকে তখন ক্রয় করা হয়।

  4. স্টপ লস সেট করুন, সর্বনিম্ন মূল্য আপডেট ট্র্যাক করুন।

  5. যখন দাম নিচে স্টপ লস পয়েন্ট অতিক্রম করে তখন স্টপ লস হয়।

  6. যখন দাম একটি মাল্টি-হেড গ্রাস প্যাটার্ন গঠন করে তখন স্টপ।

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

  1. ট্র্যাফিক এবং অস্থিরতার সূচকগুলির সমন্বয়ে, জাল ব্রেকআপগুলি কার্যকরভাবে ফিল্টার করা যায়।

  2. ট্রেন্ড ট্র্যাকিং স্টপ লস পদ্ধতি ব্যবহার করে, আপনি লাভের সর্বাধিক লকিং করতে পারেন।

  3. ট্রেন্ডের বিপরীতমুখী প্রবণতার প্রাক্কালে, স্টপ সিগন্যাল হিসাবে মাল্টি হেড ইট ইত্যাদির মতো মডেলের বিচার ব্যবহার করে স্টপ করা যেতে পারে।

  4. এই কৌশলটি সহজ, সহজেই বোঝা যায় এবং অনুসরণ করা যায়।

  5. স্টপ-ড্যামেজ এবং স্টপ-স্টপ নিয়মগুলি আরও স্পষ্ট, যা লকডাউন অ্যান্টিসিপ্যাটের অনিশ্চয়তা হ্রাস করে।

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

  1. শিক্ষাপ্রতিষ্ঠানগুলোতে ভর্তি পরীক্ষার সময়সীমার মধ্যে দেরি হচ্ছে, যার ফলে ভর্তি পরীক্ষার সেরা পয়েন্টগুলো মিস করা হচ্ছে।

  2. মাল্টি-হেড গ্রাসের মতো রূপগুলি থামার সংকেত হিসাবে যথেষ্ট নির্ভরযোগ্য নাও হতে পারে, এবং খুব তাড়াতাড়ি থামার ঝুঁকি রয়েছে।

  3. স্টপ লস পয়েন্টের পরে, একক ক্ষতির ঝুঁকি বেশি।

  4. যুক্তিসঙ্গত প্যারামিটার সমন্বয় প্রয়োজন, যেমন ATR এবং লেনদেনের পরিমাণের চক্র, অন্যথায় ঘন ঘন লেনদেন হতে পারে।

  5. এই ক্ষেত্রে, স্টপ-অফ-লস নিয়মগুলিকে মনোযোগ দিতে হবে এবং অপ্রয়োজনীয় পজিশনের সম্ভাবনা হ্রাস করতে হবে।

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

  1. অন্যান্য সূচক যেমন MACD ইত্যাদি দিয়ে প্রবেশের সংকেত ফিল্টার করার চেষ্টা করুন।

  2. এটিআর এবং লেনদেনের পরিমাণের চক্রের প্যারামিটারগুলিকে অপ্টিমাইজ করে এবং ঘন ঘন লেনদেনের ঝুঁকি হ্রাস করে।

  3. অন্যান্য স্টপ সিগন্যাল চেষ্টা করুন, যেমন এক্সট মেকানিজম যেমন মূল্য বিপর্যয়।

  4. এই গবেষণায় আরও বেশি মুনাফা লাভের সম্ভাবনার কথা বলা হয়েছে, যার জন্য স্টপ লসকে গতিশীলভাবে সামঞ্জস্য করা হয়েছে।

  5. বিভিন্ন পজিশনের সময়কালের উপর পারফরম্যান্সের প্রভাব পরীক্ষা করুন এবং সর্বোত্তম পজিশনের সময়কাল খুঁজুন।

  6. বিভিন্ন জাতের চুক্তির প্রভাব পর্যবেক্ষণ করুন এবং সবচেয়ে উপযুক্ত জাত খুঁজে বের করুন।

সারসংক্ষেপ

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

কৌশল সোর্স কোড
/*backtest
start: 2022-10-10 00:00:00
end: 2023-10-16 00:00:00
period: 1d
basePeriod: 1h
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 (kevinhhl)

//@version=4
strategy("[KL] Relative Volume Strategy",overlay=true,pyramiding=1)
ENUM_LONG = "Long"
VERBOSE_MODE = false
opened_position = false

// 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
// }

// Volatility Indicators {
// BOLL:
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)
// ATR v. sDev of prices
ATR_x2 = atr(input(10,title="Length of ATR [Trailing Stop Loss] (x2)"))*2
//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)
is_low_volat = ATR_x2 > BOLL_sDEV_x2
// }

// Trailing stop loss {
TSL_source = low

var entry_price = float(0), var stop_loss_price = float(0)

TSL_line_color = color.green
if strategy.position_size == 0 or not within_timeframe
    TSL_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=TSL_line_color)

// }

// Relative volume indicator {
LEN_RELATIVE_VOL = input(5, title="SMA(volume) length (for relative comparison)")
relative_vol = sma(volume,LEN_RELATIVE_VOL)
// }

// price actions {
bar_range_ratio = abs(close-open)/(high-low)
engulfing = low < low[1] and high > high[1] and abs(close-open) > abs(close-open)[1]
// }

// MAIN:
if within_timeframe
	entry_msg = "", exit_msg = close <= entry_price ? "stop loss" : "take profit"

    // ENTRY :::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
	if close > open and volume > relative_vol and is_low_volat
		if strategy.position_size > 0
			entry_msg := "adding"
		else if strategy.position_size == 0
			entry_msg := "initial"

		if strategy.position_size == 0
			entry_price := close
			stop_loss_price := TSL_source - ATR_x2
			ATR_x2 := ATR_x2

		strategy.entry(ENUM_LONG, strategy.long, comment=entry_msg)

    // EXIT ::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
	if strategy.position_size > 0
		bExit = false		
		// EXIT: Case (A) touches trailing stop loss
		if TSL_source <= stop_loss_price
			exit_msg := exit_msg + "[TSL]"
			bExit := true
		// EXIT: Case (B)
		else if close < open and not is_low_volat and engulfing and (high-low) > ATR_x2
			exit_msg := VERBOSE_MODE ? exit_msg + "[engulfing bearish]" : exit_msg
			bExit := true
        strategy.close(ENUM_LONG, when=bExit, comment=exit_msg)

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