估计 SEM 模型 (lavaan) 的方差 Inflation 因子 (VIF)

Estimating the Variance Inflation Factors (VIF) of a SEM model (lavaan)

我正在尝试从结构方程模型 (SEM) 中找到方差 inflation 因子 (VIF)。我的模型是:

# load the data
library(readxl)
Log_And_SurveyResult <- read_excel("C:/Users/Aakash/Desktop/analysis/Today/Mot-Log.xlsx")

# load lavaan
library(lavaan)

#scale the variables
Log_And_SurveyResult$Time <-
scale(Log_And_SurveyResult$TotalActivity)

model <-
Ct =~ CT1 + CT2 + CT3
R =~ R1 + R2 + R3
B =~ B1 + B2 + B3
UserActivity =~ Time + TotalActivity

fit <- sem(model,data = Log_And_SurveyResult, std.lv = TRUE)
summary(fit, standardized=T)

这是我的数据示例:

Time,TotalActivity,CT1,CT2,CT3,R1,R2,R3,B1,B2,B3
-0.4923798,-0.09991485,4,4,4,3,3,3,3,3,2
-1.0519708,-1.12771752,3,2,2,2,2,3,4,2,3
-0.5330384,-0.06320762,4,4,5,5,4,4,4,4,4
-1.0134522,-0.67805386,5,4,4,5,5,4,4,5,5
-1.1568273,-1.18277838,4,3,4,3,2,3,3,4,4
-0.8561675,-0.12744528,3,4,4,4,4,3,3,3,3

当我 运行 vif(fit) 时,我得到错误:

Error: $ operator not defined for this S4 class

我正在遵循以下示例:http://minato.sip21c.org/msb/man/VIF.html

关于 VIF 的大部分示例和教程都是使用多元回归模型生成的。但是我怎样才能为我的 SEM 模型获取 VIF?

编辑(与OP聊天并查看他的数据后):

OP 想要估计使用包 lavaansem() 函数生成的模型的 VIF。

我提出的解决方案是创建一个二元虚拟变量,根据模型中的自变量对其进行回归,然后使用 vif() 估计方差 Inflation 因子。示例:

## Create random binary variable
Log_And_SurveyResult$randomvar <- rbinom(nrow(Log_And_SurveyResult), 1, 0.5)

## Model and VIF
Model <- lm(randomvar ~ CT1 + CT2 + CT3, data=Log_And_SurveyResult)
vif(Model)