
Chiến lược này sử dụng đường DIF và đường DEA trong chỉ số MACD để tạo ra tín hiệu giao dịch. Khi đường DIF đi từ dưới lên qua đường DEA, nó tạo ra tín hiệu nhiều; Khi đường DIF đi từ trên xuống qua đường DEA, nó tạo ra tín hiệu lỗ. Kết quả đánh giá của chiến lược cho thấy tỷ lệ thắng khoảng 40% trên cặp giao dịch BTCUSDT, với lợi nhuận hàng năm là 1.05, nhưng sẽ dẫn đến số lượng tài sản đang nắm giữ tăng lên, do đó không thể sử dụng như một chiến lược tháo gỡ độc lập.
Chiến lược MACD Gold Fork Dead Fork là một chiến lược giao dịch đơn giản và dễ hiểu, phù hợp với thị trường đang có xu hướng. Tuy nhiên, chiến lược này có tỷ lệ thắng thấp và thiếu các biện pháp quản lý rủi ro, do đó cần được tối ưu hóa và cải thiện hơn nữa. Hiệu suất và độ tin cậy của chiến lược có thể được cải thiện bằng cách giới thiệu bộ lọc xu hướng, tham số tối ưu hóa, thêm quản lý rủi ro và kết hợp với các phương pháp phân tích khác.
/*backtest
start: 2024-03-01 00:00:00
end: 2024-03-31 23:59:59
period: 1h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
// @version=5
// @description 该策略使用 MACD DIF 线与 EDA 线产生金叉与死叉时进行入场与出场操作, 回测后发现胜率约 40%, BTCUSDT 年化利率 1.05, 同时会导致持有的资产数量不断上升, 无法作为一个独立的套利策略进行使用.
strategy("MACD 金叉策略", overlay=true)
fastLength = input(12, "快线长度")
slowLength = input(26, "慢线长度")
MACDLength = input(9, "MACD 均线长度")
deltaIncreaseOver0 = input(color.green,'MACD 柱在 0 线以上增长')
deltaIncreaseUnder0 = input(color.rgb(153, 230, 156),'MACD 柱在 0 线以下增长')
deltaDecreaseOver0 = input(color.orange,'MACD 柱在 0 线以上下跌')
deltaDecreaseUnder0 = input(color.red,'MACD 柱在 0 线以下下跌')
buySellEnabled = input(true, '是否显示入场与出场信号')
// @variable 做多轮数
var longRound = 0
// @variable 做空轮数
var shortRound = 0
DIF = ta.ema(close, fastLength) - ta.ema(close, slowLength) // 快慢均线差值
EDA = ta.ema(DIF, MACDLength) // DIF 线的 EMA 均线
delta = DIF - EDA // MACD 柱高度
// plot(0, 'Zero', color.black)
plot(DIF,'DIF', color.yellow)
plot(EDA, "EDA", color.purple)
isDeltaIncreasing = delta[1] < delta
isDeltaOver0 = delta > 0
deltaColor = isDeltaIncreasing ? (isDeltaOver0? deltaIncreaseOver0: deltaIncreaseUnder0) :( isDeltaOver0? deltaDecreaseOver0: deltaDecreaseUnder0)
plot(delta, "Delta", deltaColor, style = plot.style_columns)
isDeltaV = delta > delta[1] and delta[2] > delta[1]
isDeltaA = delta < delta[1] and delta[2] < delta[1]
longBuy(round) =>
entry = str.format("做多买入 {0}",round)
// log.info(str.format("{0} {1}",entry,close))
strategy.entry(entry, strategy.long, comment=entry)
longSell(round) =>
entry = str.format("做多买入 {0}",round)
exit = str.format("做多卖出 {0}",round)
// log.info(str.format("{0} {1}",exit,close))
strategy.close(entry, comment=exit)
shortSell(round) =>
entry = str.format("做空卖出 {0}",round)
// log.info(str.format("{0} {1}",entry,close))
strategy.entry(entry, strategy.short, comment= entry)
shortBuy(round) =>
entry = str.format("做空卖出 {0}",round)
exit = str.format("做空买入 {0}",round)
// log.info(str.format("{0} {1}",exit,close))
strategy.close(entry, comment=exit)
if (buySellEnabled)
if (ta.crossunder(DIF, EDA))
longSell(longRound)
if (ta.crossover(DIF, EDA))
longRound := longRound + 1
longBuy(longRound)