Мне нужно выполнить скользящую оценку VaR ежедневной доходности акций. Сначала я сделал следующее:
library(PerformanceAnalytics)
data(edhec)
sample<-edhec[,1:5]
var605<-rollapply(as.zoo(sample),width=60,FUN=function(x) VaR(R=x,p=.95,method="modified",invert=T),by.column=TRUE,fill=NA)
Он выполняет вычисления и возвращает объект зоопарка, но выдает ряд предупреждений следующим образом:
VaR calculation produces unreliable result (inverse risk) for column: 1 : -0.00030977098532231
Затем я попробовал то же самое с образцом моих данных следующим образом:
library(foreign)
sample2 <- read.dta("sample2.dta")
sample2.xts <- xts(sample2[,-1],order.by=as.Date(sample2$datadate,format= "%Y-%m-%d"))
any(is.na(sample2.xts))
var605<-rollapply(as.zoo(sample2.xts),width=60,FUN=function(x) VaR(R=x,p=.95,method="modified",invert=T),by.column=TRUE,fill=NA)
Но он не возвращает никакого объекта зоопарка и выдает следующие предупреждения и ошибки:
VaR calculation produces unreliable result (inverse risk) for column: 1 : -0.0077322590200255
Error in if (eval(tmp < 0)) { : missing value where TRUE/FALSE needed
Called from: top level
Из более раннего сообщения (Использование функции rollapply для расчета VaR с использованием R) Я понимаю, что скользящая оценка не может быть выполнена, если отсутствует полное скользящее окно, но в моих данных (sample2.dta) пропущенных значений нет.
sample2.dta можно загрузить с https://drive.google.com/file/d/0B8usDJAPeV85WDdDQTFEbGQwaUU/edit?usp=sharing
Может ли кто-нибудь помочь мне решить и понять эту проблему?