У меня есть следующая функция R, которая вычисляет волатильность EWMA для заданных ценных бумаг:
EWMAvol = function(returns, lambda, rollwindow){
EWMA.mat = matrix(NA, nrow = nrow(returns), ncol = ncol(returns))
for (k in 1 : ncol(returns)){
for (j in rollwindow : nrow(returns)){
td = returns
data = as.matrix(td[(j - rollwindow + 1) : j, k])
ewmaVar.mat = matrix()
ewmaVar.mat[1] = 0
for (i in 2 : rollwindow){
ewmaVar.mat[i] = lambda * ewmaVar.mat[i-1]+ (1 - lambda) * data[i]^2
}
EWMA.mat[j, k] = sqrt(ewmaVar.mat[length(ewmaVar.mat)])
}
}
return(EWMA.mat)
}
Данные, на которые опирается эта функция:
> class(rets)
[1] "xts" "zoo"
который исходит от функции Return.calculate()
из пакета PerformanceAnalytics
.
Вывод, который я сейчас получаю:
> class(EWMAvol)
[1] "matrix"
Можно ли вернуть объект/данные xts
или zoo
из моего кода? Кроме того, я хотел бы сохранить имена столбцов. Как я могу этого добиться?
Спасибо.