Model GARCH di R
Kris Boudt
Professor of finance and econometrics


quantile() pada objek ugarchroll.ugarchspec(): Tentukan model GARCH yang digunakan
garchspec <- ugarchspec(mean.model = list(armaOrder = c(1, 0)),
variance.model = list(model = "gjrGARCH"),
distribution.model = "sstd")
ugarchroll(): Estimasi model GARCH pada sampel bergulir
garchroll <- ugarchroll(garchspec, data = sp500ret, n.start = 2500,
refit.window = "moving", refit.every = 100)
quantile(): Hitung kuantil prediksi
garchVaR <- quantile(garchroll, probs = 0.05)
Anda bisa memilih probabilitas rugi lain: 1% dan 2,5% juga populer
actual <- xts(as.data.frame(garchroll)$Realized, time(garchVaR))
VaRplot(alpha = 0.05, actual = actual, VaR = garchVaR)

Pelanggaran VaR terjadi saat return aktual lebih kecil dari nilai VaR yang diprediksi: $ R_t \ < {VaR}_t$.
Frekuensi pelanggaran VaR disebut cakupan VaR.
# Perhitungan cakupan untuk return S&P 500 dan level probabilitas 5%
mean(actual < garchVaR)
0.05159143
distribution.model = "std" alih-alih distribution.model = "sstd":
garchspec <- ugarchspec(mean.model = list(armaOrder = c(1, 0)),
variance.model = list(model = "gjrGARCH"),
distribution.model = "std")
Estimasi bergulir dan prediksi VaR 5%:
garchroll <- ugarchroll(garchspec, data = sp500ret, n.start = 2500,
refit.window = "moving", refit.every = 100)
garchVaR <- quantile(garchroll, probs = 0.05)
mean(actual < garchVaR) # menghasilkan 0.05783233
variance.model = list(model = "sGARCH")
alih-alih
variance.model = list(model = "gjrGARCH"):
garchspec <- ugarchspec(mean.model = list(armaOrder = c(1, 0)),
variance.model = list(model = "sGARCH"),
distribution.model = "std")
Estimasi bergulir dan prediksi VaR 5%:
garchroll <- ugarchroll(garchspec, data = sp500ret, n.start = 2500,
refit.window = "moving", refit.every = 100)
garchVaR <- quantile(garchroll, probs = 0.05)
mean(actual < garchVaR) # menghasilkan 0.06074475
refit.every = 1000
alih-alih
refit.every = 100:
garchspec <- ugarchspec(mean.model = list(armaOrder = c(1, 0)),
variance.model = list(model = "sGARCH"),
distribution.model = "std")
garchroll <- ugarchroll(garchspec, data = sp500ret, n.start = 2500,
refit.window = "moving", refit.every = 1000)
garchVaR <- quantile(garchroll, probs = 0.05)
mean(actual < garchVaR) # menghasilkan 0.06199293
Model GARCH di R