এটি একটি পরিমাণগত ট্রেডিং কৌশল যা একাধিক প্রযুক্তিগত সূচককে অন্তর্ভুক্ত করে। এটি একটি মাল্টি-ফ্যাক্টর মডেল চালিত স্বয়ংক্রিয় ট্রেডিং বাস্তবায়নের জন্য চলমান গড়, এমএসিডি, বলিংজার ব্যান্ড, আরএসআই এবং অন্যান্য সূচকগুলিকে একত্রিত করে।
এই কৌশলটির ট্রেডিং সিগন্যালগুলি নিম্নলিখিত অংশগুলি থেকে আসেঃ
যখন উপরের সূচকগুলি একযোগে ক্রয় বা বিক্রয় সংকেত দেয়, তখন কৌশলটি সংশ্লিষ্ট দীর্ঘ বা স্বল্প সিদ্ধান্ত নেবে।
বিশেষ করে, যখন দ্রুত চলমান গড় ধীর গতির গড় অতিক্রম করে, তখন এমএসিডি হিস্টোগ্রামগুলি বৃদ্ধি পেতে শুরু করে, আরএসআই ওভারসোল্ড অঞ্চল থেকে ফিরে আসে এবং দাম বোলিংজার ব্যান্ডের নিম্ন রেলের কাছে আসে, এটি দীর্ঘ প্রবেশের জন্য প্রবণতা বিপরীত সংকেত হিসাবে বিবেচিত হয়।
এবং যখন দ্রুত এমএ ধীর এমএ এর নিচে অতিক্রম করে, এমএসিডি হিস্টোগ্রামগুলি হ্রাস পেতে শুরু করে, আরএসআই ওভারকোপড এলাকা থেকে পড়ে এবং দাম উপরের বোলিংজার ব্যান্ডে পৌঁছায়, এটি সংক্ষিপ্ত প্রবেশের জন্য স্বল্পমেয়াদী শীর্ষ বিপরীত হিসাবে বিবেচিত হয়।
একাধিক সূচক থেকে সংকেত একত্রিত করে, ভুয়া সংকেতগুলি কার্যকরভাবে ফিল্টার করা যায় এবং কৌশলটির স্থিতিশীলতা উন্নত করা যায়।
এই কৌশলটির সবচেয়ে বড় সুবিধা হল যে এটি ট্রেডিংয়ের জন্য একটি বহু-ফ্যাক্টর মডেল গ্রহণ করে, যা সংকেতগুলির নির্ভরযোগ্যতা, স্থিতিশীলতা এবং কৌশলটির লাভজনকতা বাড়ায়।
মাল্টি-ফ্যাক্টর মডেলটি ট্রেডিং সিগন্যালগুলি একে অপরের সাথে যাচাই করতে পারে এবং জাল সংকেতগুলির হস্তক্ষেপ কার্যকরভাবে হ্রাস করতে পারে।
বিভিন্ন শ্রেণীর সূচকগুলি বাজারের গতিবিধিগুলির আরও বিস্তৃত বৈশিষ্ট্যগুলি ক্যাপচার করতে পারে এবং আরও সঠিক বিচার করতে পারে।
একাধিক সূচকের সমন্বয় পৃথক সূচকগুলির ওঠানামা স্থির করতে পারে এবং আরও স্থিতিশীল আয় নিশ্চিত করতে পারে।
বিভিন্ন বাজারের অবস্থার জন্য কৌশলটি কাস্টমাইজ করার জন্য সংমিশ্রণে সূচক এবং তাদের ওজনগুলি নমনীয়ভাবে সামঞ্জস্য করা যেতে পারে।
এই কৌশলটির কিছু ঝুঁকি সম্পর্কে চিন্তা করা উচিতঃ
একাধিক সূচকগুলির জটিল সংমিশ্রণের জন্য সুনির্দিষ্ট পরামিতি সেটআপ এবং পরীক্ষার প্রয়োজন, অন্যথায় এটি অবৈধ সংকেত তৈরি করতে পারে।
একক পণ্যের পারফরম্যান্স যথেষ্ট স্থিতিশীল নাও হতে পারে। ঝুঁকিগুলিকে বৈচিত্র্যময় করার জন্য উপযুক্ত পণ্যগুলির সমন্বয়ে গঠিত একটি পোর্টফোলিও তৈরি করা উচিত।
চরম বাজারের পরিস্থিতিতে ক্ষতির পরিমাণ সীমিত করার জন্য পজিশনের আকার এবং স্টপ লস প্রক্রিয়া কঠোরভাবে নিয়ন্ত্রণ করা উচিত।
এই কৌশলটি কিছু দিক থেকে অপ্টিমাইজ করা যেতে পারেঃ
অপ্টিমাম প্যারামিটার যেমন নিমজ্জিত অস্থিরতা, ভলিউম ইত্যাদির জন্য আরও সূচকগুলির সমন্বয় পরীক্ষা করুন।
স্বয়ংক্রিয়ভাবে সূচক এবং প্যারামিটার সেটগুলির সর্বোত্তম সংমিশ্রণ তৈরি করতে মেশিন লার্নিং পদ্ধতি ব্যবহার করুন।
দীর্ঘ সময়সীমার উপর আরো ব্যাকটেস্ট এবং অপ্টিমাইজেশান করুন, বিভিন্ন বাজারের পর্যায়ে সেই অনুযায়ী ওজন সামঞ্জস্য করুন।
একক লেনদেন এবং সামগ্রিক পজিশনের ক্ষতি কঠোরভাবে নিয়ন্ত্রণ করার জন্য ঝুঁকি ব্যবস্থাপনা সরঞ্জাম অন্তর্ভুক্ত করুন।
এই কৌশলটি বিভিন্ন প্রযুক্তিগত সূচকগুলির সুবিধাগুলি পুরোপুরি ব্যবহার করে এবং একটি মাল্টি-ফ্যাক্টর মডেল গঠন করে, যা সিগন্যালগুলির নির্ভুলতা কার্যকরভাবে উন্নত করে। এদিকে, ঝুঁকি নিয়ন্ত্রণ, পরামিতিগুলি সামঞ্জস্য এবং কৌশল আপডেট করা স্থিতিশীলতা এবং মুনাফা বাড়িয়ে তুলতে গুরুত্বপূর্ণ।
/*backtest start: 2023-12-31 00:00:00 end: 2024-01-30 00:00:00 period: 4h basePeriod: 15m exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=5 strategy("Математическая Торговая Система с Ишимоку, TP/SL, ADX, RSI, OBV", shorttitle="МТС Ишимоку TP/SL ADX RSI OBV", overlay=true) is_short_enable = input(0, title="Короткие сделки") is_long_enable = input(1, title="Длинные сделки") // Входные параметры для скользящих средних fast_length = input(21, title="Быстрый период") slow_length = input(26, title="Медленный период") // Входные параметры для Ишимоку tenkan_length = input(9, title="Тенкан-сен") kijun_length = input(26, title="Киджун-сен") senkou_length = input(52, title="Сенкоу-спан B") // Входные параметры для ADX adx_length = input(14, title="ADX период") adx_level = input(30, title="ADX уровень") // Входные параметры для RSI rsi_length = input(14, title="RSI период") rsi_overbought = input(70, title="RSI перекупленность") rsi_oversold = input(30, title="RSI перепроданность") // Входные параметры для OBV obv_length = input(14, title="OBV период") // Вычисление скользящих средних fast_ma = ta.sma(close, fast_length) slow_ma = ta.sma(close, slow_length) // Вычисление Ишимоку tenkan_sen = ta.sma(high + low, tenkan_length) / 2 kijun_sen = ta.sma(high + low, kijun_length) / 2 senkou_span_a = (tenkan_sen + kijun_sen) / 2 senkou_span_b = ta.sma(close, senkou_length) // Вычисление ADX [diplus, diminus, adx_value] = ta.dmi(14, adx_length) // Вычисление RSI rsi_value = ta.rsi(close, rsi_length) // Вычисление OBV f_obv() => ta.cum(math.sign(ta.change(close)) * volume) f_obv_1() => ta.cum(math.sign(ta.change(close[1])) * volume[1]) f_obv_2() => ta.cum(math.sign(ta.change(close[2])) * volume[2]) f_obv_3() => ta.cum(math.sign(ta.change(close[3])) * volume[3]) obv_value = f_obv() price_is_up = close[1] > close[3] price_crossover_fast_ma = close > fast_ma fast_ma_is_up = ta.sma(close[1], fast_length) > ta.sma(close[3], fast_length) rsi_is_trand_up = ta.rsi(close[1], rsi_length) > ta.rsi(close[3], rsi_length) rsi_is_upper_50 = rsi_value > 50 obv_is_trand_up = f_obv_1() > f_obv_3() and obv_value > ta.sma(obv_value, obv_length) is_up = price_is_up and price_crossover_fast_ma and fast_ma_is_up and rsi_is_trand_up and rsi_is_upper_50 and obv_is_trand_up fast_ma_is_down = close < fast_ma rsi_is_trend_down = ta.rsi(close[1], rsi_length) < ta.rsi(close[2], rsi_length) rsi_is_crossover_sma = rsi_value < ta.sma(rsi_value, rsi_length) obv_is_trend_down = f_obv_1() < f_obv_2() obv_is_crossover_sma = obv_value < ta.sma(obv_value, obv_length) is_down = fast_ma_is_down and rsi_is_trend_down and rsi_is_crossover_sma and obv_is_trend_down and obv_is_crossover_sma //----------// // MOMENTUM // //----------// ema8 = ta.ema(close, 8) ema13 = ta.ema(close, 13) ema21 = ta.ema(close, 21) ema34 = ta.ema(close, 34) ema55 = ta.ema(close, 55) longEmaCondition = ema8 > ema13 and ema13 > ema21 and ema21 > ema34 and ema34 > ema55 exitLongEmaCondition = ema13 < ema55 shortEmaCondition = ema8 < ema13 and ema13 < ema21 and ema21 < ema34 and ema34 < ema55 exitShortEmaCondition = ema13 > ema55 // ---------- // // OSCILLATORS // // ----------- // rsi = ta.rsi(close, 14) longRsiCondition = rsi < 70 and rsi > 40 exitLongRsiCondition = rsi > 70 shortRsiCondition = rsi > 30 and rsi < 60 exitShortRsiCondition = rsi < 30 // Stochastic length = 14, smoothK = 3, smoothD = 3 kFast = ta.stoch(close, high, low, 14) dSlow = ta.sma(kFast, smoothD) longStochasticCondition = kFast < 80 exitLongStochasticCondition = kFast > 95 shortStochasticCondition = kFast > 20 exitShortStochasticCondition = kFast < 5 // Логика входа и выхода longCondition = longEmaCondition and longRsiCondition and longStochasticCondition and strategy.position_size == 0 exitLongCondition = (exitLongEmaCondition or exitLongRsiCondition or exitLongStochasticCondition) and strategy.position_size > 0 shortCondition = shortEmaCondition and shortRsiCondition and shortStochasticCondition and strategy.position_size == 0 exitShortCondition = (exitShortEmaCondition or exitShortRsiCondition or exitShortStochasticCondition) and strategy.position_size < 0 enter_long = (ta.crossover(close, senkou_span_a) or is_up) and longCondition enter_short = (ta.crossunder(close, senkou_span_a) or is_down) and shortCondition exit_long = ((ta.crossunder(fast_ma, slow_ma) or ta.crossunder(close, senkou_span_b) or enter_short) or exitLongCondition) exit_short = ((ta.crossover(fast_ma, slow_ma) or ta.crossover(close, senkou_span_b) or enter_long) or exitShortCondition) // Выполнение сделок if is_long_enable == 1 strategy.entry("Long", strategy.long, when=enter_long) strategy.close("Long", when=exit_long) if is_short_enable == 1 strategy.entry("Short", strategy.short, when=enter_short) strategy.close("Short", when=exit_short)