Learn R Programming

semTools

Useful tools for structural equation modeling.

This is an R package whose primary purpose is to extend the functionality of the R package lavaan. There are several suites of tools in the package, which correspond to the same theme. To browse these suites, open the help page at the Console:

?semTools::`semTools-package`

Additional tools are available to do not require users to rely on any R packages for SEM (e.g., lavaan, OpenMx, or sem), as long as their other software provides the information they need. Examples:

  • monteCarloMed() to calculate Monte Carlo confidence intervals for functions of parameters, such as indirect effects in mediation models
  • calculate.D2() to pool z or chi-squared statistics across multiple imputations of missing data
  • indProd() for creating product indicators of latent interactions
  • SSpower() provides analytically derived power estimates for SEMs
  • tukeySEM() for Tukey's WSD post-hoc test of mean-differences under unequal variance and sample size
  • bsBootMiss() to transform incomplete data to be consistent with the null-hypothesized model, appropriate for model-based (a.k.a. "Bollen--Stine") boostrapping

All users of R (or SEM) are invited to submit functions or ideas for functions by contacting the maintainer, Terrence Jorgensen (TJorgensen314 at gmail dot com). Contributors are encouraged to use Roxygen comments to document their contributed code, which is consistent with the rest of semTools. Read the vignette from the roxygen2 package for details:

vignette("rd", package = "roxygen2")

Copy Link

Version

Install

install.packages('semTools')

Monthly Downloads

19,104

Version

0.5-7

License

GPL (>= 2)

Issues

Pull Requests

Stars

Forks

Maintainer

Terry Jorgensen

Last Published

March 13th, 2025

Functions in semTools (0.5-7)

clipboard

Copy or save the result of lavaan or FitDiff objects into a clipboard or a file
combinequark

Combine the results from the quark function
dat2way

Simulated Dataset to Demonstrate Two-way Latent Interaction
dat3way

Simulated Dataset to Demonstrate Three-way Latent Interaction
calculate.D2-deprecated

Calculate the "D2" statistic
findRMSEAsamplesizenested

Find sample size given a power in nested model comparison
chisqSmallN

Small-N correction for \(chi^2\) test statistic
goricaSEM

Wrapper for goric.lavaan() from the restriktor package
discriminantValidity

Calculate discriminant validity statistics
kd

Generate data via the Kaiser-Dickman (1962) algorithm.
datCat

Simulated Data set to Demonstrate Categorical Measurement Invariance
compRelSEM

Composite Reliability using SEM
compareFit

Build an object summarizing fit indices across multiple models
efa.ekc

Empirical Kaiser criterion
efaUnrotate-deprecated

Analyze Unrotated Exploratory Factor Analysis Model
htmt

Assessing Discriminant Validity using Heterotrait--Monotrait Ratio
exLong

Simulated Data set to Demonstrate Longitudinal Measurement Invariance
fmi

Fraction of Missing Information.
loadingFromAlpha

Find standardized factor loading from coefficient alpha
lavTestLRT.mi-deprecated

Likelihood Ratio Test for Multiple Imputations
lavTestScore.mi-deprecated

Score Test for Multiple Imputations
longInvariance-deprecated

Measurement Invariance Tests Within Person
lavTestWald.mi-deprecated

Wald Test for Multiple Imputations
lavaan2emmeans

emmeans Support Functions for lavaan Models
findRMSEApower

Find the statistical power based on population RMSEA
findRMSEApowernested

Find power given a sample size in nested model comparison
indProd

Make products of indicators using no centering, mean centering, double-mean centering, or residual centering
findRMSEAsamplesize

Find the minimum sample size for a given statistical power based on population RMSEA
imposeStart

Specify starting values from a lavaan output
lrv2ord

Calculate Population Moments for Ordinal Data Treated as Numeric
mardiaKurtosis

Finding Mardia's multivariate kurtosis
mardiaSkew

Finding Mardia's multivariate skewness
maximalRelia

Calculate maximal reliability
kurtosis

Finding excessive kurtosis
measurementInvarianceCat-deprecated

Measurement Invariance Tests for Categorical Items
measurementInvariance-deprecated

Measurement Invariance Tests
miPowerFit

Modification indices and their power approach for model fit evaluation
modindices.mi-deprecated

Modification Indices for Multiple Imputations
measEq.syntax-class

Class for Representing a Measurement-Equivalence Model
measEq.syntax

Syntax for measurement equivalence
plausibleValues

Plausible-Values Imputation of Factor Scores Estimated from a lavaan Model
nullRMSEA

Calculate the RMSEA of the null model
permuteMeasEq-class

Class for the Results of Permutation Randomization Tests of Measurement Equivalence and DIF
mvrnonnorm

Generate Non-normal Data using Vale and Maurelli (1983) method
moreFitIndices

Calculate more fit indices
partialInvariance

Partial Measurement Invariance Testing Across Groups
parcelAllocation

Random Allocation of Items to Parcels in a Structural Equation Model
monteCarloCI

Monte Carlo Confidence Intervals to Test Functions of Parameter Estimates
net

Nesting and Equivalence Testing
permuteMeasEq

Permutation Randomization Tests of Measurement Equivalence and Differential Item Functioning (DIF)
plotRMSEApowernested

Plot power of nested model RMSEA
probe3WayRC

Probing three-way interaction on the residual-centered latent interaction
probe2WayMC

Probing two-way interaction on the no-centered or mean-centered latent interaction
quark

Quark
poolMAlloc

Combine sampling variability with parcel-allocation variability by pooling results across M parcel-allocations
plotRMSEAdist

Plot the sampling distributions of RMSEA
plotProbe

Plot a latent interaction
plotRMSEApower

Plot power curves for RMSEA
probe2WayRC

Probing two-way interaction on the residual-centered latent interaction
probe3WayMC

Probing three-way interaction on the no-centered or mean-centered latent interaction
singleParamTest

Single Parameter Test Divided from Nested Model Comparison
residualCovariate

Residual-center all target indicators by covariates
semTools-deprecated

Deprecated functions in package semTools.
runMI-deprecated

Fit a lavaan Model to Multiple Imputed Data Sets
rotate-deprecated

Implement orthogonal or oblique rotation
semTools

semTools: Useful Tools for Structural Equation Modeling
skew

Finding skewness
reliabilityL2-deprecated

Calculate the reliability values of a second-order factor
reliability-deprecated

Composite Reliability using SEM
simParcel

Simulated Data set to Demonstrate Random Allocations of Parcels
tukeySEM

Tukey's WSD post-hoc test of means for unequal variance and sample size
twostage-class

Class for the Results of 2-Stage Maximum Likelihood (TSML) Estimation for Missing Data
twostage

Fit a lavaan model using 2-Stage Maximum Likelihood (TSML) estimation for missing data.
splitSample

Randomly Split a Data Set into Halves
bsBootMiss

Bollen-Stine Bootstrap with the Existence of Missing Data
Net-class

Class For the Result of Nesting and Equivalence Testing
EFA-class

Class For Rotated Results from EFA
BootMiss-class

Class For the Results of Bollen-Stine Bootstrap with Incomplete Data
FitDiff-class

Class For Representing A Template of Model Fit Comparisons
auxiliary

Implement Saturated Correlates with FIML
SSpower

Power for model parameters
AVE

Calculate average variance extracted
PAVranking

Parcel-Allocation Variability in Model Ranking
OLDlavaan.mi-class

Class for a lavaan Model Fitted to Multiple Imputations