R 广义预测误差方差分解

R 广义预测误差方差分解,r,R,我试图实现这个关于广义预测误差方差分解的R代码 > fevd_generalised <- function(model, n.ahead=10, normalize=TRUE) { if (class(model) != "varest") { return("The model class is not varest!") } A <- Phi(model, n.ahead) epsilon <- residuals(model) Sigma <- t(epsi

我试图实现这个关于广义预测误差方差分解的R代码

> fevd_generalised <- function(model, n.ahead=10, normalize=TRUE) {
if (class(model) != "varest") {
return("The model class is not varest!")
}
A <- Phi(model, n.ahead)
epsilon <- residuals(model)
Sigma <- t(epsilon)%*%epsilon / (model$obs - model$p*model$K)
gi <- array(0, dim(A))
sigmas <- sqrt(diag(Sigma))
for (j in 1:dim(A)[3]) {
gi[,,j] <- t( t( A[,,j]%*%Sigma ) / sqrt(sigmas) )
}
d <- array(0, dim(A)[c(2,3)])
for (j in 1:dim(d)[2]) {
d[,j] <- diag(A[,,j]%*%Sigma%*%t(A[,,j]))
}

num <- apply(gi^2,1:2,sum)
den <- c(apply(d,1,sum))
fevd <- num/den
if (normalize) {
return(fevd/apply(fevd, 1, sum))
} else {
return(fevd)
}
}

> Blockquote

fevd_泛化也许有点太晚了,但是,这个包实现了您要求的功能