tests/testthat/test_lav_data_used_mi_no_means.R

skip_on_cran()
skip_if_not_installed("semTools")
skip_if_not_installed("Amelia")
# Require Amelia
library(testthat)
library(manymome)
library(lavaan)
suppressMessages(library(semTools))
suppressMessages(library(Amelia))

dat <- add_na(data_mod,
              prop = .20,
              seed = 1314)
sum(complete.cases(dat))
set.seed(879051)
dat_mi <- amelia(dat, m = 2)$imputations
mod <-
"
y ~ x + w + x:w + c1
"
fit_mi <- sem.mi(mod, dat_mi, meanstructure = FALSE)
fit_mi_dat <- lav_data_used(fit_mi)
tmpnames <- intersect(colnames(fit_mi_dat),
                      colnames(dat))

test_that("Moderation, MI, no means", {
    expect_identical(fit_mi_dat[, tmpnames],
                     as.matrix(dat[, tmpnames]))
  })

mod2 <-
"
w ~ x + c1
y ~ w + x + c2
"
fit2_mi <- sem.mi(mod2, dat_mi, meanstructure = FALSE)
fit2_mi_dat <- lav_data_used(fit2_mi)
tmpnames <- intersect(colnames(fit2_mi_dat),
                      colnames(dat))

test_that("Mediation, MI, no means", {
    expect_identical(fit2_mi_dat[, tmpnames],
                     as.matrix(dat[, tmpnames]))
  })

Try the manymome package in your browser

Any scripts or data that you put into this service are public.

manymome documentation built on Oct. 4, 2024, 5:10 p.m.