Я использую rollapply
для создания прогноза на 1 шаг вперед по модели GARCH (1,1) (garchFit
).Ниже приведен пример:
require(fGarch)
require(zoo)
data(EuStockMarkets)
dax <- diff(log(EuStockMarkets))[,"DAX"]
gfit <- function(df)
{
series <- df
capture.output(gf <- garchFit(formula=~arma(0,0) + garch(1,1), data=series), file='NUL')
g <- predict(gf, n.ahead=1)[,2]
attributes(g) <- NULL
return(g)
}
rolling <- rollapply(dax, width=250, FUN=gfit)
Однако это занимает относительно много времени.Итак, мой вопрос: есть ли способ ускорить это?