我正在尝试从使用ez
软件包过渡到lme
重复测量方差分析(因为我希望能够在上使用自定义对比lme
)。
遵循此博客文章的建议,我能够同时使用和设置相同的模型aov
(ez
当需要时也是如此)lme
。然而,尽管在给出的例子中那个帖子的˚F -值不完美之间同意aov
和lme
(我检查,他们这样做),这是不是我的数据的情况。尽管F值相似,但它们并不相同。
aov
返回1.3399的f值,lme
返回1.36264。我愿意接受aov
结果为“正确” 的结果,因为这也是SPSS返回的结果(这对我的字段/主管很重要)。
问题:
如果有人能解释为什么存在这种差异以及如何使用我
lme
来提供可靠的结果,那就太好了。(如果它给出“正确的”结果,我也愿意使用lmer
而不是lme
用于这种类型的东西。但是,到目前为止,我还没有使用它。)解决此问题后,我想进行对比分析。尤其是我对合并因子的前两个级别(即
c("MP", "MT")
)并将其与因子的第三个级别(即)进行对比的兴趣"AC"
。此外,测试因子的第三级与第四级(即"AC"
vs"DA"
)。
数据:
tau.base <- structure(list(id = structure(c(1L, 2L, 3L, 4L, 5L, 6L, 7L, 8L,
9L, 10L, 11L, 12L, 13L, 14L, 15L, 16L, 17L, 18L, 19L, 20L, 21L,
22L, 1L, 2L, 3L, 4L, 5L, 6L, 7L, 8L, 9L, 10L, 11L, 12L, 13L,
14L, 15L, 16L, 17L, 18L, 19L, 20L, 21L, 22L, 1L, 2L, 3L, 4L,
5L, 6L, 7L, 8L, 9L, 10L, 11L, 12L, 13L, 14L, 15L, 16L, 17L, 18L,
19L, 20L, 21L, 22L, 1L, 2L, 3L, 4L, 5L, 6L, 7L, 8L, 9L, 10L,
11L, 12L, 13L, 14L, 15L, 16L, 17L, 18L, 19L, 20L, 21L, 22L), .Label = c("A18K",
"D21C", "F25E", "G25D", "H05M", "H07A", "H08H", "H25C", "H28E",
"H30D", "J10G", "J22J", "K20U", "M09M", "P20E", "P26G", "P28G",
"R03C", "U21S", "W08A", "W15V", "W18R"), class = "factor"), factor = structure(c(1L,
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L,
1L, 1L, 1L, 1L, 1L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L,
2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 3L, 3L, 3L, 3L, 3L,
3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L,
3L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L, 4L,
4L, 4L, 4L, 4L, 4L, 4L, 4L), .Label = c("MP", "MT", "AC", "DA"
), class = "factor"), value = c(0.9648092876, 0.2128662077, 1,
0.0607615485, 0.9912814024, 3.22e-08, 0.8073856412, 0.1465590332,
0.9981672618, 1, 1, 1, 0.9794401938, 0.6102546108, 0.428651501,
1, 0.1710644881, 1, 0.7639763913, 1, 0.5298989196, 1, 1, 0.7162733447,
0.7871177434, 1, 1, 1, 0.8560509327, 0.3096989662, 1, 8.51e-08,
0.3278862311, 0.0953598576, 1, 1.38e-08, 1.07e-08, 0.545290432,
0.1305621416, 2.61e-08, 1, 0.9834051136, 0.8044114935, 0.7938839461,
0.9910112678, 2.58e-08, 0.5762677121, 0.4750002288, 1e-08, 0.8584252623,
1, 1, 0.6020385797, 8.51e-08, 0.7964935271, 0.2238374288, 0.263377904,
1, 1.07e-08, 0.3160751898, 5.8e-08, 0.3460325565, 0.6842217296,
1.01e-08, 0.9438301877, 0.5578367224, 2.18e-08, 1, 0.9161424562,
0.2924856039, 1e-08, 0.8672987992, 0.9266688748, 0.8356425464,
0.9988463913, 0.2960361777, 0.0285680426, 0.0969063841, 0.6947998266,
0.0138254805, 1, 0.3494775301, 1, 2.61e-08, 1.52e-08, 0.5393467752,
1, 0.9069223275)), .Names = c("id", "factor", "value"), class = "data.frame", row.names = c(1L,
6L, 10L, 13L, 16L, 17L, 18L, 22L, 23L, 24L, 27L, 29L, 31L, 33L,
42L, 43L, 44L, 45L, 54L, 56L, 58L, 61L, 64L, 69L, 73L, 76L, 79L,
80L, 81L, 85L, 86L, 87L, 90L, 92L, 94L, 96L, 105L, 106L, 107L,
108L, 117L, 119L, 121L, 124L, 127L, 132L, 136L, 139L, 142L, 143L,
144L, 148L, 149L, 150L, 153L, 155L, 157L, 159L, 168L, 169L, 170L,
171L, 180L, 182L, 184L, 187L, 190L, 195L, 199L, 202L, 205L, 206L,
207L, 211L, 212L, 213L, 216L, 218L, 220L, 222L, 231L, 232L, 233L,
234L, 243L, 245L, 247L, 250L))
和代码:
require(nlme)
summary(aov(value ~ factor+Error(id/factor), data = tau.base))
anova(lme(value ~ factor, data = tau.base, random = ~1|id))
lme
标准教科书ANOVA 的结果有所不同(由给出aov
,这就是我所需要的),这对我来说不是一个选择。在我的论文中,我要报告方差分析,而不是方差分析。有趣的是,Venables&Ripley(2002,p。285)表明,两种方法都得出相同的估计值。但是F值的差异使我感到难受。此外,Anova()
(from car
)仅返回lme
对象的Chi²值。因此,对我来说,我的第一个问题尚未得到解答。
lme
;但对比,glht
适用于lm
配合过,而不仅仅是lme
千篇一律。(另外,lme
结果也是标准教科书的结果。)
lm
重复测量分析。只有aov
可以处理重复的措施,但是会返回一个类的对象,aovlist
不幸的是它没有处理glht
。
lm
使用剩余误差作为所有效果的误差项;当某些效果应使用不同的误差项aov
时(或使用来自的结果lm
手动计算F统计量)是必要的。在您的示例中,的误差项factor
是id:factor
交互作用,它是加法模型中的残留误差项。将您的结果与进行比较anova(lm(value~factor+id))
。