了解r lme4中混合模型的警告消息

phi*_*her 5 r lme4 mixed-models

我已经在lme4包中建立并运行了混合效应逻辑回归模型,以估计不同位置(细胞/栖息地)中鱼类占用的概率.数据框由对68条单独鱼类的1,207,140次观测组成.对于每个人(每天约1年),它描述了每个唯一位置的发生次数相对于所有位置的总发生次数.

这是基本模型:

    m.base = glmer(cbind(N,t.move-N) ~ jdate + snSurface.Area + Restoration..P.A. +    
    Release.Location+ Sex + (1|Station) + (0 + jdate|ID), data=allfishdat, family=binomial)
where N=# unique positions, t.move=total positions, jdate=julian date, Station=locations, ID=fish ID
Run Code Online (Sandbox Code Playgroud)

我收到以下警告消息:

Warning messages:
1: In checkConv(attr(opt, "derivs"), opt$par, ctrl = control$checkConv,  :
                Model failed to converge with max|grad| = 3349.26 (tol = 0.001)
2: In if (resHess$code != 0) { :
 the condition has length > 1 and only the first element will be used
3: In checkConv(attr(opt, "derivs"), opt$par, ctrl = control$checkConv,  :
 Model is nearly unidentifiable: very large eigenvalue
 - Rescale variables?;Model is nearly unidentifiable: large eigenvalue ratio
 - Rescale variables?
Run Code Online (Sandbox Code Playgroud)

我做了一些搜索,试图了解这些消息的含义及其对模型的影响,但还没有理解警告.

It *_*res 2

如果第一个问题与 R 需要经过更多迭代才能达到收敛有关,那么下面的代码可能会有所帮助。将“20000”替换为对您的特定模型有意义的最大迭代数。(请注意,您的原始模型代码已在末尾修改为包含“control = my.control”。)

my.control=lmerControl(optCtrl=list(maxfun=20000); my.control

m.base = glmer(cbind(N,t.move-N) ~ jdate + snSurface.Area + Restoration..P.A. +  Release.Location+ Sex + (1|Station) + (0 + jdate|ID), data=allfishdat, family=binomial, control = my.control)
Run Code Online (Sandbox Code Playgroud)

使用以下命令查看当前的 lmeControls 也可能对您有用:

str(lmerControl())
Run Code Online (Sandbox Code Playgroud)

此外,之前的答案可能对您有帮助: 增加新版本 lmer 的迭代?

  • 我在这里没有看到任何有关迭代不足的警告的证据。例如,`库(lme4);fm1 <- lmer(Reaction ~ Days + (Days | subject), sleepstudy, control=lmerControl(optCtrl=list(maxfun=5)))` 明确指出“超出了函数评估的最大数量”,我在上面没有看到。 (4认同)