出于某种原因,当我指定 glms(事实证明,还有 lm)时,R 并没有预测数据的缺失值。这是一个例子:
y = round(runif(50))
y = c(y,rep(NA,50))
x = rnorm(100)
m = glm(y~x, family=binomial(link="logit"))
p = predict(m,na.action=na.pass)
length(p)
y = round(runif(50))
y = c(y,rep(NA,50))
x = rnorm(100)
m = lm(y~x)
p = predict(m)
length(p)
p 的长度应该是 100,但它是 50。奇怪的是,我在同一个脚本中还有其他预测可以从缺失的数据中预测。
编辑:事实证明,那些其他预测是完全错误的——我正在做imputed.value = rnorm(N,mean.from.predict,var.of.prediction.interval)
. 这从 lm predict 或 glm predict 函数中回收length(predict)<N
了 mean 和 sd 向量 when ,这与我所寻求的完全不同。
所以我的问题是我的示例代码如何阻止 glm 和 lm 预测缺失值?
谢谢!