基本上,我正在运行nlme::lme
,但缺少值。该模型适合na.action=na.omit
,但是为什么拟合/残差/ coef的名称似乎都被移动了一行?
## Generate data ---------------------
X1=gl(2,4)
X2=gl(2,2,8)
Y=rnorm(8)
dat=data.frame(Y=Y,X1=X1,X2=X2)
dat
## missing value -------------
mis.dat=dat
mis.dat[3,"Y"]=NA
mis.dat
> mis.dat
Y X1 X2
1 -0.06845332 1 1
2 0.89169085 1 1
3 NA 1 2
4 1.88997449 1 2
5 0.95912879 2 1
6 -0.64049400 2 1
7 -0.23354948 2 2
8 -0.66869350 2 2
## Fit model -----------------------
model=nlme::lme(Y~1,random=~1|X1/X2,data=mis.dat,na.action=na.omit)
summary(model)
## Notie the names -------------------
fitted(model)
> fitted(model)
1/1 1/1 2/1 2/1 2/2 2/2 <NA>
0.67179438 0.67179438 0.67179439 0.02855517 0.02855517 0.02855517 0.02855517
attr(,"label")
[1] "Fitted values"
#model$coef$random
#resid(model)
注意拟合值的名称如何?不应该在第3个位置有1/2,并且在那之后的名字向右移动一个位置,从而消除了NA?
答案 0 :(得分:1)
你发现了一个小错误。看看nlme:::fitted.lme
看看会发生什么:
使用
从模型中提取拟合值object[["fitted"]]
fixed X1 X2
1 0.6014526 0.1686912 0.1686912
2 0.6014526 0.1686912 0.1686912
4 0.6014526 0.1686912 0.1686912
5 0.6014526 1.0342140 1.0342140
6 0.6014526 1.0342140 1.0342140
7 0.6014526 1.0342140 1.0342140
8 0.6014526 1.0342140 1.0342140
请注意,即使由于缺少y
- 值而忽略了观察3,也有8个拟合值,并且不应该存在。然后从
object[["groups"]]
X1 X2
1 1 1/1
2 1 1/1
3 1 1/2
4 2 2/1
5 2 2/1
6 2 2/2
7 2 2/2
注意如何只有7个名字。当使用match
时,NA会被引入。
最终问题出在lme
,它应该只返回7个拟合值。但是,我没有时间了解如何解决这个问题。随意report it。