移動平均金叉死叉取引戦略は,短期および長期の移動平均 ((EMA)) の交差を追跡する,金叉および死叉時に買入および販売操作を行う定量取引戦略である.この戦略は,MACD指標と組み合わせて取引信号判断を行う.
この戦略は主に12日EMA,26日EMAおよびMACD指標に依存している.具体的論理は以下の通りである.
フィルタリング条件は以下の通りです.
この戦略は,移動平均の交差とMACD指標を組み合わせて,市場の短期および中期トレンドの転換点を効果的に捕捉することができます.主な利点は:
この戦略にはいくつかのリスクがあります.
対応する緩和策:
この戦略は以下の点で最適化できます.
移動平均線金叉死叉は,MACD取引戦略と結合し,簡単なトレンド追跡によって取引信号を形成し,実行しやすい.適切なフィルタリング条件と組み合わせたリスク制御は,有効な量化取引戦略である.この戦略は,パラメータ最適化,止損機構の追加,より多くの補助指標と組み合わせることで改善することができる.
/*backtest
start: 2024-01-01 00:00:00
end: 2024-01-31 23:59:59
period: 1h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=5
strategy("EMMA", max_bars_back = 200)
var up1 = #26A69A
var up2 = #B2DFDB
var down1 = #FF5252
var down2 = #FFCDD2
var confirmationLength = 2
var earliest = timestamp("20 Jan 2024 00:00 +0000")
// Regn u
shortEMA = ta.ema(close, 12)
longEMA = ta.ema(close, 26)
macd = shortEMA - longEMA
signal = ta.ema(macd, 9)
delta = macd - signal
absDelta = math.abs(delta)
previousDelta = delta[1]
signalCrossover = ta.crossover(macd, signal)
signalCrossunder = ta.crossunder(macd, signal)
harskiftetdag = hour(time[confirmationLength]) > hour(time)
enterLongSignal = signalCrossover[confirmationLength] and (macd > signal) and (absDelta >= 0.08)
exitLongSignal = signalCrossunder[confirmationLength] and (macd < signal)
enterShortSignal = signalCrossunder[confirmationLength] and (macd < signal) and (absDelta >= 0.08)
exitShortSignal = signalCrossover[confirmationLength] and (macd > signal)
// Så er det tid til at købe noe
qty = math.floor(strategy.equity / close)
if time >= earliest and not harskiftetdag
if exitLongSignal
strategy.close("long")
else if enterLongSignal
strategy.close("short")
strategy.entry("long", strategy.long, qty = qty)
if exitShortSignal
strategy.close("short")
else if enterShortSignal
strategy.close("long")
strategy.entry("short", strategy.short, qty = qty)
// Så er det tid til at vise noe
plot(macd, color=color.blue)
plot(signal, color=color.orange)
// bgcolor(color = delta > 0.1 ? color.new(color.green, 90) : color.new(color.green, 100))
// bgcolor(color = signalCrossover ? color.purple : signalCrossunder ? color.aqua : color.new(color.green, 100))
histogramColor = delta > 0 ? (previousDelta < delta ? up1 : up2) : (previousDelta > delta ? down1 : down2)
plot(
delta,
style=plot.style_columns,
color=histogramColor
)