r - lmer 错误 : grouping factor must be < number of observations

标签 r lme4 mixed-models nlme

我正在尝试对某些数据运行混合效应模型,但在其中一个固定效应上挣扎,我认为主要是因为它是一个因素?!

样本数据:

data4<-structure(list(code = structure(1:10, .Label = c("10888", "10889", 
"10890", "10891", "10892", "10893", "10894", "10896", "10897", 
"10898", "10899", "10900", "10901", "10902", "10903", "10904", 
"10905", "10906", "10907", "10908", "10909", "10910", "10914", 
"10916", "10917", "10919", "10920", "10922", "10923", "10924", 
"10925", "10927"), class = "factor"), speed = c(0.0296315046039244, 
0.0366986630049636, 0.0294297725505692, 0.048316183511095, 0.0294275666501456, 
0.199924957584131, 0.0798850288176711, 0.0445886457047146, 0.0285993712316451, 
0.0715158276875623), meanflow = c(0.657410742496051, 0.608271363339857, 
0.663241108786611, 0.538259450171821, 0.666299529534762, 0.507156583629893, 
0.762448863636364, 37.6559178370787, 50.8557196935557, 31.6601587837838
), length = c(136, 157, 132, 140, 135, 134, 144, 149, 139, 165
), river = structure(c(2L, 2L, 2L, 2L, 2L, 2L, 2L, 1L, 1L, 1L
), .Label = c("c", "f"), class = "factor")), .Names = c("code", 
"speed", "meanflow", "length", "river"), row.names = c(2L, 4L, 
6L, 8L, 10L, 12L, 14L, 16L, 18L, 20L), class = "data.frame")

我的模型是这样的:
model1<-lmer(speed ~ river + length +(1|meanflow)+(1|code), data4)

当运行返回错误消息时:
Error in checkNlevels(reTrms$flist, n = n, control) : 
number of levels of each grouping factor must be < number of observations

在网上搜索后,我有 found one response

但对于我一生不明白的问题的回答!

最佳答案

你在这里有两个问题:

  • 看起来您对 code 的每个值都有一个观察结果.这意味着您无法同时估计残差方差(内置于 lmer 和更一般的线性混合模型)和中间- code方差——这两个参数都将尝试估计相同的方差分量,以及 var(residual) 的任意组合和 var(code)加起来相同的值将代表对数据的同样良好的拟合。
  • 对于 meanflow 的每个值,您也有一个观察值;这是因为 meanflow是一个连续变量,它通常不是你想在模型中用作分组变量的东西。我不确定你想用这个词来捕捉什么。

  • 如果您坚持使用 lmerControl,实际上可以适合这些模型。绕过检查,但您不一定会得到合理的结果!
    model2 <- lmer(speed ~ river + length +(1|meanflow)+(1|code), data4,
        control=lmerControl(check.nobs.vs.nlev = "ignore",
         check.nobs.vs.rankZ = "ignore",
         check.nobs.vs.nRE="ignore"))
    

    这里的方差大约被分成了三等分:
     VarCorr(model2)
     ##  Groups   Name        Std.Dev.
     ##  meanflow (Intercept) 0.035354
     ##  code     (Intercept) 0.032898
     ##  Residual             0.033590
    

    如果我们只使用一种(仍然不合适的)随机效应,
    model0 <- lmer(speed ~ river + length +(1|meanflow), data4,
        control=lmerControl(check.nobs.vs.nlev = "ignore",
         check.nobs.vs.rankZ = "ignore",
         check.nobs.vs.nRE="ignore"))
    

    现在方差被精确地分成两半:
    VarCorr(model0)
    ##  Groups   Name        Std.Dev.
    ##  meanflow (Intercept) 0.041596
    ##  Residual             0.041596
    

    关于r - lmer 错误 : grouping factor must be < number of observations,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19713228/

    相关文章:

    r - 在 R 中组合多个模型对子集数据的预测的简单方法

    r - 如何绘制 lme 模型的各个轨迹

    r - 如何在混合效应模型中获得系数及其置信区间?

    python - 在 Python 中运行 lmer(线性混合效应回归)

    r - 箭头 Parquet 分区,R中同一目录结构中的多个数据集

    r - `caret` 中的训练错误率

    r - 合并返回大小为 x^2 的矩阵

    r - 从 lme4 mer 模型对象中提取随机效应方差

    r - 使用 'mice' 调整 R 平方

    r - 如何在具有多个预测变量的混合模型中绘制随机截距和斜率?