এই কৌশলটি একটি অভিযোজিত ট্রেডিং সিস্টেম যা একাধিক প্রযুক্তিগত বিশ্লেষণ সূচককে একত্রিত করে এবং গতিশীলভাবে বাজারের শর্তগুলি সনাক্ত করে বিভিন্ন ট্রেডিং কৌশলগুলির মধ্যে স্যুইচ করে। সিস্টেমটি মূলত চলমান গড় (এমএ), বলিংজার ব্যান্ড (বিবি) এবং আপেক্ষিক শক্তি সূচক (আরএসআই) এর উপর ভিত্তি করে, বাজারের প্রবণতা এবং পরিসীমা দোলনের বৈশিষ্ট্য অনুসারে স্বয়ংক্রিয়ভাবে সবচেয়ে উপযুক্ত ট্রেডিং পদ্ধতি নির্বাচন করে। কৌশলটি বিভিন্ন লাভ এবং স্টপ-লস পরামিতি সেট করে ট্রেন্ডিং এবং ব্যাপ্তি বাজারের জন্য বৈচিত্র্যযুক্ত ঝুঁকি ব্যবস্থাপনা সমাধান বাস্তবায়ন করে।
এই কৌশলটি বাজারের প্রবণতা নির্ধারণের জন্য ৫০-পরিসরের এবং ২০-পরিসরের চলমান গড় ব্যবহার করে, ওভারব্রেকড এবং ওভারসোল্ড অঞ্চলগুলি সনাক্ত করার জন্য বোলিংজার ব্যান্ড এবং আরএসআই এর সাথে একত্রিত। ট্রেন্ডিং মার্কেটে, সিস্টেমটি মূলত ধীর চলমান গড়ের সাথে দামের সম্পর্ক এবং দ্রুত এবং ধীর লাইনের মধ্যে ক্রসওভারের উপর ভিত্তি করে ট্রেড করে; ব্যাপ্তি বাজারে, এটি মূলত বোলিংজার ব্যান্ডের ব্রেকআউট এবং আরএসআই ওভারব্রেকড / ওভারসোল্ড সংকেতগুলিতে ট্রেড করে। সিস্টেমটি ঝুঁকি নিয়ন্ত্রণের জন্য অভিন্ন 2% স্টপ-লস সহ ট্রেন্ডিং মার্কেটের জন্য 6% এবং ব্যাপ্তি বাজারের জন্য 4% ব্যবহার করে বাজারের অবস্থার সাথে স্বয়ংক্রিয়ভাবে লাভের মাত্রা সামঞ্জস্য করে।
এই কৌশলটি একাধিক ক্লাসিকাল প্রযুক্তিগত সূচককে একত্রিত করে বিভিন্ন বাজারের পরিবেশে অভিযোজিত করতে সক্ষম একটি অভিযোজিত ট্রেডিং সিস্টেম তৈরি করে। অপারেশনাল সরলতা বজায় রেখে, সিস্টেমটি গতিশীল বাজার অবস্থা সনাক্তকরণ এবং স্বয়ংক্রিয় ট্রেডিং কৌশল স্যুইচিং অর্জন করে, শক্তিশালী ব্যবহারিকতা প্রদর্শন করে। পার্থক্যযুক্ত লাভ এবং স্টপ-লস সেটিংসের মাধ্যমে, কৌশলটি ঝুঁকি নিয়ন্ত্রণের সময় ভাল মুনাফা বজায় রাখে। আরও প্রযুক্তিগত সূচক প্রবর্তন এবং পরামিতি সমন্বয় প্রক্রিয়াগুলি অনুকূল করে কৌশল স্থিতিশীলতা এবং নির্ভরযোগ্যতা আরও বাড়ানো যেতে পারে।
/*backtest start: 2024-01-17 00:00:00 end: 2025-01-16 00:00:00 period: 1d basePeriod: 1d exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT","balance":49999}] */ //@version=6 strategy("Supply & Demand Test 1 - Enhanced", overlay=true) // Inputs ma_length = input.int(50, title="50-period Moving Average Length", minval=1) ma_length_fast = input.int(20, title="20-period Moving Average Length", minval=1) bb_length = input.int(20, title="Bollinger Bands Length", minval=1) bb_std_dev = input.float(2.0, title="Bollinger Bands Std Dev", step=0.1) rsi_length = input.int(14, title="RSI Length", minval=1) stop_loss_percent = input.float(0.02, title="Stop Loss Percent", step=0.001, minval=0.001) take_profit_trend = input.float(0.06, title="Take Profit Percent (Trend)", step=0.001, minval=0.001) take_profit_range = input.float(0.04, title="Take Profit Percent (Range)", step=0.001, minval=0.001) // Moving Averages ma_slow = ta.sma(close, ma_length) ma_fast = ta.sma(close, ma_length_fast) // Bollinger Bands bb_basis = ta.sma(close, bb_length) bb_dev = ta.stdev(close, bb_length) bb_upper = bb_basis + bb_std_dev * bb_dev bb_lower = bb_basis - bb_std_dev * bb_dev // RSI rsi = ta.rsi(close, rsi_length) // Market Conditions is_trending_up = close > ma_slow is_trending_down = close < ma_slow is_range_bound = not (is_trending_up or is_trending_down) // Entry Conditions long_trend_entry = is_trending_up and close >= ma_slow * 1.02 short_trend_entry = is_trending_down and close <= ma_slow * 0.98 long_ma_crossover = ta.crossover(ma_fast, ma_slow) short_ma_crossover = ta.crossunder(ma_fast, ma_slow) long_range_entry = is_range_bound and close <= bb_lower * 0.97 short_range_entry = is_range_bound and close >= bb_upper * 1.03 long_rsi_entry = is_range_bound and rsi < 30 short_rsi_entry = is_range_bound and rsi > 70 // Entry and Exit Logic if long_trend_entry strategy.entry("Long Trend", strategy.long) strategy.exit("Exit Long Trend", from_entry="Long Trend", stop=close * (1 - stop_loss_percent), limit=close * (1 + take_profit_trend)) alert("Entered Long Trend", alert.freq_once_per_bar) if short_trend_entry strategy.entry("Short Trend", strategy.short) strategy.exit("Exit Short Trend", from_entry="Short Trend", stop=close * (1 + stop_loss_percent), limit=close * (1 - take_profit_trend)) alert("Entered Short Trend", alert.freq_once_per_bar) if long_ma_crossover strategy.entry("Long MA Crossover", strategy.long) strategy.exit("Exit Long MA Crossover", from_entry="Long MA Crossover", stop=close * (1 - stop_loss_percent), limit=close * (1 + take_profit_trend)) alert("Entered Long MA Crossover", alert.freq_once_per_bar) if short_ma_crossover strategy.entry("Short MA Crossover", strategy.short) strategy.exit("Exit Short MA Crossover", from_entry="Short MA Crossover", stop=close * (1 + stop_loss_percent), limit=close * (1 - take_profit_trend)) alert("Entered Short MA Crossover", alert.freq_once_per_bar) if long_range_entry strategy.entry("Long Range", strategy.long) strategy.exit("Exit Long Range", from_entry="Long Range", stop=close * (1 - stop_loss_percent), limit=close * (1 + take_profit_range)) alert("Entered Long Range", alert.freq_once_per_bar) if short_range_entry strategy.entry("Short Range", strategy.short) strategy.exit("Exit Short Range", from_entry="Short Range", stop=close * (1 + stop_loss_percent), limit=close * (1 - take_profit_range)) alert("Entered Short Range", alert.freq_once_per_bar) if long_rsi_entry strategy.entry("Long RSI", strategy.long) strategy.exit("Exit Long RSI", from_entry="Long RSI", stop=close * (1 - stop_loss_percent), limit=close * (1 + take_profit_range)) alert("Entered Long RSI", alert.freq_once_per_bar) if short_rsi_entry strategy.entry("Short RSI", strategy.short) strategy.exit("Exit Short RSI", from_entry="Short RSI", stop=close * (1 + stop_loss_percent), limit=close * (1 - take_profit_range)) alert("Entered Short RSI", alert.freq_once_per_bar) // Plotting plot(ma_slow, color=color.blue, title="50-period MA") plot(ma_fast, color=color.orange, title="20-period MA") plot(bb_upper, color=color.red, title="Bollinger Upper") plot(bb_lower, color=color.green, title="Bollinger Lower") plot(bb_basis, color=color.gray, title="Bollinger Basis") hline(70, "Overbought (RSI)", color=color.red, linestyle=hline.style_dotted) hline(30, "Oversold (RSI)", color=color.green, linestyle=hline.style_dotted)