
এই কৌশলটি একটি পরিমাণগত ট্রেডিং সিস্টেম যা একাধিক সূচক মুভিং এভারেজ (EMA), তুলনামূলকভাবে দুর্বল সূচক (RSI) এবং মুভিং এভারেজ ট্রেন্ডিং স্প্রেড সূচক (MACD) এর সমন্বয় করে। এই কৌশলটি একাধিক প্রযুক্তিগত সূচকের সমন্বয় করে একটি সম্পূর্ণ ট্রেডিং সিদ্ধান্ত গ্রহণের কাঠামো গঠন করে। কৌশলটি চারটি ইএমএ লাইন 10, 20, 50 এবং 100 দিনের মূল প্রবণতা নির্ধারণের সরঞ্জাম হিসাবে ব্যবহার করে এবং আরএসআই এবং এমএসিডিকে সহায়ক নিশ্চিতকরণ সূচক হিসাবে সংযুক্ত করে, পাশাপাশি ঝুঁকি নিয়ন্ত্রণের জন্য স্টপ লস এবং স্টপস সেট করে।
কৌশলটির মূল যুক্তি নিম্নলিখিত মূল উপাদানগুলির উপর ভিত্তি করে:
এটি একটি যুক্তিসঙ্গত, যুক্তিসঙ্গতভাবে কঠোরভাবে পরিকল্পিত পরিমাণযুক্ত ট্রেডিং কৌশল। একাধিক প্রযুক্তিগত সূচকগুলির সমন্বিত ব্যবহারের মাধ্যমে, এটি কার্যকরভাবে বাজার প্রবণতা ক্যাপচার করতে পারে এবং একটি সম্পূর্ণ ঝুঁকি নিয়ন্ত্রণ ব্যবস্থা রয়েছে। কৌশলটির অপ্টিমাইজেশনের জন্য প্রচুর জায়গা রয়েছে, ক্রমাগত উন্নতি এবং সমন্বয় করে আরও ভাল ব্যবসায়ের কার্যকারিতা অর্জনের আশা করা যায়। এটি রিয়েল-টাইম ব্যবসায়ের আগে পর্যাপ্ত ব্যাক-টেস্টিং যাচাইয়ের পরামর্শ দেওয়া হয় এবং নির্দিষ্ট বাজারের পরিস্থিতি অনুসারে প্যারামিটার সেটিংগুলি যথাযথভাবে সামঞ্জস্য করা উচিত।
/*backtest
start: 2019-12-23 08:00:00
end: 2024-12-04 00:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=5
strategy("4 EMA Strategy with RSI & MACD", shorttitle="4 EMA + RSI + MACD", overlay=true)
// Input EMA periods
ema1 = input(10, title="EMA 1")
ema2 = input(20, title="EMA 2")
ema3 = input(50, title="EMA 3")
ema4 = input(100, title="EMA 4")
// Input RSI & MACD settings
rsiLength = input(14, title="RSI Length")
rsiOverbought = input(70, title="RSI Overbought")
rsiOversold = input(30, title="RSI Oversold")
macdFast = input(12, title="MACD Fast Length")
macdSlow = input(26, title="MACD Slow Length")
macdSignal = input(9, title="MACD Signal Length")
// Stop Loss and Take Profit Inputs
stopLossPct = input.float(1.5, title="Stop Loss %") / 100
takeProfitPct = input.float(3, title="Take Profit %") / 100
// Calculate EMAs
ema_1 = ta.ema(close, ema1)
ema_2 = ta.ema(close, ema2)
ema_3 = ta.ema(close, ema3)
ema_4 = ta.ema(close, ema4)
// Calculate RSI
rsi = ta.rsi(close, rsiLength)
// Calculate MACD
[macdLine, signalLine, _] = ta.macd(close, macdFast, macdSlow, macdSignal)
// Plot EMAs
plot(ema_1, color=color.blue, title="EMA 10")
plot(ema_2, color=color.green, title="EMA 20")
plot(ema_3, color=color.orange, title="EMA 50")
plot(ema_4, color=color.red, title="EMA 100")
// Entry Conditions
longCondition = ta.crossover(ema_1, ema_4) and ta.crossover(ema_2, ema_3) and rsi > 50 and macdLine > signalLine
shortCondition = ta.crossunder(ema_1, ema_4) and ta.crossunder(ema_2, ema_3) and rsi < 50 and macdLine < signalLine
// Declare Stop Loss and Take Profit Variables
var float stopLossPrice = na
var float takeProfitPrice = na
var line stopLossLine = na
var line takeProfitLine = na
// Long Trade
if (longCondition)
strategy.entry("Buy", strategy.long)
stopLossPrice := strategy.position_avg_price * (1 - stopLossPct)
takeProfitPrice := strategy.position_avg_price * (1 + takeProfitPct)
// stopLossLine := line.new(bar_index, stopLossPrice, bar_index + 1, stopLossPrice, color=color.red, width=2, style=line.style_dotted)
// takeProfitLine := line.new(bar_index, takeProfitPrice, bar_index + 1, takeProfitPrice, color=color.green, width=2, style=line.style_dotted)
// Short Trade
if (shortCondition)
strategy.entry("Sell", strategy.short)
stopLossPrice := strategy.position_avg_price * (1 + stopLossPct)
takeProfitPrice := strategy.position_avg_price * (1 - takeProfitPct)
// stopLossLine := line.new(bar_index, stopLossPrice, bar_index + 1, stopLossPrice, color=color.red, width=2, style=line.style_dotted)
// takeProfitLine := line.new(bar_index, takeProfitPrice, bar_index + 1, takeProfitPrice, color=color.green, width=2, style=line.style_dotted)
// Clear Lines on Trade Exit
// if (strategy.position_size == 0)
// line.delete(stopLossLine)
// line.delete(takeProfitLine)
// Exit Trades
if (strategy.position_size > 0)
strategy.exit("Sell", from_entry="Buy", stop=stopLossPrice, limit=takeProfitPrice)
if (strategy.position_size < 0)
strategy.exit("Cover", from_entry="Sell", stop=stopLossPrice, limit=takeProfitPrice)