[R-SIG-Finance] Copula-EVT-GARCH with rmgarch package (reproducible code)

Sachin Kuruvithadam sacios at hotmail.it
Wed Jun 22 19:19:21 CEST 2016


I'm trying to simulate 1-step ahead returns 5000 times for a portfolio of 9 variables. After specifying their GJR-GARCH specifications with SPD marginals, I use the following code (which was inspired by the examples in the 'rmgarch.tests' folder). I use the first 571x9 observations for fitting and the last 570 for out-of-sample analysis. Moreover, I use a moving-window approach, in the sense that I always use the last 571 observations in the cgarchfilter rather than [1:(T+i)] as in the example. Once the simulated returns 'simx' are stored in 'simulatedreturns', I compute the return of an equally-weighted portfolio as a 570x5000 vector, i.e. one series of return of each observation for each simulation. Last, I compute VaR (90%, 95%, 99%) as the respective quantile (0.10, 0.05, 0.01).


My problem is that, contrary to the literature I've found on the topic, VaR is severely underestimated, I obtain a number of violations which is way more than expected (should be 57 for 90%VaR, 28 for 95%VaR, 6 for 99%VaR). Is there any error in the code I have below? I've followed the example by the letter and cannot understand what went wrong. Anyone can help? Any hint is GREATLY appreciated!


library(rugarch)
library(rmgarch)

data(dji30retw)
Dat = dji30retw[, 1:9, drop = FALSE]

model <- ugarchspec(variance.model=list(model="gjrGARCH", garchOrder=c(1,1), variance.targeting=TRUE),
                    mean.model=list(armaOrder=c(0,0), include.mean=F, archm=F, archpow=1),
                    distribution.model="norm")
spec = cgarchspec(uspec = multispec(replicate(3, model)), VAR = FALSE, robust = FALSE,
                    lag.criterion = "AIC", external.regressors = NULL,
                    dccOrder = c(1,1), asymmetric = TRUE, distribution.model = list(copula = "mvt",
                                                                                     method = "ML", time.varying = TRUE,
                                                                                     transformation = "spd"))
fit = cgarchfit(spec, data = Dat, out.sample = 570, cluster = NULL,
                  fit.control = list(eval.se=FALSE))
T = dim(Dat)[1]-570
simMu = simS = filtMu = filtS = matrix(NA, ncol = 9, nrow = 570)
simCor = simC = filtC = filtCor = array(NA, dim = c(9,9,570))
colSd = function(x) apply(x, 2, "sd")
specx = spec
for(i in 1:9) specx at umodel$fixed.pars[[i]] = as.list(fit at model$mpars[fit at model$midx[,i]==1,i])
setfixed(specx)<-as.list(fit at model$mpars[fit at model$midx[,10]==1,10])

simulatedreturns <- array(dim=c(570,9,5000))
for(i in 1:570){
  if(i==1){
    presigma = matrix(tail(sigma(fit), 1), ncol = 9)
    prereturns = matrix(unlist(Dat[T, ]), ncol = 9, nrow = 1)
    preresiduals = matrix(tail(residuals(fit),1), ncol = 9, nrow = 1)
    preR = last(rcor(fit))[,,1]
    diag(preR) = 1
    preQ = fit at mfit$Qt[[length(fit at mfit$Qt)]]
    preZ = tail(fit at mfit$Z, 1)
    tmp = cgarchfilter(specx, Dat[2:(T+1), ], filter.control = list(n.old = T))
    filtMu[i,] = tail(fitted(tmp), 1)
    filtS[i,] = tail(sigma(tmp), 1)
    filtC[,,i] = last(rcov(tmp))[,,1]
    filtCor[,,i] = last(rcor(tmp))[,,1]
  } else{
    presigma = matrix(tail(sigma(tmp), 1), ncol = 9)
    prereturns = matrix(unlist(Dat[(T+i-1), ]), ncol = 9, nrow = 1)
    preresiduals = matrix(tail(residuals(tmp),1), ncol = 9, nrow = 1)
    preR = last(rcor(tmp))[,,1]
    diag(preR) = 1
    preQ = tmp at mfilter$Qt[[length(tmp at mfilter$Qt)]]
    preZ = tail(tmp at mfilter$Z, 1)

    tmp = cgarchfilter(specx17, Dat[(i+1):(T+i), ], filter.control = list(n.old = T))
    filtMu[i,] = tail(fitted(tmp), 1)
    filtS[i,] = tail(sigma(tmp), 1)
    filtC[,,i] = last(rcov(tmp))[,,1]
    filtCor[,,i] = last(rcor(tmp))[,,1]
  }
  sim = cgarchsim(fit, n.sim = 1, m.sim = 5000, startMethod = "sample", preR = preR, preQ = preQ, preZ = preZ,
                    prereturns = prereturns, presigma = presigma, preresiduals = preresiduals, cluster = NULL)
  simx = t(sapply(sim at msim$simX, FUN = function(x) x[1,]))
  simMu[i,] = colMeans(simx)
  simC[,,i] = sim at msim$simH[[1]][,,1]
  simCor[,,i] = sim at msim$simR[[1]][,,1]
  simS[i,] = sqrt(diag(simC[,,i]))
  simulatedreturns[i,,]=simx
}



	[[alternative HTML version deleted]]



More information about the R-SIG-Finance mailing list