当我运行此程序时,我会在160'运行后收到错误消息。 (210):
Error in solve.default(fit$hessian) : system is computationally singular: reciprocal condition number = 1.24675e-16
In addition: There were 35 warnings (use warnings() to see them)
当我收到错误时,程序停止。我用另一组数据运行程序。然后它工作正常。如何在此处使用tryCatch,以便在发生错误时程序不会停止?
minOrder <- c(0,0,1,0)
maxOrder <- c(5,5,2,2)
bestAIC <- 1e9
model <- list()
N1 <- ((0^minOrder[1]+maxOrder[1])*(0^minOrder[2]+maxOrder[2])*(0^minOrder[3]+maxOrder[3])* (0^minOrder[4]+maxOrder[4]))
AIC <- numeric(N1)
MODEL <- mat.or.vec(N1,length(maxOrder))
i <- 1
for(p in minOrder[1]:maxOrder[1]){
for(q in minOrder[2]:maxOrder[2]){
if(p==0 && q==0){q <- 1}
for(m in minOrder[3]:maxOrder[3]){
for(s in minOrder[4]:maxOrder[4]){
model <- garchFit(substitute(~arma(ar,ma)+garch(alpha,beta), list(ar=p,ma=q,alpha=m,beta=s)), data=logr, trace=F, cond.dist = c("norm"), include.mean=TRUE)
AICmodel <- model@fit$ics[1]
AIC[i] <- AICmodel
MODEL[i,] <- c(p,q,m,s)
i <- i+1
if(AICmodel < bestAIC){
bestAIC <- AICmodel
bestFIT <- model
bestMODEL <- c(p,q,m,s)
}
}
}
}
}
答案 0 :(得分:0)
您应该首先确定哪个是给您错误的调用。您可以在程序停止后调用traceback()
来执行此操作。然后将该呼叫括在try
中。我猜您在致电garchFit
时收到错误消息。如果是这种情况,您可以:
model <- try(garchFit(substitute(~arma(ar,ma)+garch(alpha,beta), list(ar=p,ma=q,alpha=m,beta=s)), data=logr, trace=F, cond.dist = c("norm"), include.mean=TRUE))
if (class(model)=="try-error") next
try
返回它包含的表达式的结果(如果成功)或类try-error
的对象,其中包含错误的详细信息。如果是这种情况,则跳过next
的下一次迭代。您将收到错误的详细信息,但程序将继续。如果您不想要显示任何消息,请使用try
参数调用silent=TRUE
。