inst/tinytest/test_feedback_and_xy_cov.R

suppressMessages(library(lavaan))

dat <- dat_path_model

mod <-
"
x1 ~ x2
x3 ~ x1
x4 ~ x3 + x2
"

fit <- sem(mod,
           dat_path_model,
           meanstructure = TRUE,
           fixed.x = TRUE)

mod2 <-
"
f1 =~ x4 + x2 + x3
"

fit2 <- cfa(mod2,
            dat_path_model,
            meanstructure = TRUE,
            fixed.x = TRUE)

out <- modelbpp:::feedback_and_xy_cov(fit)
out2 <- modelbpp:::feedback_and_xy_cov(fit2)

feedback_check <- structure(list(lhs = c("x1", "x2", "x2"), op = c("~", "~", "~"
), rhs = c("x4", "x3", "x4")), row.names = c(NA, 3L), class = "data.frame")

xy_cov_check <- structure(list(lhs = c("x1", "x2", "x2"), op = c("~~", "~~",
"~~"), rhs = c("x4", "x3", "x4")), row.names = c(NA, 3L), class = "data.frame")

expect_true(setequal(out$all_feedback,
                     feedback_check),
            info = "modelbpp:::feedback_and_xy_cov")
expect_true(setequal(out$all_xy_cov,
                     xy_cov_check),
            info = "modelbpp:::feedback_and_xy_cov")

lor_feedback_check <- list(c(lhs = "x1", op = "~", rhs = "x4"), c(lhs = "x2", op = "~",
rhs = "x3"), c(lhs = "x2", op = "~", rhs = "x4"))

lor_xy_cov_check <- list(c(lhs = "x1", op = "~~", rhs = "x4"), c(lhs = "x2", op = "~~",
rhs = "x3"), c(lhs = "x2", op = "~~", rhs = "x4"))

expect_true(setequal(modelbpp:::df_to_lor(out$all_feedback),
                     lor_feedback_check),
            info = "modelbpp:::feedback_and_xy_cov")
expect_true(setequal(modelbpp:::df_to_lor(out$all_xy_cov),
                     lor_xy_cov_check),
            info = "modelbpp:::feedback_and_xy_cov")

out_add_fb <- get_add(fit, exclude_feedback = TRUE)
names(out_add_fb)
out2_add_fb <- get_add(fit2, exclude_feedback = TRUE)
names(out2_add_fb)

out_add_xy_cov <- get_add(fit, exclude_xy_cov = TRUE)
names(out_add_xy_cov)
out2_add_xy_cov <- get_add(fit2, exclude_xy_cov = TRUE)
names(out2_add_xy_cov)

out_add_both <- get_add(fit, exclude_xy_cov = TRUE,
                             exclude_feedback = TRUE)
names(out_add_both)
out2_add_both <- get_add(fit2, exclude_xy_cov = TRUE,
                             exclude_feedback = TRUE)
names(out2_add_both)

expect_false("add: x1~x4" %in% names(out_add_fb),
            info = "modelbpp:::feedback_and_xy_cov")
expect_false("add: x1~~x4" %in% names(out_add_xy_cov),
            info = "modelbpp:::feedback_and_xy_cov")
expect_true("add: x1~~x4" %in% names(out_add_fb),
            info = "modelbpp:::feedback_and_xy_cov")
expect_true("add: x1~x4" %in% names(out_add_xy_cov),
            info = "modelbpp:::feedback_and_xy_cov")
expect_false("add: x1~x4" %in% names(out_add_both),
            info = "modelbpp:::feedback_and_xy_cov")
expect_false("add: x1~~x4" %in% names(out_add_both),
            info = "modelbpp:::feedback_and_xy_cov")

Try the modelbpp package in your browser

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

modelbpp documentation built on Sept. 30, 2024, 9:40 a.m.