2

在下面的代码中,我试图创建一个矩阵来列出每个城市的 opt.lam。运行循环后,前两个城市总是工作,然后我得到任何城市的错误。

这是我得到的错误。(coefmatrix 工作正常,它只是产生此错误的 lambdamatrix)。

[<-( *tmp*, , i, value = c(0.577199381062121, 0.577199381062121, : 下标越界) 中的错误

这是我的代码:

lambdamatrix <- matrix(nrow=n,ncol=2)
rownames(lambdamatrix) <- cityIDs
colnames(lambdamatrix) <- c("lambda.min","lambda.1se")
for (i in 1:n) {
  data <- subset(simdata, city==cityIDs[i])
  x <- as.matrix(data.frame(data[,3:24]))
cvfit <- cv.glmnet(x, data$Y, family="poisson", offset=log(data$population))
opt.lam <- c(cvfit$lambda.min, cvfit$lambda.1se)
fit <- glmnet(x, data$Y, family= "poisson", offset=log(data$population))
abline(plot(fit, "lambda", label= TRUE, 
            main = cityIDs[i]), v=log(opt.lam), lty=2, lwd=3, 
                                    col=c("red","dark green"))
coefmatrix[,i] <- coef(fit, s=opt.lam[1])[1:23]
lambdamatrix[,i] <- c(cvfit$lambda.min, cvfit$lambda.1se)[1:n]
}`
4

1 回答 1

3

In [,i],i是列索引器(而[i,]将是行索引器)。

既然你定义lambdamatrixmatrix(nrow = n, ncol = 2),一旦你过去了,你就会i=2要求不存在的列。

于 2015-03-23T23:51:33.330 回答