首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用于回归模型的具有多个列表和函数的lapply

用于回归模型的具有多个列表和函数的lapply
EN

Stack Overflow用户
提问于 2020-12-15 04:00:37
回答 1查看 139关注 0票数 2

我想使用lapply同时运行四个多级模型(使用lmer)。

使用带有一个因变量和一列自变量的lm()的一个简单示例如下:

代码语言:javascript
复制
data(mtcars)
varlist <- names(mtcars)[3:6]

models <- lapply(varlist, function(x) {
  lm(substitute(mpg ~ i, list(i = as.name(x))), data = mtcars)
})

如何将其扩展为运行四个lmer()模型,每个模型都有不同的因变量和不同的自变量列表?对于所有四个模型,这两个级别将保持不变。四个(伪造的)示例模型是:

代码语言:javascript
复制
data(mtcars)
library(lme4)

model1 <- lmer(mpg ~ cyl + disp + hp + (1 | am) +  (1 | vs), data = mtcars)

model2 <- lmer(cyl ~ mpg + disp + qsec + (1 | am) +  (1 | vs), data = mtcars)

model3 <- lmer(disp ~ mpg + cyl + carb + (1 | am) +  (1 | vs), data = mtcars)

model4 <- lmer(qsec ~ mpg + cyl + drat + (1 | am) +  (1 | vs), data = mtcars)

有什么想法吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-12-15 04:09:04

我们可以有一个由依赖变量(或vector变量)和自变量组成的list,并将其传递给Map以创建formula并应用lmer。在这里,list的单位元素是表示自变量的vector,表示因变量的单个元素。

代码语言:javascript
复制
library(lme4)
indep_var_list <- list(c("cyl", "disp", "hp"),
                   c("mpg", "disp", "qsec"),
                    c("mpg", "cyl", "carb"),
                    c("mpg", "cyl", "drat"))

dep_vars <- c("mpg", "cyl", "disp", "qsec")

out <- Map(function(x, y) {

       fmla <-  as.formula(paste(y, "~ ", paste(x, collapse= " + ") ,
                            " + (1 | am) + (1 | vs)"))
       model <- lmer(fmla, data = mtcars)
       model
       }, indep_var_list, dep_vars)

-output

代码语言:javascript
复制
[1]]
Linear mixed model fit by REML ['lmerMod']
Formula: mpg ~ cyl + disp + hp + (1 | am) + (1 | vs)
   Data: mtcars
REML criterion at convergence: 169.5913
Random effects:
 Groups   Name        Std.Dev.
 am       (Intercept) 2.209   
 vs       (Intercept) 0.000   
 Residual             2.831   
Number of obs: 32, groups:  am, 2; vs, 2
Fixed Effects:
(Intercept)          cyl         disp           hp  
   32.55270     -0.90447     -0.00972     -0.02971  
convergence code 0; 0 optimizer warnings; 1 lme4 warnings 

[[2]]
Linear mixed model fit by REML ['lmerMod']
Formula: cyl ~ mpg + disp + qsec + (1 | am) + (1 | vs)
   Data: mtcars
REML criterion at convergence: 78.0586
Random effects:
 Groups   Name        Std.Dev.
 am       (Intercept) 0.5773  
 vs       (Intercept) 0.4491  
 Residual             0.5743  
Number of obs: 32, groups:  am, 2; vs, 2
Fixed Effects:
(Intercept)          mpg         disp         qsec  
  10.592032    -0.045832     0.006052    -0.279176  

[[3]]
Linear mixed model fit by REML ['lmerMod']
Formula: disp ~ mpg + cyl + carb + (1 | am) + (1 | vs)
   Data: mtcars
REML criterion at convergence: 316.1521
Random effects:
 Groups   Name        Std.Dev.
 am       (Intercept)  0.00   
 vs       (Intercept)  0.00   
 Residual             49.83   
Number of obs: 32, groups:  am, 2; vs, 2
Fixed Effects:
(Intercept)          mpg          cyl         carb  
     112.57        -7.15        47.90       -12.30  
convergence code 0; 0 optimizer warnings; 1 lme4 warnings 

[[4]]
Linear mixed model fit by REML ['lmerMod']
Formula: qsec ~ mpg + cyl + drat + (1 | am) + (1 | vs)
   Data: mtcars
REML criterion at convergence: 92.9165
Random effects:
 Groups   Name        Std.Dev.
 am       (Intercept) 1.4979  
 vs       (Intercept) 0.6131  
 Residual             0.9008  
Number of obs: 32, groups:  am, 2; vs, 2
Fixed Effects:
(Intercept)          mpg          cyl         drat  
    24.5519       0.0288      -0.7956      -0.6974  
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65295644

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档