我想lme4
用来拟合混合效应回归并multcomp
计算成对比较。我有一个包含多个连续和分类预测变量的复杂数据集,但我的问题可以使用内置ChickWeight
数据集作为示例来演示:
m <- lmer(weight ~ Time * Diet + (1 | Chick), data=ChickWeight, REML=F)
Time
是连续的并且Diet
是分类的(4 个级别)并且每个饮食有多个小鸡。所有小鸡开始时的体重大致相同,但它们的饮食(可能)会影响它们的生长速度,因此Diet
截距应该(或多或少)相同,但斜率可能不同。我可以得到这样的截距效果的成对比较Diet
:
summary(glht(m, linfct=mcp(Diet = "Tukey")))
而且,确实,它们并没有显着不同,但是我怎样才能对Time:Diet
效果进行类似的测试呢?只是将交互项放入mcp
会产生错误:
summary(glht(m, linfct=mcp('Time:Diet' = "Tukey")))
Error in summary(glht(m, linfct = mcp(`Time:Diet` = "Tukey"))) :
error in evaluating the argument 'object' in selecting a method for function
'summary': Error in mcp2matrix(model, linfct = linfct) :
Variable(s) ‘Time:Diet’ have been specified in ‘linfct’ but cannot be found in ‘model’!