| Title: | Bootstrapping Helpers for Structural Equation Modelling | 
| Version: | 0.1.1 | 
| Description: | A collection of helper functions for forming bootstrapping confidence intervals and examining bootstrap estimates in structural equation modelling. Currently supports models fitted by the 'lavaan' package by Rosseel (2012) <doi:10.18637/jss.v048.i02>. | 
| License: | GPL (≥ 3) | 
| Encoding: | UTF-8 | 
| RoxygenNote: | 7.3.2 | 
| Suggests: | knitr, rmarkdown, testthat (≥ 3.0.0) | 
| Config/testthat/edition: | 3 | 
| Config/testthat/parallel: | true | 
| VignetteBuilder: | knitr | 
| Imports: | boot, lavaan, psych, lavaan.printer | 
| URL: | https://Yangzhen1999.github.io/semboottools/ | 
| BugReports: | https://github.com/Yangzhen1999/semboottools/issues | 
| NeedsCompilation: | no | 
| Packaged: | 2025-09-17 08:48:09 UTC; Administrator | 
| Author: | Wendie Yang | 
| Maintainer: | Wendie Yang <1581075494q@gmail.com> | 
| Repository: | CRAN | 
| Date/Publication: | 2025-09-17 09:10:01 UTC | 
semboottools: Bootstrapping Helpers for Structural Equation Modelling
Description
A collection of helper functions for forming bootstrapping confidence intervals and examining bootstrap estimates in structural equation modelling. Currently supports models fitted by the 'lavaan' package by Rosseel (2012) doi: 10.18637/jss.v048.i02.
Author(s)
Maintainer: Wendie Yang 1581075494q@gmail.com (ORCID)
Authors:
- Shu Fai Cheung shufai.cheung@gmail.com (ORCID) 
See Also
Useful links:
- Report bugs at https://github.com/Yangzhen1999/semboottools/issues 
Diagnostic Plots of Bootstrap Estimates in 'lavaan'
Description
Plots for examining the
distribution of bootstrap estimates
in a model fitted by lavaan.
Usage
hist_qq_boot(
  object,
  param,
  standardized = NULL,
  nclass = NULL,
  hist_color = "#5DADE233",
  hist_linewidth = 1.5,
  hist_border_color = "#1B4F72",
  density_line_type = "solid",
  density_line_color = "#8B0000CC",
  density_line_linewidth = 2,
  est_line_color = "#154360",
  est_line_type = "dashed",
  est_line_linewidth = 2,
  qq_dot_pch = 21,
  qq_dot_color = "#1B4F72",
  qq_dot_fill = "#5DADE233",
  qq_dot_size = 1.3,
  qq_line_color = "#8B0000CC",
  qq_line_linewidth = 2.1,
  qq_line_linetype = "solid"
)
scatter_boot(
  object,
  params,
  standardized = NULL,
  main = "Bootstrap Estimates",
  ...
)
Arguments
| object | Either
a  | 
| param | String. The name of
the parameter to be plotted, which
should be the name as appeared in
a call to  | 
| standardized | Logical. Whether
the estimates from the standardized
solution are to be plotted. Default
is  | 
| nclass | The number of breaks.
This argument will be passed to
 | 
| hist_color | String. The color of the
bars in the histogram. It will be
passed to  | 
| hist_linewidth | The width of the borders of the bars in the histogram. Default is 1.5. | 
| hist_border_color | String.
The color of the borders (outline) of the bars
in the histogram. It will be passed to  | 
| density_line_type | String.
The type of the line of the density
curve in the histogram. It will be
passed to  | 
| density_line_color | String.
The color of the density curve in
the histogram. It will be
passed to  | 
| density_line_linewidth | The width
of the density curve in the histogram.
It will be
passed to  | 
| est_line_color | String. The
color of the vertical line showing
the point estimate in the histogram.
It will be
passed to  | 
| est_line_type | String. The
type of the vertical line in the
histogram showing the point estimate
of the parameter. It will be
passed to  | 
| est_line_linewidth | The width
of the vertical line showing the
point estimate in the histogram.
It will be
passed to  | 
| qq_dot_pch | Numeric. The shape
of the points in the normal QQ-plot.
It will be
passed to  | 
| qq_dot_color | String. The color
of the points in the normal QQ-plot.
It will be
passed to  | 
| qq_dot_fill | String.
The fill color of the points in the normal QQ-plot.
Only applicable when  | 
| qq_dot_size | The size of the
points in the normal QQ-plot.
It will be
passed to  | 
| qq_line_color | String. The color
of the diagonal line to be drawn in
the normal QQ-plot.
It will be
passed to  | 
| qq_line_linewidth | The width
of the diagonal line to be drawn in
the normal QQ-plot.
It will be
passed to  | 
| qq_line_linetype | The type of
the diagonal line to be drawn in the
normal QQ-plot. Default is  | 
| params | The vector of the names of
the parameters to be plotted, which
should be the names as appeared in
a call to  | 
| main | The title of the
scatterplot matrix. Default is
 | 
| ... | Arguments to be passed to
 | 
Details
Rousselet, Pernet, and Wilcox (2021)
argued that when using bootstrapping,
it is necessary to examine the distribution
of bootstrap estimates. This can be
done when boot::boot() is used
because it has a plot method for
its output. This cannot be easily
done in model fitted by lavaan::lavaan(),
such as lavaan::sem() and
lavaan::cfa().
The function hist_qq_boot() is used for
plotting the distribution of bootstrap
estimates for a model fitted by
lavaan in a format similar to that
of the output of boot::boot(), with
a histogram on the left and a normal
QQ-plot on the right.
For free parameters in a model
(unstandardized), it can be called
directly on the output of lavaan
and retrieves the stored estimates.
For estimates of user-defined parameters,
call store_boot() first to compute
and store the bootstrap estimates
first.
For estimates in standardized solution,
for both free and user-defined
parameters, call store_boot()
first to compute and store the bootstrap
estimates in the standardized solution.
It can also
plot bootstrap estimates in the output
of standardizedSolution_boot()
or parameterEstimates_boot().
The function scatter_boot() is
used to generate a scatterplot
matrix of the bootstrap estimates of
two or more parameters. The function
psych::pairs.panels() from the
package psych is used.
Like hist_qq_boot(), it can also
be used on the output
of standardizedSolution_boot()
or parameterEstimates_boot().
Value
Return the original lavaan::lavaan object invisibly. Called for its side-effect (plotting the graphs).
Author(s)
Shu Fai Cheung https://orcid.org/0000-0002-9871-9448
References
Rousselet, G. A., Pernet, C. R., & Wilcox, R. R. (2021). The percentile bootstrap: A primer with step-by-step instructions in R. Advances in Methods and Practices in Psychological Science, 4(1), 1–10. doi:10.1177/2515245920911881
See Also
store_boot()
and standardizedSolution_boot().
Examples
library(lavaan)
set.seed(5478374)
n <- 50
x <- runif(n) - .5
m <- .40 * x + rnorm(n, 0, sqrt(1 - .40))
y <- .30 * m + rnorm(n, 0, sqrt(1 - .30))
dat <- data.frame(x = x, y = y, m = m)
mod <-
"
m ~ a * x
y ~ b * m + x
ab := a * b
"
fit <- sem(mod,
           data = dat,
           se = "bootstrap",
           bootstrap = 50,
           iseed = 985714)
# Can plot bootstrap estimates for
# free parameters directly
# Note that 'standardized' must be always be set to
# either TRUE or FALSE. No default value.
hist_qq_boot(fit, "a", standardized = FALSE)
# For estimates of user-defined parameters,
# call store_boot() first.
fit <- store_boot(fit)
hist_qq_boot(fit, "ab", standardized = FALSE)
# For estimates in standardized solution,
# call store_boot() first.
fit <- store_boot(fit)
hist_qq_boot(fit, "a", standardized = TRUE)
hist_qq_boot(fit, "ab", standardized = TRUE)
# It can also plot the estimates stored
# in the output of standardizedSolution_boot().
std_boot <- standardizedSolution_boot(fit)
hist_qq_boot(std_boot, "ab")
hist_qq_boot(fit, "ab", standardized = TRUE)
# Scatterplot matrix of bootstrap estimates for
# two or more free parameters
scatter_boot(fit, c("a", "b", "ab"), standardized = FALSE)
# Can include user-defined parameters in
# scatterplot matrix, if their bootstrap
# estimates have been stored
scatter_boot(fit, c("ab", "a", "b"), standardized = FALSE)
# scatter_boot also supports the
# standardized solution
scatter_boot(fit, c("a", "b", "ab"), standardized = TRUE)
Bootstrap CIs for Parameter Estimates
Description
Functions for forming bootstrap confidence intervals for the parameter estimates.
Usage
parameterEstimates_boot(
  object,
  level = 0.95,
  boot_org_ratio = FALSE,
  boot_ci_type = c("perc", "bc", "bca.simple"),
  save_boot_est = TRUE,
  boot_pvalue = TRUE,
  boot_pvalue_min_size = 1000,
  standardized = FALSE,
  ...
)
Arguments
| object | A 'lavaan'-class object, fitted with 'se = "boot"'. | 
| level | The level of confidence of the confidence intervals. Default is .95. | 
| boot_org_ratio | The ratio of
(a) the distance of the bootstrap
confidence limit from the point
estimate to (b) the distance of the
original confidence limit in
 | 
| boot_ci_type | The type of the
bootstrapping confidence intervals.
Support percentile confidence intervals
( | 
| save_boot_est | Whether the
bootstrap estimates of the
parameter estimates are saved. If
saved, the bootstrap estimates
of the free parameters will be stored
in the attribute  | 
| boot_pvalue | Whether asymmetric
bootstrap p-values are computed.
Default is  | 
| boot_pvalue_min_size | Integer.
The asymmetric bootstrap p-values
will be computed only if the number
of valid bootstrap estimates is at
least this value. Otherwise,  | 
| standardized | The type of standardized
estimates. The same argument of
 | 
| ... | Other arguments to be
passed to
 | 
Details
parameterEstimates_boot()
receives a
lavaan::lavaan object and
form bootstrap confidence intervals
for the parameter estimates.
The function store_boot() should
be called first to
compute and store bootstrap estimates.
This function will then retrieve them.
Bootstrap Confidence Intervals
It supports percentile and bias-corrected bootstrap confidence intervals.
Bootstrap Standard Errors
The standard errors are the standard deviation of the bootstrap estimates.
Bootstrap Asymmetric p-Values
If percentile bootstrap confidence interval is requested, asymmetric bootstrap p-values are also computed, using the method presented in Asparouhov and Muthén (2021).
Value
The output of
lavaan::parameterEstimates(),
with bootstrap confidence intervals
appended to the right, with class
set to sbt_ustd_boot. It has
a print method
(print.sbt_ustd_boot()) that
can be used to print the parameter
estimates in a format similar to
that of the printout of
the summary() of a lavaan::lavaan object.
Author(s)
Shu Fai Cheung https://orcid.org/0000-0002-9871-9448.
References
Asparouhov, A., & Muthén, B. (2021). Bootstrap p-value computation. Retrieved from https://www.statmodel.com/download/FAQ-Bootstrap%20-%20Pvalue.pdf
See Also
lavaan::parameterEstimates(), store_boot()
Examples
library(lavaan)
set.seed(5478374)
n <- 50
x <- runif(n) - .5
m <- .40 * x + rnorm(n, 0, sqrt(1 - .40))
y <- .30 * m + rnorm(n, 0, sqrt(1 - .30))
dat <- data.frame(x = x, y = y, m = m)
model <-
'
m ~ a*x
y ~ b*m
ab := a*b
'
# Should set bootstrap to at least 2000 in real studies
fit <- sem(model, data = dat, fixed.x = FALSE)
summary(fit)
fit <- store_boot(fit,
                  do_bootstrapping = TRUE,
                  R = 100,
                  iseed = 1234)
est <- parameterEstimates_boot(fit)
est
Print a 'sbt_std_boot' Object
Description
Print method for a
'sbt_std_boot' object, which
is the output of
standardizedSolution_boot().
Usage
## S3 method for class 'sbt_std_boot'
print(
  x,
  ...,
  nd = 3,
  output = c("lavaan.printer", "text", "table"),
  standardized_only = TRUE,
  boot_ci_only = FALSE,
  drop_cols = "Z"
)
Arguments
| x | Object of the class
 | 
| ... | Optional arguments to be
passed to  | 
| nd | The number of digits after the decimal place. Default is 3. | 
| output | String. How the results
are printed. If set to  | 
| standardized_only | Logical.
If  | 
| boot_ci_only | Logical. Whether
only bootstrap confidence intervals
are printed. If  | 
| drop_cols | The name(s) of the
column(s) to drop
if output format is  | 
Details
The default format of the printout,
"lavaan.printer",
is a compact version of the lavaan-style
printout, generated by lavaan.printer.
Alternatively, users can request a format
similar to that of the printout
of the summary of a lavaan output
by setting output to "text". This
format can be used if "lavaan.printer"
failed.
Users can also print the content just
as a data frame by setting output
to "table". Not easy to read much
more compact.
For the "text" or "lavaan.printer" format, users can
also select whether
only the standardized solution is
printed (the default) or whether
the standardized solution is appended
to the right of the printout.
Value
x is returned invisibly. Called for its side effect.
Author(s)
Shu Fai Cheung https://orcid.org/0000-0002-9871-9448
See Also
Examples
library(lavaan)
set.seed(5478374)
n <- 50
x <- runif(n) - .5
m <- .40 * x + rnorm(n, 0, sqrt(1 - .40))
y <- .30 * m + rnorm(n, 0, sqrt(1 - .30))
dat <- data.frame(x = x, y = y, m = m)
model <-
'
m ~ a*x
y ~ b*m
ab := a*b
'
# Should set bootstrap to at least 2000 in real studies
fit <- sem(model, data = dat, fixed.x = FALSE,
           se = "boot",
           bootstrap = 50)
std_out <- standardizedSolution_boot(fit)
std_out
print(std_out, standardized_only = FALSE)
Print a 'sbt_ustd_boot' Object
Description
Print method for a
'sbt_ustd_boot' object, which
is the output of
parameterEstimates_boot().
Usage
## S3 method for class 'sbt_ustd_boot'
print(
  x,
  ...,
  nd = 3,
  output = c("lavaan.printer", "text", "table"),
  drop_cols = "Z"
)
Arguments
| x | Object of the class
 | 
| ... | Optional arguments to be
passed to  | 
| nd | The number of digits after the decimal place. Default is 3. | 
| output | String. How the results
are printed. If set to  | 
| drop_cols | The name(s) of the
column(s) to drop
if output format is  | 
Details
The default format of the printout,
"lavaan.printer",
is a compact version of the lavaan-style
printout, generated by lavaan.printer.
Alternatively, users can request a format
similar to that of the printout
of the summary of a lavaan output
by setting output to "text". This
format can be used if "lavaan.printer"
failed.
Users can also print the content just
as a data frame by setting output
to "table". Not easy to read much
more compact.
Value
x is returned invisibly. Called for its side effect.
Author(s)
Shu Fai Cheung https://orcid.org/0000-0002-9871-9448
See Also
Examples
library(lavaan)
set.seed(5478374)
n <- 50
x <- runif(n) - .5
m <- .40 * x + rnorm(n, 0, sqrt(1 - .40))
y <- .30 * m + rnorm(n, 0, sqrt(1 - .30))
dat <- data.frame(x = x, y = y, m = m)
model <-
'
m ~ a*x
y ~ b*m
ab := a*b
'
# Should set bootstrap to at least 2000 in real studies
fit <- sem(model, data = dat, fixed.x = FALSE)
fit <- store_boot(fit,
                  do_bootstrapping = TRUE,
                  R = 100,
                  iseed = 1234)
est <- parameterEstimates_boot(fit)
est
Bootstrap CIs for Standardized Solution
Description
Functions for forming bootstrap confidence intervals for the standardized solution.
Usage
standardizedSolution_boot(
  object,
  level = 0.95,
  type = "std.all",
  boot_delta_ratio = FALSE,
  boot_ci_type = c("perc", "bc", "bca.simple"),
  save_boot_est_std = TRUE,
  boot_pvalue = TRUE,
  boot_pvalue_min_size = 1000,
  ...
)
Arguments
| object | A 'lavaan'-class object, fitted with 'se = "boot"'. | 
| level | The level of confidence of the confidence intervals. Default is .95. | 
| type | The type of standard
estimates. The same argument of
 | 
| boot_delta_ratio | The ratio of
(a) the distance of the bootstrap
confidence limit from the point
estimate to (b) the distance of the
delta-method limit from the point
estimate. Default is  | 
| boot_ci_type | The type of the
bootstrapping confidence intervals.
Support percentile confidence intervals
( | 
| save_boot_est_std | Whether the
bootstrap estimates of the
standardized solution are saved. If
saved, they will be stored in the
attribute  | 
| boot_pvalue | Whether asymmetric
bootstrap p-values are computed.
Default is  | 
| boot_pvalue_min_size | Integer.
The asymmetric bootstrap p-values
will be computed only if the number
of valid bootstrap estimates is at
least this value. Otherwise,  | 
| ... | Other arguments to be
passed to
 | 
Details
standardizedSolution_boot()
receives a
lavaan::lavaan object fitted
with bootstrapping standard errors
requested and forms the confidence
intervals for the standardized
solution.
It works by calling
lavaan::standardizedSolution()
with the bootstrap estimates
of free parameters in each bootstrap sample
to compute the standardized estimates
in each sample.
Alternative, call store_boot() to
computes and store bootstrap estimates
of the standardized solution.
This function will then retrieve them,
even if se was not set to
"boot" or "bootstrap" when fitting
the model.
Bootstrap Confidence Intervals
It supports percentile and bias-corrected bootstrap confidence intervals.
Bootstrap Standard Errors
The standard errors are the standard deviation of the bootstrap estimates, which can be different from the delta-method standard errors.
Bootstrap Asymmetric p-Values
If percentile bootstrap confidence interval is requested, asymmetric bootstrap p-values are also computed, using the method presented in Asparouhov and Muthén (2021).
Value
The output of
lavaan::standardizedSolution(),
with bootstrap confidence intervals
appended to the right, with class
set to sbt_std_boot. It has
a print method
(print.sbt_std_boot()) that
can be used to print the standardized
solution in a format similar to
that of the printout of
the summary() of a lavaan::lavaan object.
Author(s)
Shu Fai Cheung
https://orcid.org/0000-0002-9871-9448.
Originally proposed in an issue at GitHub
https://github.com/simsem/semTools/issues/101#issue-1021974657,
inspired by a discussion at
the Google group for lavaan
https://groups.google.com/g/lavaan/c/qQBXSz5cd0o/m/R8YT5HxNAgAJ.
boot::boot.ci() is used to form the
percentile confidence intervals in
this version.
References
Asparouhov, A., & Muthén, B. (2021). Bootstrap p-value computation. Retrieved from https://www.statmodel.com/download/FAQ-Bootstrap%20-%20Pvalue.pdf
See Also
lavaan::standardizedSolution(), store_boot()
Examples
library(lavaan)
set.seed(5478374)
n <- 50
x <- runif(n) - .5
m <- .40 * x + rnorm(n, 0, sqrt(1 - .40))
y <- .30 * m + rnorm(n, 0, sqrt(1 - .30))
dat <- data.frame(x = x, y = y, m = m)
model <-
'
m ~ a*x
y ~ b*m
ab := a*b
'
# Should set bootstrap to at least 2000 in real studies
fit <- sem(model, data = dat, fixed.x = FALSE,
           se = "boot",
           bootstrap = 100)
summary(fit)
std <- standardizedSolution_boot(fit)
std
# Print in a friendly format with only standardized solution
print(std, output = "text")
# Print in a friendly format with both unstandardized
# and standardized solution
print(std, output = "text", standardized_only = FALSE)
# hist_qq_boot() can be used to examine the bootstrap estimates
# of a parameter
hist_qq_boot(std, param = "ab")
# scatter_boot() can be used to examine the bootstrap estimates
# of two or more parameters
scatter_boot(std, params = c("ab", "a", "b"))
Compute and Store Bootstrap Estimates
Description
This function computes bootstrap estimates of a fitted structural equation model and stores the estimates for further processing.
Usage
store_boot(
  object,
  type = "std.all",
  do_bootstrapping = TRUE,
  R = 1000,
  boot_type = "ordinary",
  parallel = c("no", "multicore", "snow"),
  ncpus = parallel::detectCores(logical = FALSE) - 1,
  iseed = NULL,
  keep.idx = FALSE,
  bootstrapLavaan_args = list()
)
Arguments
| object | A 'lavaan'-class object, fitted with 'se = "boot"'. | 
| type | The type of standard
estimates. The same argument of
 | 
| do_bootstrapping | If  | 
| R | If  | 
| boot_type | If  | 
| parallel | If  | 
| ncpus | If  | 
| iseed | If  | 
| keep.idx | Whether the indices
of cases selected in each bootstrap
sample is to be stored. To be passed
to the argument of the same name
in  | 
| bootstrapLavaan_args | A named
list of additional arguments to be
passed to  | 
Details
The function store_boot()
receives a
lavaan::lavaan object, optionally
fitted with bootstrapping standard errors
requested, and compute and store
the bootstrap estimates of user-defined
parameters and estimates in the
standardized solution.
If bootstrapping was not requested
when fitting the model (i.e., se
not set to "boot" or "bootstrap"),
then bootstrapping will be conducted
using lavaan::bootstrapLavaan() to
compute bootstrap estimates of free
parameters. Otherwise, the stored
bootstrap estimates will be used in
subsequent steps.
For standardized solution bootstrap
estimates, it works by calling
lavaan::standardizedSolution()
with the bootstrap estimates
of free parameters in each bootstrap sample
to compute the standardized estimates
in each sample.
For user-defined parameters, it works by calling the function used to compute user-defined parameters with the bootstrap estimates of free parameters in each bootstrap samples to compute the user-defined parameters.
The bootstrap estimates are then
stored in the external slot
of the fit object for further
processing.
Value
The original lavaan object is
returned with the following objects
stored in the external slot:
-  sbt_boot_std: The matrix of bootstrap estimates in the standardized solution.
-  sbt_boot_def: The matrix of bootstrap estimates of user-defined parameters, if any.
-  sbt_boot_ustd: The matrix of bootstrap estimates of free parameters, if bootstrapping is not requested when fitting the model (i.e.,seis not set to"boot"or"bootstrap"when fitting the model inlavaan).
Author(s)
Shu Fai Cheung
https://orcid.org/0000-0002-9871-9448.
Based on semhelpinghands::standardizedSolution_boot_ci(),
which was originally proposed in an issue at GitHub
https://github.com/simsem/semTools/issues/101#issue-1021974657,
inspired by a discussion at
the Google group for lavaan
https://groups.google.com/g/lavaan/c/qQBXSz5cd0o/m/R8YT5HxNAgAJ.
Unlike semhelpinghands::standardizedSolution_boot_ci(),
this function only computes and stores
the bootstrap estimates.
Examples
library(lavaan)
set.seed(5478374)
n <- 50
x <- runif(n) - .5
m <- .40 * x + rnorm(n, 0, sqrt(1 - .40))
y <- .30 * m + rnorm(n, 0, sqrt(1 - .30))
dat <- data.frame(x = x, y = y, m = m)
model <-
'
m ~ a*x
y ~ b*m
ab := a*b
'
# Should set bootstrap to at least 2000 in real studies
fit <- sem(model, data = dat, fixed.x = FALSE,
           se = "boot",
           bootstrap = 100)
summary(fit)
fit <- store_boot(fit)