R中ugarchfit函数的循环函数

R中ugarchfit函数的循环函数,r,time-series,arima,fgarch,R,Time Series,Arima,Fgarch,我有时间序列数据。我已经返回了数据并获得了日志返回。我的目标是从模型列表中选择最适合的ARMA-GARCH模型。我不想分别拟合每个模型,而是想一次拟合这些模型并从中选择最好的。因此,我制作了一个warp函数来完成这项工作。例如,我想适合几种型号: 1- ARMA(1,1)-GARCH(1,1) 2- ARMA(1,2)-GARCH(1,1) 3- ARMA(1,3)-GARCH(1,1) 4- ARMA(2,1)-GARCH(1,1) 5- ARM

我有时间序列数据。我已经返回了数据并获得了日志返回。我的目标是从模型列表中选择最适合的
ARMA-GARCH
模型。我不想分别拟合每个模型,而是想一次拟合这些模型并从中选择最好的。因此,我制作了一个warp函数来完成这项工作。例如,我想适合几种型号:

   1- ARMA(1,1)-GARCH(1,1)
 
   2-  ARMA(1,2)-GARCH(1,1)

   3-  ARMA(1,3)-GARCH(1,1)

   4-  ARMA(2,1)-GARCH(1,1)

   5-  ARMA(2,2)-GARCH(1,1)

   6-  ARMA(2,3)-GARCH(1,1)

   .. ..

1-  ARMA(1,1)-GARCH(1,2)

2-  ARMA(1,1)-GARCH(1,3)

3-  ARMA(1,1)-GARCH(2,1)
等等。也就是说,让
ARMA(p,q)
的范围从
1:6
开始,而
GARCH(p,q)
也从
1:6
开始。如何使用R中的
loop
函数执行此操作。我希望返回所有模型中最小的标准(
AIC
)。
换句话说,我希望我的函数在不同的订单之间自动循环

以下是我的尝试:

GarchWarp <- function(n,dat,d){ ## n is the order of the model. d is the dimension of the data, for example, one series, two series. 

    GarchWarp <- function(n,dat,d){

meanModel <- varModel <- list()
  if(n > 1){
    for(i in 1:n){
  
  meanModel[i] <- list(armaOrder = c(i,i)) # ARMA
  varModel <- list(model = "sGARCH", garchOrder = c(i,i)) # GARCH
  uspec <- ugarchspec(varModel, mean.model = meanModel,
                      distribution.model = "std") # scaled Student t
  fitPC <- apply(dat, 2, function(x) ugarchfit(uspec, data = x))
  Recrit <- lapply(1:d, function(i) infocriteria(fitPC[[i]]))
    }
  }
  return(Recrit)
}

您好,必须通过
dput(head(data))
为您的每个数据集提供可复制的样本数据,以便其他人可以使用它,您将有更好的机会获得相关结果。@Anoushiravan R谢谢。我编辑它。
    structure(c(0.00618750144876756, 0.00491561236137983, 0.00178237912109402, 
0.0052134813154332, 0.00129554617030614, 0.00232162478086728, 
0, 0.0320481134224817, 0.00881819387210214, 0, 0.00569585759405733, 
-0.00259413863757629), class = c("xts", "zoo"), index = structure(c(1514851200, 
1514937600, 1515024000, 1515110400, 1515369600, 1515456000), tzone = "UTC", tclass = c("POSIXct", 
"POSIXt")), .Dim = c(6L, 2L), .Dimnames = list(NULL, c("P_Sha", 
"P_Jap")))