
এই কৌশলটি একটি স্বয়ংক্রিয় ট্রেডিং সিস্টেম যা অস্থিরতা এবং গতিশীলতার সূচকগুলিকে একত্রিত করে এবং একাধিক প্রযুক্তিগত সূচকগুলির সমন্বয়মূলক সমন্বয় দ্বারা বাজারের প্রবণতাকে ক্যাপচার করে। এটির মধ্যে রয়েছে এটিআর সূচক যা বাজারের অস্থিরতা পর্যবেক্ষণ করে, MACD প্রবণতা গতিশীলতা নির্ধারণ করে, এবং দামের গতিশীলতার সূচকগুলির সাথে একত্রে ট্রেডিং সিগন্যালগুলি নিশ্চিত করে এবং একটি নমনীয় স্টপ-ড্রপ ব্যবস্থা স্থাপন করে। এই সিস্টেমটি অত্যন্ত অভিযোজিত এবং বাজারের অবস্থার সাথে স্বয়ংক্রিয়ভাবে ট্রেডিং ফ্রিকোয়েন্সি এবং পজিশন নিয়ন্ত্রণের সামঞ্জস্য করতে পারে।
কৌশলটি মূলত তিনটি সূচক ব্যবস্থার উপর নির্ভর করে যা মূল ট্রেডিং লজিক হিসাবে কাজ করেঃ প্রথমত, এটিআর ব্যবহার করে বাজারের ওঠানামা পরিমাপ করে, ট্রেডিং সিদ্ধান্তের জন্য একটি অস্থির রেফারেন্স সরবরাহ করে; দ্বিতীয়ত, প্রবণতা টার্নওভার পয়েন্টগুলি ধরার জন্য MACD সূচকের গোল্ডেন ফোরক ক্রস ব্যবহার করা হয়, যেখানে MACD দ্রুত এবং ধীর লাইনগুলির ক্রসগুলি প্রধান ট্রেডিং ট্রিগার সিগন্যাল হিসাবে ব্যবহৃত হয়; তৃতীয়ত, পুনরায় যাচাইকরণ প্রবণতার শক্তি নিশ্চিত করার জন্য দামের তুলনামূলক পূর্ববর্তী পরিবর্তনগুলি পর্যবেক্ষণ করে দামের গতিশীলতার সূচক ব্যবহার করা হয়। সিস্টেমটি 50-দিনের গড় পরিমাপকে ট্রেন্ড ফিল্টার হিসাবে যুক্ত করে, কেবলমাত্র গড় পরিমাপের উপরই বেশি করার অনুমতি দেওয়া হয়, বিপরীতভাবে খালি করার অনুমতি দেওয়া হয়। অতিরিক্ত লেনদেন এড়াতে কৌশলটি সর্বনিম্ন ব্যবসায়ের ব্যবধান নির্ধারণ করে এবং বিকল্পভাবে সিগন্যাল পাল্টা কার্যকর করতে বাধ্য করে।
এই কৌশলটি একটি যুক্তিসঙ্গত, যুক্তিসঙ্গতভাবে নকশাকৃত পরিমাণযুক্ত ট্রেডিং সিস্টেম যা একাধিক প্রযুক্তিগত সূচকের সমন্বিত ব্যবহারের মাধ্যমে বাজারের প্রবণতাকে কার্যকরভাবে ক্যাপচার করে। সিস্টেমটি ঝুঁকি নিয়ন্ত্রণ এবং লেনদেনের কার্যকরকরণের দিক থেকে সুনির্দিষ্ট বিবেচনা করে এবং এটির ভাল ব্যবহারিকতা রয়েছে। যদিও কিছু সম্ভাব্য ঝুঁকি রয়েছে, তবে প্রস্তাবিত অপ্টিমাইজেশনের দিকনির্দেশের মাধ্যমে কৌশলটির স্থায়িত্ব এবং উপার্জন আরও বাড়ানোর সম্ভাবনা রয়েছে।
/*backtest
start: 2019-12-23 08:00:00
end: 2024-11-25 08:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=5
strategy("[ETH] Volatility & Momentum Adaptive Strategy", shorttitle="Definitive 1 day Ethereum Signal", overlay=true, initial_capital=10000, currency=currency.USD)
// === Input Parameters === //
trade_size = input.float(5, title="Trade Size (ETH)")
atr_length = input.int(8, minval=1, title="ATR Length")
macd_fast = input.int(8, minval=1, title="MACD Fast Length")
macd_slow = input.int(7, minval=1, title="MACD Slow Length")
macd_signal = input.int(9, minval=1, title="MACD Signal Length")
momentum_length = input.int(37, title="Momentum Length")
stop_loss_percent = input.float(9.9, title="Stop Loss Percentage (%)")
take_profit_percent = input.float(9.0, title="Take Profit Percentage (%)")
alternate_signal = input.bool(true, title="Alternate Buy/Sell Signals")
// === Indicators === //
// ATR to measure volatility
atr = ta.atr(atr_length)
// MACD for trend momentum
[macd_line, signal_line, _] = ta.macd(close, macd_fast, macd_slow, macd_signal)
macd_cross_up = ta.crossover(macd_line, signal_line)
macd_cross_down = ta.crossunder(macd_line, signal_line)
// Momentum
momentum = ta.mom(close, momentum_length)
// === Signal Control Variables === //
var bool last_signal_long = na
var int last_trade_bar = na
min_bars_between_trades = 5 // Adjust for minimal trade frequency control
time_elapsed = na(last_trade_bar) or (bar_index - last_trade_bar) >= min_bars_between_trades
// === Buy and Sell Conditions === //
// Buy when:
buy_signal = (macd_cross_up and momentum > 0 and close > ta.sma(close, 50) and time_elapsed)
// Sell when:
sell_signal = (macd_cross_down and momentum < 0 and close < ta.sma(close, 50) and time_elapsed)
// Enforce alternate signals if selected
if alternate_signal
buy_signal := buy_signal and (na(last_signal_long) or not last_signal_long)
sell_signal := sell_signal and (not na(last_signal_long) and last_signal_long)
// === Trade Execution === //
// Buy Position
if (buy_signal)
if strategy.position_size < 0
strategy.close("Short")
strategy.entry("Long", strategy.long, qty=trade_size)
last_signal_long := true
last_trade_bar := bar_index
// Sell Position
if (sell_signal)
if strategy.position_size > 0
strategy.close("Long")
strategy.entry("Short", strategy.short, qty=trade_size)
last_signal_long := false
last_trade_bar := bar_index
// === Stop Loss and Take Profit === //
if strategy.position_size > 0
long_take_profit = strategy.position_avg_price * (1 + take_profit_percent / 100)
long_stop_loss = strategy.position_avg_price * (1 - stop_loss_percent / 100)
strategy.exit("TP/SL Long", from_entry="Long", limit=long_take_profit, stop=long_stop_loss)
if strategy.position_size < 0
short_take_profit = strategy.position_avg_price * (1 - take_profit_percent / 100)
short_stop_loss = strategy.position_avg_price * (1 + stop_loss_percent / 100)
strategy.exit("TP/SL Short", from_entry="Short", limit=short_take_profit, stop=short_stop_loss)
// === Visual Signals === //
plotshape(series=buy_signal and time_elapsed, title="Buy Signal", location=location.belowbar, color=color.green, style=shape.labelup, text="BUY")
plotshape(series=sell_signal and time_elapsed, title="Sell Signal", location=location.abovebar, color=color.red, style=shape.labeldown, text="SELL")