Die Strategie für die RSI-Divergenzindikatoren

Schriftsteller:ChaoZhang, Datum: 2024-01-25 11:49:36
Tags:

img

Übersicht

Die RSI Divergence Indicator Strategie ist eine quantitative Handelsstrategie, die auf dem Relative Strength Index (RSI) basiert.

Strategie Logik

Der Kernindikator dieser Strategie ist der RSI. Er analysiert die Divergenz zwischen dem RSI-Indikator und dem Preis. Die sogenannte Divergenz bezieht sich auf die entgegengesetzten Signale zwischen RSI und Preis.

Wenn der RSI ein relativ niedriges Tief bildet, während der Preis ein relativ hohes Tief bildet, handelt es sich um eine bullische Divergenz zwischen dem RSI und dem Preis. Dies impliziert, dass der Preis nach oben umkehren kann. Die Strategie wird an dieser Stelle eine Long-Position etablieren.

Umgekehrt, wenn der RSI ein relativ hohes Hoch bildet, während der Preis ein relativ niedrigeres Hoch bildet, handelt es sich um eine bärische Divergenz zwischen dem RSI und dem Preis. Dies impliziert, dass der Preis nach unten umkehren kann. Die Strategie wird an dieser Stelle eine Short-Position einrichten.

Durch die Erfassung dieser Abweichungen zwischen RSI und Preis kann die Strategie rechtzeitig Chancen für Preisumkehrungen erkennen und niedrige Käufe und hohe Verkäufe erreichen.

Vorteile

Die RSI Divergenzstrategie hat folgende Vorteile:

  1. Divergenzen zwischen RSI und Preis implizieren oft eine bevorstehende Trendumkehr, was ein sehr wirksames Vorhersagesignal ist.

  2. Durch die Festlegung von Positionen an Divergenzpunkten ist es in der Lage, zu relativ niedrigen Preisen zu kaufen und zu relativ hohen Preisen zu verkaufen, wobei die besten Praktiken des quantitativen Handels berücksichtigt werden.

  3. Durchbrechen Sie die Grenzen der konventionellen RSI-Strategien. Konventionelle RSI-Strategien konzentrieren sich nur auf überkaufte und überverkaufte Bereiche. Diese Strategie nutzt die intrinsischen Umkehr-Eigenschaften des RSI selbst, um Wendepunkte genauer zu erfassen und die Effizienz der Strategie zu verbessern.

  4. Die wichtigsten Parameter sind nur die RSI-Periode und die Lookback-Periode, die sehr einfach und einfach zu optimieren sind.

Risiken

Die RSI-Divergenzstrategie birgt auch einige Risiken:

  1. Divergenzsignale können falsche Signale sein. Die Divergenzen zwischen RSI und Preis führen nicht unbedingt zu realen Preisumkehrungen. Manchmal bilden sie auch falsche Umkehrungen, was zu Handelsverlusten führt. Ein angemessener Stop-Loss sollte eingestellt werden, um Risiken zu kontrollieren.

  2. Schlechte Performance in Trendmärkten. Wenn der Preis einen klaren richtungsweisenden Trend zeigt, wäre der Gewinnraum dieser Strategie relativ gering. In diesem Fall ist es besser, die Strategie vorübergehend zu deaktivieren und auf neue Trendmärkte zu warten.

  3. Das Risiko von Pyramiden. Die Strategie hat Pyramidenparameter festgelegt. Im Falle von aufeinanderfolgenden Verlustgeschäften kann es den Kontoabzug beschleunigen. Die Positionsgröße und der Stop-Loss sollten kontrolliert werden, um das Risiko zu mindern.

Verbesserungen

Die Strategie kann auch in folgenden Aspekten optimiert werden:

  1. Kombinieren Sie andere Indikatoren zur Signalfilterung. MACD, KDJ und andere Indikatoren können hinzugefügt werden, um die RSI-Divergenzpunkte zu überprüfen, einige falsche Signale auszufiltern und die Gewinnrate der Strategie zu verbessern.

  2. Optimieren Sie die RSI-Parameter. Verschiedene RSI-Perioden können getestet werden, um den zu finden, der am besten den Eigenschaften des Produkts entspricht. Im Allgemeinen funktioniert zwischen 6-15 gut.

  3. Optimieren Sie die Lookback-Periode. Die Lookback-Periode beeinflusst direkt die Handelsfrequenz der Strategie. Verschiedene Werte können getestet werden, um die optimale Frequenz zu finden, in der Regel zwischen 5-15 ist ein guter Bereich.

  4. Hinzufügen von Stop-Loss-Logik. Vernünftige Stop-Loss-Methoden wie ATR-Trailing-Stop-Loss können implementiert werden, um Verluste schnell zu reduzieren, wenn sie entstehen. Dies kann das Risiko der Strategie effektiv kontrollieren.

Schlussfolgerung

Die RSI Divergenz-Strategie erfasst Preiswendepunkte genau, indem sie die intrinsischen Umkehr-Eigenschaften des RSI-Indikators selbst analysiert. Sie erreicht einen Low-Buy-High-Sell-Handelsansatz. Im Vergleich zu den traditionellen Überkauf-Überverkauf-RSI-Strategien nutzt sie raffiniertere und intrinsische Eigenschaften des RSI, was die Effizienz erheblich verbessert. Mit Parameteroptimierung und Risikokontrolle eignet sie sich sehr gut für die Erfassung von kurzfristigen Handelsmöglichkeiten in verschiedenen Märkten.


/*backtest
start: 2023-12-01 00:00:00
end: 2023-12-31 23:59:59
period: 1h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=4
//study(title="Divergence Indicator", format=format.price)
//GOOGL setting  5 , close, 3 , 1  profitLevel at 75 shows win rate  87.21 %  profit factor 7.059
//GOOGL setting  8 , close, 3 , 1  profitLevel at 80 shows win rate  86.57 %  profit factor 18.96 
//SPY setting    5, close , 3, 3  profitLevel at 70  , shows win rate 80.34%  profit factor 2.348
strategy(title="RSI Divergence Indicator", overlay=false,pyramiding=2, default_qty_value=2,   default_qty_type=strategy.fixed, initial_capital=10000, currency=currency.USD)

len = input(title="RSI Period", minval=1, defval=9)
src = input(title="RSI Source", defval=close)
lbR = input(title="Pivot Lookback Right", defval=3)
lbL = input(title="Pivot Lookback Left", defval=1)
takeProfitRSILevel = input(title="Take Profit at RSI Level", minval=70, defval=80)

rangeUpper = input(title="Max of Lookback Range", defval=60)
rangeLower = input(title="Min of Lookback Range", defval=5)
plotBull = input(title="Plot Bullish", defval=true)
plotHiddenBull = input(title="Plot Hidden Bullish", defval=true)
plotBear = input(title="Plot Bearish", defval=true)
plotHiddenBear = input(title="Plot Hidden Bearish", defval=false)

//useTrailStopLoss = input(false, title="Use Trailing Stop Loss")

sl_type = input("NONE", title="Trailing StopLoss Type", options=['ATR','PERC', 'NONE'])

stopLoss = input(title="Stop Loss%", defval=5, minval=1)

atrLength=input(14, title="ATR Length (for Trailing stop loss)")
atrMultiplier=input(3.5, title="ATR Multiplier (for Trailing stop loss)")


bearColor = color.purple
bullColor = color.green
hiddenBullColor = color.new(color.green, 80)
hiddenBearColor = color.new(color.red, 80)
textColor = color.white
noneColor = color.new(color.white, 100)

osc = rsi(src, len)

plot(osc, title="RSI", linewidth=2, color=#8D1699)
hline(50, title="Middle Line", linestyle=hline.style_dotted)
obLevel = hline(70, title="Overbought", linestyle=hline.style_dotted)
osLevel = hline(30, title="Oversold", linestyle=hline.style_dotted)
fill(obLevel, osLevel, title="Background", color=#9915FF, transp=90)

plFound = na(pivotlow(osc, lbL, lbR)) ? false : true
phFound = na(pivothigh(osc, lbL, lbR)) ? false : true

_inRange(cond) =>
    bars = barssince(cond == true)
    rangeLower <= bars and bars <= rangeUpper

//------------------------------------------------------------------------------
// Regular Bullish

// Osc: Higher Low
oscHL = osc[lbR] > valuewhen(plFound, osc[lbR], 1) and _inRange(plFound[1])

// Price: Lower Low
priceLL = low[lbR] < valuewhen(plFound, low[lbR], 1)

bullCond = plotBull and priceLL and oscHL and plFound

plot(
	 plFound ? osc[lbR] : na,
	 offset=-lbR,
	 title="Regular Bullish",
	 linewidth=2,
	 color=(bullCond ? bullColor : noneColor),
	 transp=0
	 )


plotshape(
	 bullCond ? osc[lbR] : na,
	 offset=-lbR,
	 title="Regular Bullish Label",
	 text=" Bull ",
	 style=shape.labelup,
	 location=location.absolute,
	 color=bullColor,
	 textcolor=textColor,
	 transp=0
	 )

//------------------------------------------------------------------------------
// Hidden Bullish

// Osc: Lower Low
oscLL = osc[lbR] < valuewhen(plFound, osc[lbR], 1) and _inRange(plFound[1])

// Price: Higher Low
priceHL = low[lbR] > valuewhen(plFound, low[lbR], 1)

hiddenBullCond = plotHiddenBull and priceHL and oscLL and plFound

plot(
	 plFound ? osc[lbR] : na,
	 offset=-lbR,
	 title="Hidden Bullish",
	 linewidth=2,
	 color=(hiddenBullCond ? hiddenBullColor : noneColor),
	 transp=0
	 )

plotshape(
	 hiddenBullCond ? osc[lbR] : na,
	 offset=-lbR,
	 title="Hidden Bullish Label",
	 text=" H Bull ",
	 style=shape.labelup,
	 location=location.absolute,
	 color=bullColor,
	 textcolor=textColor,
	 transp=0
	 )

longCondition=bullCond or hiddenBullCond
//? osc[lbR] : na  
//hiddenBullCond
strategy.entry(id="RSIDivLE", long=true,  when=longCondition)


//Trailing StopLoss
////// Calculate trailing SL
/////////////////////////////////////////////////////
sl_val = sl_type == "ATR"      ? stopLoss * atr(atrLength) : 
         sl_type == "PERC" ? close * stopLoss / 100 : 0.00

trailing_sl = 0.0
trailing_sl :=   strategy.position_size>=1 ?  max(low  - sl_val, nz(trailing_sl[1])) :  na

//draw initil stop loss
//plot(strategy.position_size>=1 ? trailing_sl : na, color = color.blue , style=plot.style_linebr,  linewidth = 2, title = "stop loss")
//plot(trailing_sl, title="ATR Trailing Stop Loss", style=plot.style_linebr, linewidth=1, color=color.purple, transp=30)
//Trailing StopLoss
////// Calculate trailing SL
/////////////////////////////////////////////////////


//------------------------------------------------------------------------------
// Regular Bearish

// Osc: Lower High
oscLH = osc[lbR] < valuewhen(phFound, osc[lbR], 1) and _inRange(phFound[1])

// Price: Higher High
priceHH = high[lbR] > valuewhen(phFound, high[lbR], 1)

bearCond = plotBear and priceHH and oscLH and phFound

plot(
	 phFound ? osc[lbR] : na,
	 offset=-lbR,
	 title="Regular Bearish",
	 linewidth=2,
	 color=(bearCond ? bearColor : noneColor),
	 transp=0
	 )

plotshape(
	 bearCond ? osc[lbR] : na,
	 offset=-lbR,
	 title="Regular Bearish Label",
	 text=" Bear ",
	 style=shape.labeldown,
	 location=location.absolute,
	 color=bearColor,
	 textcolor=textColor,
	 transp=0
	 )

//------------------------------------------------------------------------------
// Hidden Bearish

// Osc: Higher High
oscHH = osc[lbR] > valuewhen(phFound, osc[lbR], 1) and _inRange(phFound[1])

// Price: Lower High
priceLH = high[lbR] < valuewhen(phFound, high[lbR], 1)

hiddenBearCond = plotHiddenBear and priceLH and oscHH and phFound

plot(
	 phFound ? osc[lbR] : na,
	 offset=-lbR,
	 title="Hidden Bearish",
	 linewidth=2,
	 color=(hiddenBearCond ? hiddenBearColor : noneColor),
	 transp=0
	 )

plotshape(
	 hiddenBearCond ? osc[lbR] : na,
	 offset=-lbR,
	 title="Hidden Bearish Label",
	 text=" H Bear ",
	 style=shape.labeldown,
	 location=location.absolute,
	 color=bearColor,
	 textcolor=textColor,
	 transp=0
	 )
longCloseCondition=crossover(osc,takeProfitRSILevel) or bearCond
strategy.close(id="RSIDivLE", comment="Close All="+tostring(close - strategy.position_avg_price, "####.##"), when= abs(strategy.position_size)>=1  and  sl_type == "NONE" and longCloseCondition)

//close all on stop loss
strategy.close(id="RSIDivLE", comment="TSL="+tostring(close - strategy.position_avg_price, "####.##"),  when=abs(strategy.position_size)>=1 and (sl_type == "PERC"   or sl_type == "ATR" ) and crossunder(close, trailing_sl)  )  //close<ema55 and rsi5Val<20 //ema34<ema55  //close<ema89


// Calculate start/end date and time condition
startDate  = input(timestamp("2019-01-01T00:00:00"), type = input.time)
finishDate = input(timestamp("2021-01-01T00:00:00"), type = input.time)
 
time_cond  = time >= startDate and time <= finishDate


Mehr