এমএসিডি ট্রেন্ড ফলোিং ইনট্রাডে স্ট্র্যাটেজি হল একটি ইনট্রাডে ট্রেডিং কৌশল যা চলমান গড়, এমএসিডি সূচক এবং উইলিয়ামস সূচককে একত্রিত করে। এটি দীর্ঘ এবং সংক্ষিপ্ত অবস্থানের জন্য প্রবেশ এবং প্রস্থান মানদণ্ড গঠনের জন্য তিনটি সূচকের বিভিন্ন সমন্বয় ব্যবহার করে, স্বল্পমেয়াদী মূল্য আন্দোলনের প্রবণতা বৈশিষ্ট্যগুলি ক্যাপচার করার লক্ষ্যে।
এই কৌশলটির মূল ট্রেডিং যুক্তি বেশ কয়েকটি দিকের উপর ভিত্তি করেঃ
যখন দাম এক্সপোনেনশিয়াল মুভিং এভারেজ (ইএমএ) লাইনের উপরে চলে যায় তখন লম্বা হয়ে যায় এবং যখন এটি নীচে যায় তখন শর্ট হয়ে যায়;
ম্যাকডি দ্রুত রেখার উপরে লম্বা হয়ে গেলে লম্বা হয়ে যায় এবং নীচে গেলে শর্ট হয়ে যায়।
যখন উইলিয়াম ইন্ডিকেটরের দ্রুত এমএ লাইন ধীর এমএ লাইনের উপরে থাকে এবং বিপরীতভাবে লম্বা হয়;
প্রবেশের শর্ত হিসাবে এই তিনটি দৃশ্যের সমন্বয় ব্যবহার করুন;
রিভার্স সিগন্যালের পর বেরিয়ে আসুন।
সামগ্রিক প্রবণতা দিকের জন্য ইএমএ এবং স্বল্পমেয়াদী গতির জন্য এমএসিডিকে একত্রিত করে, এই কৌশলটি লাভের জন্য শালীন প্রবেশের পয়েন্টগুলিতে মূল্য প্রবণতা চলাচলকে ক্যাপচার করতে পারে। উইলিয়ামস সূচক আরও বেশি ক্রয় / oversold স্তরগুলি পরিমাপ করে মিথ্যা ব্রেকআউট এড়াতে সহায়তা করে।
এই মাল্টি-ইন্ডিক্টর কম্বো স্ট্রাকচারটি একটি সাধারণ স্বল্পমেয়াদী প্রবণতা অনুসরণ করে, প্রধান প্রান্তগুলির সাথে যেমনঃ
মিথ্যা সংকেত হ্রাস করার জন্য তিনবার ক্রস-ভেরিফিকেশন;
মূল প্রবণতার জন্য EMA, স্বল্পমেয়াদী গতির জন্য MACD;
উইলিয়ামস ইন্ডিকেটর অস্থির গতির সময় শীর্ষ বা নীচে মাছ ধরার পরিত্যাগ করে;
রিভার্সাল কম্বো নিশ্চিত করে যে ঝুঁকি নিয়ন্ত্রণটি প্রস্থানগুলির সাথে সামঞ্জস্যপূর্ণ।
এই কৌশলটির জন্য উল্লেখযোগ্য ঝুঁকিও রয়েছেঃ
জটিল কাঠামো প্যারামিটার টিউনিংকে চ্যালেঞ্জিং করে তোলে;
ঘন ঘন স্বল্পমেয়াদী লেনদেনের ফলে লেনদেনের খরচ বেড়ে যেতে পারে;
প্রকৃত প্রবণতা বিপরীত পয়েন্ট সনাক্ত করতে ব্যর্থ হলে ক্ষতি হতে পারে।
প্রধান হ্রাস প্যারামিটার অপ্টিমাইজেশান এবং লাভের কম্বো সর্বাধিকীকরণ এবং সর্বোচ্চ একক বাণিজ্য ক্ষতি নিয়ন্ত্রণের জন্য স্টপ লস।
কৌশল উন্নত করার জন্য প্রধান দিকঃ
সর্বোত্তম সেট জন্য আরো পরামিতি সমন্বয় পরীক্ষা;
এন্ট্রি ভ্যালিডেশনের জন্য ভলিউমের মতো আরও ডেটা ফিড যুক্ত করুন;
ঝুঁকি নিয়ন্ত্রণ জোরদার করার জন্য গতিশীল বা ট্রেলিং স্টপ লস ব্যবহার করুন;
সত্যিকারের বিপরীততা সনাক্ত করতে মেশিন লার্নিং অন্তর্ভুক্ত করুন।
ইনট্রা ডে কৌশল অনুসরণ করে এই এমএসিডি প্রবণতা কার্যকরভাবে স্বল্পমেয়াদী প্রবণতা সনাক্তকরণ এবং ঝুঁকি পরিচালনার জন্য সূচকগুলিকে একত্রিত করে। টিউনিং পরামিতিগুলিতে আরও উন্নতি, স্টপ লস স্তর সেট করা এবং আরও ডেটা ফিড অন্তর্ভুক্ত করা কৌশল জয়ের হার এবং লাভজনকতা বাড়িয়ে তুলতে পারে। কৌশল অগ্রগতির জন্য ধারণাগুলি গবেষণা করার মতো।
/*backtest start: 2023-11-18 00:00:00 end: 2023-12-18 00:00:00 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/ // © platsn //@version=5 strategy("MACD Willy Strategy", overlay=true, pyramiding=1, initial_capital=10000) // ******************** Trade Period ************************************** startY = input(title='Start Year', defval=2011, group = "Trading window") startM = input.int(title='Start Month', defval=1, minval=1, maxval=12, group = "Trading window") startD = input.int(title='Start Day', defval=1, minval=1, maxval=31, group = "Trading window") finishY = input(title='Finish Year', defval=2050, group = "Trading window") finishM = input.int(title='Finish Month', defval=12, minval=1, maxval=12, group = "Trading window") finishD = input.int(title='Finish Day', defval=31, minval=1, maxval=31, group = "Trading window") timestart = timestamp(startY, startM, startD, 00, 00) timefinish = timestamp(finishY, finishM, finishD, 23, 59) // t1 = time(timeframe.period, "0945-1545:23456") // window = time >= timestart and time <= timefinish and t1 ? true : false // t2 = time(timeframe.period, "0930-1555:23456") // window2 = time >= timestart and time <= timefinish and t2 ? true : false leverage = input.float(1, title="Leverage (if applicable)", step=0.1, group = "Trading Options") reinvest = input.bool(defval=false,title="Reinvest profit", group = "Trading Options") reinvest_percent = input.float(defval=20, title = "Reinvest percentage", group="Trading Options") // entry_lookback = input.int(defval=10, title="Lookback period for entry condition", group = "Trading Options") // -------------------------------------------- Data Source -------------------------------------------- src = input(title="Source", defval=close) // ***************************************************************************************************** Daily ATR ***************************************************** atrlen = input.int(14, minval=1, title="ATR period", group = "Daily ATR") iPercent = input.float(5, minval=1, maxval=100, step=0.1, title="% ATR to use for SL / PT", group = "Daily ATR") percentage = iPercent * 0.01 datr = request.security(syminfo.tickerid, "1D", ta.rma(ta.tr, atrlen)) datrp = datr * percentage // plot(datr,"Daily ATR") // plot(datrp, "Daily % ATR") //*********************************************************** VIX volatility index **************************************** VIX = request.security("BTC_USDT:swap", timeframe.period, close) vix_thres = input.float(20.0, "VIX Threshold for entry", step=0.5, group="VIX Volatility Index") // ************************************************ Volume ****************************************************** vol_len = input(50, 'Volume MA Period') avg_vol = ta.sma(volume, vol_len) //-------------------------------------------------------- Moving Average ------------------------------------ emalen1 = input.int(200, minval=1, title='EMA', group= "Moving Averages") ema1 = ta.ema(src, emalen1) // ------------------------------------------ MACD ------------------------------------------ // Getting inputs fast_length = input(title="Fast Length", defval=12) slow_length = input(title="Slow Length", defval=26) signal_length = input.int(title="Signal Smoothing", minval = 1, maxval = 50, defval = 9) sma_source = input.string(title="Oscillator MA Type", defval="EMA", options=["SMA", "EMA"]) sma_signal = input.string(title="Signal Line MA Type", defval="EMA", options=["SMA", "EMA"]) // Plot colors col_macd = input(#2962FF, "MACD Line ", group="Color Settings", inline="MACD") col_signal = input(#FF6D00, "Signal Line ", group="Color Settings", inline="Signal") col_grow_above = input(#26A69A, "Above Grow", group="Histogram", inline="Above") col_fall_above = input(#B2DFDB, "Fall", group="Histogram", inline="Above") col_grow_below = input(#FFCDD2, "Below Grow", group="Histogram", inline="Below") col_fall_below = input(#FF5252, "Fall", group="Histogram", inline="Below") // Calculating fast_ma = sma_source == "SMA" ? ta.sma(src, fast_length) : ta.ema(src, fast_length) slow_ma = sma_source == "SMA" ? ta.sma(src, slow_length) : ta.ema(src, slow_length) macd = fast_ma - slow_ma signal = sma_signal == "SMA" ? ta.sma(macd, signal_length) : ta.ema(macd, signal_length) hist = macd - signal // ---------------------------------------- William %R -------------------------------------- w_length = input.int(defval=34, minval=1) w_upper = ta.highest(w_length) w_lower = ta.lowest(w_length) w_output = 100 * (close - w_upper) / (w_upper - w_lower) fast_period = input(defval=5, title='Smoothed %R Length') slow_period = input(defval=13, title='Slow EMA Length') w_fast_ma = ta.wma(w_output,fast_period) w_slow_ma = ta.ema(w_output,slow_period) // ------------------------------------------------ Entry Conditions ---------------------------------------- L_entry1 = close > ema1 and hist > 0 and w_fast_ma > w_slow_ma S_entry1 = close < ema1 and hist < 0 and w_fast_ma < w_slow_ma // -------------------------------------------------- Entry ----------------------------------------------- strategy.initial_capital = 50000 profit = strategy.netprofit trade_amount = math.floor(strategy.initial_capital*leverage / close) if strategy.netprofit > 0 and reinvest trade_amount := math.floor((strategy.initial_capital+(profit*reinvest_percent*0.01))*leverage / close) else trade_amount := math.floor(strategy.initial_capital*leverage/ close) if L_entry1 //and window strategy.entry("Long", strategy.long, trade_amount) if S_entry1 //and window strategy.entry("Short", strategy.short, trade_amount) // --------------------------------------------------- Exit Conditions ------------------------------------- L_exit1 = hist < 0 and w_fast_ma < w_slow_ma and w_fast_ma < -20 S_exit1 = hist > 0 and w_fast_ma > w_slow_ma and w_fast_ma > -80 // ----------------------------------------------------- Exit --------------------------------------------- if L_exit1 //and window2 strategy.close("Long") if S_exit1 //and window2 strategy.close("Short") // if time(timeframe.period, "1530-1600:23456") // strategy.close_all()