2

我正在尝试使用 R 的 lavaan 包进行潜在变量分析。但是,我收到以下错误消息:

警告消息:1:在 lav_data_full(data = data, group = group, cluster = cluster, :lavaan 警告:一些观察到的方差(至少)是其他方差的 1000 倍;使用 varTable(fit) 进行调查 2:在lav_model_vcov(lavmodel = lavmodel, lavsamplestats = lavsamplestats, :lavaan 警告:无法计算标准误差!lavaan 注意:这可能是模型未识别的症状。3:在 lav_object_post_check(object) 中:lavaan 警告:一些估计的 ov 方差为负 4:在 lav_object_post_check(object) 中:
lavaan 警告:一些估计的 lv 方差为负

我的模型结构如下:

在此处输入图像描述

model <- "
        # regressions
        eigenvector.frug ~ Size + Morphology

        # latent variables
        Size =~ Mass + Forearm
        Morphology =~ LMT + BUM

        # covariances and variances
        Mass ~~ Forearm
        LMT ~~ BUM
        Mass ~~ Mass
        Forearm ~~ Forearm
        LMT ~~ LMT
        BUM ~~ BUM
        "

我正在运行的代码是:

fit <- sem(model, data=data,
           orthogonal=TRUE)

我得到以下摘要:

lavaan (0.5-23.1097) converged normally after 141 iterations

  Number of observations                            41

  Estimator                                         ML
  Minimum Function Test Statistic               88.676
  Degrees of freedom                                 2
  P-value (Chi-square)                           0.000

Parameter Estimates:

  Information                                 Expected
  Standard Errors                             Standard

Latent Variables:
                   Estimate  Std.Err  z-value  P(>|z|)
  Size =~                                             
    Mass              1.000                           
    Forearm           4.941       NA                  
  Morphology =~                                       
    LMT               1.000                           
    BUM               1.349       NA                  

Regressions:
                     Estimate  Std.Err  z-value  P(>|z|)
  eigenvector.frug ~                                    
    Size               -0.000       NA                  
    Morphology         -2.774       NA                  

Covariances:
                   Estimate  Std.Err  z-value  P(>|z|)
 .Mass ~~                                             
   .Forearm          59.805       NA                  
 .LMT ~~                                              
   .BUM               2.926       NA                  
  Size ~~                                             
    Morphology        0.000                           

Variances:
                   Estimate  Std.Err  z-value  P(>|z|)
   .Mass            272.184       NA                  
   .Forearm        -518.752       NA                  
   .LMT               3.283       NA                  
   .BUM               5.871       NA                  
   .eigenvectr.frg    0.344       NA                  
    Size             26.894       NA                  
    Morphology       -0.038       NA    

由于数据在不同的尺度上有所不同,我尝试使用 scale 函数对所有变量进行归一化并再次运行模型。

data2 = scale(data)

然后我收到以下错误消息:

警告消息:在 lav_model_vcov(lavmodel = lavmodel, lavsamplestats = lavsamplestats, :lavaan 警告:无法计算标准错误!lavaan 注意:这可能是模型未识别的症状。

以及以下摘要:

lavaan (0.5-23.1097) converged normally after  69 iterations

  Number of observations                            41

  Estimator                                         ML
  Minimum Function Test Statistic               87.973
  Degrees of freedom                                 2
  P-value (Chi-square)                           0.000

Parameter Estimates:

  Information                                 Expected
  Standard Errors                             Standard

Latent Variables:
                   Estimate  Std.Err  z-value  P(>|z|)
  Size =~                                             
    Mass              1.000                           
    Forearm           0.940       NA                  
  Morphology =~                                       
    LMT               1.000                           
    BUM               0.181       NA                  

Regressions:
                     Estimate  Std.Err  z-value  P(>|z|)
  eigenvector.frug ~                                    
    Size                0.536       NA                  
    Morphology         -0.042       NA                  

Covariances:
                   Estimate  Std.Err  z-value  P(>|z|)
 .Mass ~~                                             
   .Forearm           0.389       NA                  
 .LMT ~~                                              
   .BUM               0.541       NA                  
  Size ~~                                             
    Morphology        0.000                           

Variances:
                   Estimate  Std.Err  z-value  P(>|z|)
   .Mass              0.404       NA                  
   .Forearm           0.471       NA                  
   .LMT               0.394       NA                  
   .BUM               0.957       NA                  
   .eigenvectr.frg    0.819       NA                  
    Size              0.571       NA                  
    Morphology        0.581       NA         

你能帮我找出问题所在吗?非常感谢。

4

1 回答 1

5

我认为问题在于同一构造上的指标之间的相关残差。您正试图以冗余的方式解释同一构造上的指标之间的关系。

例如,潜在结构“大小”可以解释指标变量“质量”和“前臂”之间的关系。那里的残差将被概念化为指标中由潜在构造解释的方差。

但是你要做的是让残差相关,它模拟了“质量”和“前臂”之间的共享方差,这不是由潜在因素解释的。

问题在于您的潜在构造仅由这两个变量组成。您基本上是在说lavaan:“将这两个指标之间的方差建模为潜在构造……不用等待!还将相同的方差建模为残差!” 所以lavaan基本上是在告诉你,“那没有意义,我不能那样做!” 我会尝试这段代码:

model2 <- "
        # regressions
        eigenvector.frug ~ Size + Morphology

        # latent variables
        Size =~ Mass + Forearm
        Morphology =~ LMT + BUM

        # covariances and variances
        Mass ~~ Mass
        Forearm ~~ Forearm
        LMT ~~ LMT
        BUM ~~ BUM
        "

此代码隐式地将残差协方差固定为零。

您可能会遇到的另一个问题是每个子模型都没有被识别。对于每个潜在变量,您尝试从 2 个未识别的指标估计潜在构造(即,您有 3 个与方差相关的元素要使用,但您正在估计 2 个残差、一个负载和一个潜在方差) . 为了解决这个问题,您可以将每个潜在因子的负载限制为彼此相等。我们可以通过为因子载荷分配相同的标签来做到这一点(这里,每个因子的“a”和“b”)。

model3 <- "
        # regressions
        eigenvector.frug ~ Size + Morphology

        # latent variables
        Size =~ a*Mass + a*Forearm
        Morphology =~ b*LMT + b*BUM

        # covariances and variances
        Mass ~~ Mass
        Forearm ~~ Forearm
        LMT ~~ LMT
        BUM ~~ BUM
        "
于 2017-05-22T14:34:41.497 回答