Como executar o teste post-hoc no modelo lmer?

18

Este é o meu quadro de dados:

Group   <- c("G1","G1","G1","G1","G1","G1","G1","G1","G1","G1","G1","G1","G1","G1","G1","G2","G2","G2","G2","G2","G2","G2","G2","G2","G2","G2","G2","G2","G2","G2","G3","G3","G3","G3","G3","G3","G3","G3","G3","G3","G3","G3","G3","G3","G3")
Subject <- c("S1","S2","S3","S4","S5","S6","S7","S8","S9","S10","S11","S12","S13","S14","S15","S1","S2","S3","S4","S5","S6","S7","S8","S9","S10","S11","S12","S13","S14","S15","S1","S2","S3","S4","S5","S6","S7","S8","S9","S10","S11","S12","S13","S14","S15")
Value   <- c(9.832217741,13.62390117,13.19671612,14.68552076,9.26683366,11.67886655,14.65083473,12.20969772,11.58494621,13.58474896,12.49053635,10.28208078,12.21945867,12.58276212,15.42648969,9.466436017,11.46582655,10.78725485,10.66159358,10.86701127,12.97863424,12.85276916,8.672953949,10.44587257,13.62135205,13.64038394,12.45778874,8.655142642,10.65925259,13.18336949,11.96595556,13.5552118,11.8337142,14.01763101,11.37502161,14.14801305,13.21640866,9.141392359,11.65848845,14.20350364,14.1829714,11.26202565,11.98431285,13.77216009,11.57303893)

data <- data.frame(Group, Subject, Value)

Em seguida, corro um modelo de efeitos lineares mistos para comparar a diferença dos 3 grupos em "Valor", em que "Assunto" é o fator aleatório:

library(lme4)
library(lmerTest)
model <- lmer (Value~Group + (1|Subject), data = data)
summary(model)

Os resultados são:

Fixed effects:
            Estimate Std. Error       df t value Pr(>|t|)    
(Intercept) 12.48771    0.42892 31.54000  29.114   <2e-16 ***
GroupG2     -1.12666    0.46702 28.00000  -2.412   0.0226 *  
GroupG3      0.03828    0.46702 28.00000   0.082   0.9353    

No entanto, como comparar o Grupo2 com o Grupo3? Qual é a convenção no artigo acadêmico?

Ping Tang
fonte

Respostas:

16

Você poderia usar emmeans::emmeans()ou lmerTest::difflsmeans(), ou multcomp::glht().

Eu prefiro emmeans(anteriormente lsmeans).

library(emmeans)
emmeans(model, list(pairwise ~ Group), adjust = "tukey")

A nota difflsmeansnão pode corrigir várias comparações e usa o método Satterthwaite para calcular graus de liberdade como padrão, em vez do método Kenward-Roger usado por emmeans.

library(lmerTest)
difflsmeans(model, test.effs = "Group")

O multcomp::glht()método é descrito na outra resposta a esta pergunta, por Hack-R.

Além disso, você pode obter os valores de p ANOVA carregando lmerTeste usando anova.

library(lmerTest)
anova(model)

Só para esclarecer, você pretendia que o Valor fosse avaliado três vezes para cada sujeito, certo? Parece que o grupo está dentro dos assuntos, não entre assuntos.

Kayle Sawyer
fonte
1
Eu só quero acrescentar à resposta de Kayle Sawyer que o pacote lsmeans está sendo preterido em favor dos emmeans .
Downhiller
Observe que se você especificar a biblioteca, deverá usar lmerTest :: lmer (), não lme4 :: lmer () para anova () para mostrar os valores-p.
precisa
11

Depois de ajustar seu lmermodelo, você pode executar ANOVA, MANOVA e vários procedimentos de comparação no objeto de modelo, como este:

library(multcomp)
summary(glht(model, linfct = mcp(Group = "Tukey")), test = adjusted("holm"))
   Simultaneous Tests for General Linear Hypotheses

Multiple Comparisons of Means: Tukey Contrasts


Fit: lmer(formula = Value ~ Group + (1 | Subject), data = data)

Linear Hypotheses:
             Estimate Std. Error z value Pr(>|z|)  
G2 - G1 == 0 -1.12666    0.46702  -2.412   0.0378 *
G3 - G1 == 0  0.03828    0.46702   0.082   0.9347  
G3 - G2 == 0  1.16495    0.46702   2.494   0.0378 *
---
Signif. codes:  0***0.001**0.01*0.05 ‘.’ 0.1 ‘ ’ 1
(Adjusted p values reported -- holm method)

Quanto à convenção em trabalhos acadêmicos, isso varia muito por campo, periódico e assunto específico. Portanto, nesse caso, basta revisar artigos relacionados e ver o que eles fazem.

Hack-R
fonte
Obrigado. Mas qual ajuste foi realmente usado? Tukey ou azinheira? Por que ambos aparecem no teste post-hoc?
Ping Tang
@PingTang De nada. É a correção de Bonferroni-Holm da comparação múltipla de pares. Essa é apenas uma opção, é claro. Você também poderia fazer summary(glht(model, linfct = mcp(Group = "Tukey"))). Se você quiser ver o pleno descrições acadêmicas / estatísticos dos vários testes que podem ser realizados check-out as referências em ?glhte multicompde forma mais geral. Eu acho que Hsu 1996 seria o principal.
Hack-R
3
@PingTang, a mcpfunção, Group = Tukeysignifica justamente comparar todos os grupos em pares na variável "Group". Isso não significa um ajuste de Tukey.
Sal Mangiafico