我试图从结构方程模型 (SEM) 中找到方差膨胀因子 (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)
Run Code Online (Sandbox Code Playgroud)
这是我的数据示例:
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
Run Code Online (Sandbox Code Playgroud)
当我运行时vif(fit),出现错误:
Error: $ operator not defined for this S4 class
Run Code Online (Sandbox Code Playgroud)
我正在关注以下示例: http: //minato.sip21c.org/msb/man/VIF.html
VIF 的大多数示例和教程都是使用多元回归模型生成的。但如何获取 SEM 模型的 VIF?
sem()要估计使用包函数生成的模型的 VIF,lavaan您可以创建一个二元虚拟变量,将其与模型中的自变量进行回归,然后用于vif()估计方差膨胀因子。例子:
## 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)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2732 次 |
| 最近记录: |