Stratégie SAR parabolique d'arrêt de traînée basée sur l'indicateur ATR

Auteur:ChaoZhang est là., Date: 2023-09-13 15h53
Les étiquettes:

Cette stratégie s'appelle Stratégie d'arrêt de traînée SAR parabolique basée sur l'indicateur ATR. Elle utilise l'indicateur ATR pour ajuster le facteur d'accélération de SAR parabolique pour s'adapter à la volatilité changeante du marché.

Le facteur d'accélération du SAR parabolique traditionnel reste fixe et ne peut pas s'adapter à une volatilité accrue.

Plus précisément, après avoir déterminé la tendance des prix, un facteur d'accélération adaptatif est calculé sur la base de la valeur ATR pour tracer la courbe d'arrêt de trail Parabolic SAR. Lorsque les prix dépassent le niveau d'arrêt, le stop loss est déclenché.

L'avantage de cette stratégie est de rendre les arrêts SAR paraboliques traditionnels dynamiques en fonction de la volatilité du marché.

En général, les arrêts adaptatifs sont importants pour protéger les profits et limiter les risques. Les traders doivent choisir des indicateurs d'arrêt appropriés en fonction des conditions du marché, et tester et optimiser les paramètres, afin de maximiser l'utilité des stratégies d'arrêt de perte.


/*backtest
start: 2023-08-13 00:00:00
end: 2023-09-12 00:00:00
period: 1h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=4
strategy(title="ATR Parabolic SAR Strategy [QuantNomad]", shorttitle="ATR PSAR Strategy [QN]", overlay=true, default_qty_type = strategy.percent_of_equity,  default_qty_value = 100)

atr_length = input(14)
start      = input(0.02)
increment  = input(0.02)
maximum    = input(0.2)
entry_bars = input(1, title = "Entry on Nth trend bar") 

atr = atr(atr_length)

atr := na(atr) ? tr : atr

psar        = 0.0 // PSAR
af          = 0.0 // Acceleration Factor
trend_dir   = 0   // Current direction of PSAR
ep          = 0.0 // Extreme point
trend_bars  = 0

sar_long_to_short = trend_dir[1] == 1  and close <= psar[1] // PSAR switches from long to short
sar_short_to_long = trend_dir[1] == -1 and close >= psar[1] // PSAR switches from short to long

trend_change = barstate.isfirst[1] or sar_long_to_short or sar_short_to_long

// Calculate trend direction
trend_dir    :=  barstate.isfirst[1] and close[1]  > open[1] ?  1 : 
                 barstate.isfirst[1] and close[1] <= open[1] ? -1 : 
                 sar_long_to_short ? -1 : 
                 sar_short_to_long ?  1 : nz(trend_dir[1])

trend_bars := sar_long_to_short ? -1 : 
              sar_short_to_long ?  1 : 
              trend_dir ==  1   ? nz(trend_bars[1]) + 1 : 
              trend_dir == -1   ? nz(trend_bars[1]) - 1 : 
              nz(trend_bars[1])

// Calculate  Acceleration Factor
af := trend_change ? start : 
   (trend_dir == 1 and high > ep[1]) or  
   (trend_dir == -1 and low < ep[1]) ? 
   min(maximum, af[1] + increment) : 
   af[1]

// Calculate extreme point
ep := trend_change and trend_dir == 1 ? high :  
   trend_change and trend_dir == -1 ? low : 
   trend_dir == 1 ? max(ep[1], high) : 
   min(ep[1], low)

// Calculate PSAR
psar :=  barstate.isfirst[1] and close[1]  > open[1] ? low[1]  : 
         barstate.isfirst[1] and close[1] <= open[1] ? high[1] : 
         trend_change ? ep[1] :    
         trend_dir == 1 ? psar[1] + af * atr : 
                          psar[1] - af * atr

plot(psar, style=plot.style_cross, color=trend_dir == 1 ? color.green : color.red,  linewidth = 2)


// Strategy 
strategy.entry("Long",  true,  when = trend_bars ==  entry_bars)
strategy.entry("Short", false, when = trend_bars == -entry_bars)

Plus de