
Chande-KrollストップダイナミックATRトレンドトラッキング戦略は,Chande-Krollストップ指数とSMAをベースにした量的な取引戦略である.この戦略は,市場の上昇傾向を捉え,同時にダイナミックストップを使用してリスクを管理する.Chande-Krollストップ指数は,平均実在波幅 (ATR) に基づいてストップレベルを動的に調整し,異なる市場の変動状況に対応する.21サイクルSMAは,トレンドフィルターとして機能し,主要トレンドの方向で取引を保証する.
この戦略の核心は,Chande-Krollのストップ指数で,動的ストップレベルを計算するためにATRを使用している.ATRは市場の波動性を測定し,ストップレベルはATRと倍数の動的調整によって調整されている.これは,ストップポジションが現在の市場条件に適合することを保証している.同時に,21周期SMAはトレンドフィルターとして,閉盘価格がSMAよりも高い場合にのみ複数のシグナルを触発する.これは,熊市での取引を避けるのに役立ちます. 複数条件: 閉盤価格がChande-Kroll下線を突破し,21周期SMAより高いとき,複数を開始します. 平仓条件:閉盘価格がChande-Kroll上線を下回ったとき,平仓.
Chande-KrollストップダイナミックATRトレンドフォロー戦略は,ダイナミックストップとトレンドフォローの原理に基づいた量化取引戦略である.Chande-Krollストップ指数とSMAトレンドフィルターの組み合わせにより,戦略は上昇傾向を捉えながら,リスクを効果的に管理することができる.戦略のパラメータの柔軟性とポジションスケールのダイナミックな調整により,戦略の適応性がさらに強化される.戦略には一定のリスクがあるにもかかわらず,合理的なリスク管理措置と継続的な最適化により,戦略は長期的に安定した収益を期待できる.
/*backtest
start: 2023-06-08 00:00:00
end: 2024-06-13 00:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=5
strategy("Chande Kroll Stop Strategy", overlay=true, initial_capital = 1000, commission_type = strategy.commission.percent, commission_value = 0.01, slippage = 3)
// Chande Kroll Stop parameters
calcMode = input.string(title="Calculation Mode", defval="Exponential", options=["Linear", "Exponential"])
riskMultiplier = input(5, "Risk Multiplier")
atrPeriod = input(10, "ATR Period")
atrMultiplier = input(3, "ATR Multiplier")
stopLength = input(21, "Stop Length")
smaLength = input(21, "SMA Length")
// Calculate ATR
atr = ta.atr(atrPeriod)
// Calculate Chande Kroll Stop
highStop = ta.highest(high, stopLength) - atrMultiplier * atr
lowStop = ta.lowest(low, stopLength) + atrMultiplier * atr
sma21 = ta.sma(close, smaLength)
// Entry and Exit conditions
longCondition = ta.crossover(close, lowStop) and close > sma21
exitLongCondition = close < highStop
// Funktion zur Berechnung der Menge
calc_qty(mode, riskMultiplier) =>
lowestClose = ta.lowest(close, 1560)
if mode == "Exponential"
qty = riskMultiplier / lowestClose * 1000 * strategy.equity / strategy.initial_capital
else
qty = riskMultiplier / lowestClose * 1000
// Berechnung der Menge basierend auf der Benutzerwahl
qty = calc_qty(calcMode, riskMultiplier)
// Execute strategy
if (longCondition)
strategy.entry("Long", strategy.long, qty=qty)
alert("Buy Signal", alert.freq_once_per_bar_close)
if (exitLongCondition)
strategy.close("Long")
alert("Sell Signal", alert.freq_once_per_bar_close)
// Plotting
plotshape(series=longCondition, location=location.belowbar, color=#0097a7, style=shape.triangleup, size=size.small, title="Buy Signal")
plotshape(series=ta.crossunder(close, highStop), location=location.abovebar, color=#ff195f, style=shape.triangledown, size=size.small, title="Sell Signal")
plot(sma21, color=color.gray)
plot(highStop, color=#0097a7)
plot(lowStop, color=#ff195f)