Strategi Indikator Divergensi RSI

Penulis:ChaoZhang, Tarikh: 2024-01-25 11:49:36
Tag:

img

Ringkasan

Strategi Penunjuk Perbezaan RSI adalah strategi perdagangan kuantitatif berdasarkan penunjuk Indeks Kekuatan Relatif (RSI). Ia mengesan peluang untuk pembalikan trend dengan menganalisis perbezaan antara penunjuk RSI dan harga, bertujuan untuk membeli rendah dan menjual tinggi.

Logika Strategi

Indikator teras strategi ini adalah RSI. Ia menganalisis perbezaan antara penunjuk RSI dan harga.

Secara khusus, apabila RSI membentuk rendah yang agak rendah sementara harga membentuk rendah yang relatif tinggi, ia adalah perbezaan menaik antara RSI dan harga. Ini menunjukkan bahawa harga mungkin berbalik ke atas. Strategi akan menubuhkan kedudukan panjang pada ketika ini.

Sebaliknya, apabila RSI membentuk tinggi yang agak tinggi sementara harga membentuk tinggi yang agak rendah, ia adalah perbezaan penurunan antara RSI dan harga. Ini menunjukkan bahawa harga mungkin berbalik ke bawah. Strategi akan menubuhkan kedudukan pendek pada ketika ini.

Dengan menangkap perbezaan ini antara RSI dan harga, strategi dapat mengesan peluang untuk pembalikan harga tepat pada masanya dan mencapai membeli rendah dan menjual tinggi.

Kelebihan

Strategi RSI Divergence mempunyai kelebihan berikut:

  1. Kepelbagaian antara RSI dan harga sering menunjukkan pembalikan trend yang akan datang, yang merupakan isyarat ramalan yang sangat berkesan.

  2. Mencapai membeli rendah dan menjual tinggi. Dengan menubuhkan kedudukan di titik perbezaan, ia dapat membeli pada harga yang agak rendah dan menjual pada harga yang agak tinggi, sejajar dengan amalan terbaik perdagangan kuantitatif.

  3. Menembusi batasan strategi RSI konvensional. Strategi RSI konvensional hanya memberi tumpuan kepada kawasan overbought dan oversold. Strategi ini menggunakan sifat pembalikan intrinsik RSI itu sendiri untuk menangkap titik perubahan dengan lebih tepat, meningkatkan kecekapan strategi.

  4. Tetapan parameter mudah. parameter utama hanya tempoh RSI dan tempoh melihat kembali, yang sangat mudah dan mudah untuk mengoptimumkan.

Risiko

Strategi RSI Divergence juga mempunyai beberapa risiko:

  1. Isyarat perbezaan boleh menjadi isyarat palsu. Perbezaan antara RSI dan harga tidak semestinya membawa kepada pembalikan harga sebenar. Kadang-kadang mereka juga membentuk pembalikan palsu, yang membawa kepada kerugian perdagangan. Stop loss yang munasabah harus ditetapkan untuk mengawal risiko.

  2. Prestasi yang lemah dalam pasaran trend. Apabila harga menunjukkan trend arah yang jelas, ruang keuntungan strategi ini agak kecil. Adalah lebih baik untuk melumpuhkan strategi buat sementara waktu dalam kes ini dan menunggu pasaran baru.

  3. Risiko piramida. Strategi telah menetapkan parameter piramida. Sekiranya perdagangan yang kalah berturut-turut, ia boleh mempercepatkan pengeluaran akaun. Ukuran kedudukan dan stop loss harus dikawal untuk mengurangkan risiko.

Peningkatan

Strategi ini juga boleh dioptimumkan dalam aspek berikut:

  1. Menggabungkan penunjuk lain untuk penapisan isyarat. MACD, KDJ dan penunjuk lain boleh ditambah untuk mengesahkan titik perbezaan RSI, menapis beberapa isyarat palsu dan meningkatkan kadar kemenangan strategi.

  2. Mengoptimumkan parameter RSI. Tempoh RSI yang berbeza boleh diuji untuk mencari yang paling sesuai dengan ciri produk. Secara amnya antara 6-15 berfungsi dengan baik.

  3. Mengoptimumkan tempoh melihat kembali. Tempoh melihat kembali secara langsung mempengaruhi kekerapan perdagangan strategi. Nilai yang berbeza boleh diuji untuk mencari kekerapan yang optimum, biasanya antara 5-15 adalah julat yang baik.

  4. Tambah logik stop loss. Kaedah stop loss yang munasabah seperti ATR trailing stop loss boleh dilaksanakan untuk mengurangkan kerugian dengan cepat apabila berlaku. Ini dapat mengawal risiko strategi dengan berkesan.

Kesimpulan

Strategi RSI Divergence dengan tepat menangkap titik perubahan harga dengan menganalisis sifat pembalikan intrinsik penunjuk RSI itu sendiri. Ia mencapai pendekatan perdagangan beli rendah-jual tinggi. Berbanding dengan strategi RSI overbought-oversold tradisional, ia menggunakan ciri-ciri RSI yang lebih halus dan intrinsik, meningkatkan kecekapan. Dengan pengoptimuman parameter dan kawalan risiko, ia sangat sesuai untuk menangkap peluang perdagangan jangka pendek dalam pasaran yang berbeza.


/*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


Lebih lanjut