Strategi Divergensi Diskrit RSI


Tanggal Pembuatan: 2023-11-16 11:36:45 Akhirnya memodifikasi: 2023-11-16 11:36:45
menyalin: 0 Jumlah klik: 862
1
fokus pada
1617
Pengikut

Strategi Divergensi Diskrit RSI

Ringkasan

Strategi ini digunakan untuk menilai volatilitas dengan menghitung crossover antara RSI dan EMA rata-rata, dan menggabungkan RSI dengan deviasi harga untuk mencari titik jual beli potensial. Strategi ini merupakan strategi pelacakan tren.

Prinsip Strategi

  1. Indikator RSI yang dihitung dengan panjang 14, di mana RSI di atas melewati garis 50 untuk melihat lebih banyak sinyal, di bawah melewati untuk melihat lebih jauh.

  2. RSI diperhitungkan dengan 20 periode EMA rata-rata dan 14 periode EMA rata-rata, ketika garis cepat melewati garis lambat sebagai sinyal beli, dan turun sebagai sinyal jual.

  3. Deteksi RSI yang menyimpang dari harga:

  • Banyak Kepala Berbalik: Harga Berinovasi Rendah Tapi RSI Tidak Berinovasi Rendah, Untuk Sinyal Beli

  • Hidden Multiple Deviation: Harga Berinovasi Tinggi, Namun RSI Tidak Berinovasi Tinggi, Untuk Sinyal Beli

  • Harga Berinovasi Tinggi Tapi RSI Tidak Berinovasi Tinggi, Untuk Sinyal Penjualan

  • Hidden Blank: Harga Berinovasi Rendah Tapi RSI Tidak Berinovasi Rendah, Untuk Sinyal Penjualan

  1. Opsional untuk memulai strategi stop loss, termasuk stop loss persentase dan stop loss ATR.

Analisis Keunggulan

  1. Keuntungan dari RSI adalah bahwa ia dapat mendeteksi overbought dan oversold. Keuntungan dari EMA adalah bahwa ia dapat berfungsi sebagai smoothing dan menghilangkan sebagian dari kebisingan.

  2. RSI dan harga deviasi dapat memberikan sinyal awal sebelum trend berbalik.

  3. Mengintegrasikan dua sinyal indikator yang dapat saling diverifikasi untuk meningkatkan stabilitas strategi.

  4. Sistem pengendalian kerugian dapat mengontrol kerugian tunggal.

Analisis risiko

  1. RSI sebagai indikator indeks yang berfluktuasi dengan harga, ketika harga berfluktuasi tajam, utilitas indikator RSI akan diskon.

  2. EMA memperkirakan ada masalah waktu yang tidak dapat dipastikan.

  3. Jika harga terus berjalan pada arah yang berbeda dari sinyal, maka akan muncul sinyal palsu.

  4. Penetapan stop loss yang tidak masuk akal dapat menyebabkan stop loss yang tidak perlu.

  5. Pengunduran diri mungkin lebih besar dan membutuhkan dukungan keuangan yang cukup.

Arah optimasi

  1. Perhitungan RSI dan EMA dari berbagai parameter dapat diuji untuk mencari kombinasi parameter yang optimal.

  2. Anda dapat mempertimbangkan untuk mengganti EMA rata-rata dengan indikator lain seperti MACD untuk optimasi kombinasi.

  3. Anda dapat mengatur mekanisme konfirmasi untuk menghindari penyimpangan palsu. Jika perlu, beberapa sinyal penyimpangan berturut-turut dipicu.

  4. Menambahkan strategi stop-loss untuk mengunci keuntungan.

  5. Anda dapat masuk ke pasar berdasarkan sinyal jangka pendek, seperti pola candlestick, dan menilai tren yang sesuai dengan strategi ini.

Meringkaskan

Strategi ini mengintegrasikan penilaian overbought dan oversold dari RSI, penilaian tren dari EMA, dan prediksi sinyal deviasi untuk membentuk sistem pelacakan tren yang lebih lengkap. Efek strategi yang lebih baik dapat diperoleh berdasarkan penyesuaian parameter dan pengoptimalan kombinasi. Namun, perlu berhati-hati untuk mencegah terjadinya kejutan dan gangguan sinyal palsu di pasar tren. Dengan manajemen dana yang ketat, strategi ini dapat menghasilkan keuntungan tambahan yang stabil di garis tengah.

Kode Sumber Strategi
/*backtest
start: 2023-11-08 00:00:00
end: 2023-11-15 00:00:00
period: 30m
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=4
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=14)
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)

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.red
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=color.white)
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=color.gray, 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

src1 = close, 
len6 = input(14, minval=1, title="RSI Length")
len7 = input(20, minval=1, title="EMA of RSI Length")
len8 = input(14,minval=1, title="Fast EMA")
up = rma(max(change(src1), 0), len6)
down = rma(-min(change(src1), 0), len6)
rsi = down == 0 ? 100 : up == 0 ? 0 : 100 - (100 / (1 + up / down))
emaRSI = ema(rsi,len7)
fastEmaRSI=ema(rsi,len8)

plot(emaRSI, title="EMA of RSI", linewidth=1, color=color.red)
plot(fastEmaRSI,title="Fast EMA of RSI", linewidth=1,color = color.lime)
band1 = hline(80, title="Upper Line", linewidth=1, color=color.red)
band0 = hline(20, title="Lower Line", linewidth=1, color=color.lime)
fill(band1, band0, color=color.purple)