Strategi ini menggunakan Purata Bergerak Sederhana (SMA) pada pelbagai jangka masa untuk menangkap trend pasaran. Dengan membandingkan kedudukan relatif SMA jangka pendek dan jangka panjang, ia menjana isyarat beli dan jual. Strategi ini juga menggunakan keadaan pengesahan trend untuk menapis isyarat palsu dan meningkatkan ketepatan perdagangan.
Strategi ini menggunakan SMA pada jangka masa yang berbeza untuk menangkap trend pasaran, menapis isyarat palsu menggunakan keadaan pengesahan trend, dan menggabungkan mengambil keuntungan / berhenti kerugian dan ciri penyesuaian kedudukan dinamik untuk mencapai trend berikut dan objektif pengurusan risiko. Walaupun strategi ini mempunyai kelebihan tertentu, ia masih menghadapi risiko seperti pengoptimuman parameter, pasaran bergolak, dan peristiwa yang tidak dijangka. Pengoptimuman masa depan boleh memberi tumpuan kepada menggabungkan penunjuk teknikal tambahan, mengoptimumkan pemilihan parameter, meningkatkan pengurusan risiko, dan menyesuaikan diri dengan keadaan pasaran yang berbeza untuk meningkatkan ketahanan dan keuntungan strategi.
/*backtest start: 2024-05-01 00:00:00 end: 2024-05-31 23:59:59 period: 6h basePeriod: 15m exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=5 strategy("market slayer v3", overlay=true) // Input parameters showConfirmationTrend = input(title='Show Trend', defval=true) confirmationTrendTimeframe = input.timeframe(title='Main Trend', defval='240') confirmationTrendValue = input(title='Main Trend Value', defval=2) showConfirmationBars = input(title='Show Confirmation Bars', defval=true) topCbarValue = input(title='Top Confirmation Value', defval=60) short_length = input.int(10, minval=1, title="Short SMA Length") long_length = input.int(20, minval=1, title="Long SMA Length") takeProfitEnabled = input(title="Take Profit Enabled", defval=false) takeProfitValue = input.float(title="Take Profit (points)", defval=20, minval=1) stopLossEnabled = input(title="Stop Loss Enabled", defval=false) stopLossValue = input.float(title="Stop Loss (points)", defval=50, minval=1) // Calculate SMAs short_sma = ta.sma(close, short_length) long_sma = ta.sma(close, long_length) // Generate buy and sell signals based on SMAs buy_signal = ta.crossover(short_sma, long_sma) sell_signal = ta.crossunder(short_sma, long_sma) // Plot SMAs plot(short_sma, color=color.rgb(24, 170, 11), title="Short SMA") plot(long_sma, color=color.red, title="Long SMA") // Confirmation Bars f_confirmationBarBullish(cbValue) => cBarClose = close slowConfirmationBarSmaHigh = ta.sma(high, cbValue) slowConfirmationBarSmaLow = ta.sma(low, cbValue) slowConfirmationBarHlv = int(na) slowConfirmationBarHlv := cBarClose > slowConfirmationBarSmaHigh ? 1 : cBarClose < slowConfirmationBarSmaLow ? -1 : slowConfirmationBarHlv[1] slowConfirmationBarSslDown = slowConfirmationBarHlv < 0 ? slowConfirmationBarSmaHigh : slowConfirmationBarSmaLow slowConfirmationBarSslUp = slowConfirmationBarHlv < 0 ? slowConfirmationBarSmaLow : slowConfirmationBarSmaHigh slowConfirmationBarSslUp > slowConfirmationBarSslDown fastConfirmationBarBullish = f_confirmationBarBullish(topCbarValue) fastConfirmationBarBearish = not fastConfirmationBarBullish fastConfirmationBarClr = fastConfirmationBarBullish ? color.green : color.red fastConfirmationChangeBullish = fastConfirmationBarBullish and fastConfirmationBarBearish[1] fastConfirmationChangeBearish = fastConfirmationBarBearish and fastConfirmationBarBullish[1] confirmationTrendBullish = request.security(syminfo.tickerid, confirmationTrendTimeframe, f_confirmationBarBullish(confirmationTrendValue), lookahead=barmerge.lookahead_on) confirmationTrendBearish = not confirmationTrendBullish confirmationTrendClr = confirmationTrendBullish ? color.green : color.red // Plot trend labels plotshape(showConfirmationTrend, style=shape.square, location=location.top, color=confirmationTrendClr, title='Trend Confirmation Bars') plotshape(showConfirmationBars and (fastConfirmationChangeBullish or fastConfirmationChangeBearish), style=shape.triangleup, location=location.top, color=fastConfirmationChangeBullish ? color.green : color.red, title='Fast Confirmation Bars') plotshape(showConfirmationBars and buy_signal and confirmationTrendBullish, style=shape.triangleup, location=location.top, color=color.green, title='Buy Signal') plotshape(showConfirmationBars and sell_signal and confirmationTrendBearish, style=shape.triangledown, location=location.top, color=color.red, title='Sell Signal') // Generate trade signals buy_condition = buy_signal and confirmationTrendBullish and not (strategy.opentrades > 0) sell_condition = sell_signal and confirmationTrendBearish and not (strategy.opentrades > 0) strategy.entry("Buy", strategy.long, when=buy_condition, comment ="BUY CALLS") strategy.entry("Sell", strategy.short, when=sell_condition, comment ="BUY PUTS") // Take Profit if (takeProfitEnabled) strategy.exit("Take Profit Buy", from_entry="Buy", profit=takeProfitValue) strategy.exit("Take Profit Sell", from_entry="Sell", profit=takeProfitValue) // Stop Loss if (stopLossEnabled) strategy.exit("Stop Loss Buy", from_entry="Buy", loss=stopLossValue) strategy.exit("Stop Loss Sell", from_entry="Sell", loss=stopLossValue) // Close trades based on trend confirmation bars if strategy.opentrades > 0 if strategy.position_size > 0 if not confirmationTrendBullish strategy.close("Buy", comment ="CLOSE CALLS") else if not confirmationTrendBearish strategy.close("Sell", comment ="CLOSE PUTS") // Define alert conditions as booleans buy_open_alert = buy_condition sell_open_alert = sell_condition buy_closed_alert = strategy.opentrades < 0 sell_closed_alert = strategy.opentrades > 0 // Alerts alertcondition(buy_open_alert, title='Buy calls', message='Buy calls Opened') alertcondition(sell_open_alert, title='buy puts', message='buy Puts Opened') alertcondition(buy_closed_alert, title='exit calls', message='exit calls ') alertcondition(sell_closed_alert, title='exit puts', message='exit puts Closed')