tests/testthat/test-predict-dpar.R

skip_on_cran()

test_that("estimate_means and estimate_relation - dpar", {
  skip_if_not_installed("brms")
  skip_if_not_installed("marginaleffects")
  skip_if_not_installed("datawizard")
  skip_if_not_installed("httr2")
  skip_if_not_installed("collapse")

  m <- suppressWarnings(insight::download_model("brms_sigma_2"))
  skip_if(is.null(m))

  out1 <- marginaleffects::predictions(
    m,
    newdata = insight::get_datagrid(m, c("Condition", "Participant")),
    by = c("Condition", "Participant"),
    dpar = "sigma"
  )
  out2 <- estimate_means(
    m,
    by = c("Condition", "Participant"),
    predict = "sigma",
    backend = "marginaleffects"
  )
  expect_equal(out1$estimate, out2$Sigma, tolerance = 1e-4)

  out1 <- estimate_relation(
    m,
    by = c("Condition", "Participant"),
    predict = "sigma"
  )
  out1 <- datawizard::data_arrange(out1, "Condition")
  dg <- insight::get_datagrid(m, c("Condition", "Participant"))
  out2 <- cbind(
    dg,
    data.frame(
      predicted = colMeans(brms::posterior_epred(
        m,
        newdata = dg,
        dpar = "sigma"
      ))
    )
  )
  out2 <- datawizard::data_arrange(out2, "Condition")
  expect_equal(out1$Predicted, out2$predicted, tolerance = 1e-4)
})
easystats/estimate documentation built on April 5, 2025, 1:36 p.m.