tests/testthat/test-zibr.R

real_expected <- list(
  logistic_est_table = structure(
    c(2.69732340911363, 0.200018071642455, 6.17105397782147e-06, 0.887710710500198),
    .Dim = c(2L, 2L),
    .Dimnames = list(
      c("intersept", "Treatment"),
      c("Estimate", "Pvalue")
    )
  ),
  logistic_s1_est = 3.27876357265477,
  beta_est_table = structure(
    c(-2.78605402671509, -0.32334269957996, 0, 0.206300170582503),
    .Dim = c(2L, 2L),
    .Dimnames = list(
      c("intersept", "Treatment"),
      c("Estimate", "Pvalue")
    )
  ),
  beta_s2_est = 0.538923350735293,
  beta_v_est = 7.62238420518043,
  loglikelihood = 321.901751058239,
  joint_p = c(Treatment = 0.445494681803514)
)

test_that("zibr main function works on package data", {
  zibr_fit <- zibr(
    logistic_cov = data.frame(Treatment = ibd$Treatment),
    beta_cov = data.frame(Treatment = ibd$Treatment),
    Y = ibd$Abundance, subject_ind = ibd$Subject,
    time_ind = ibd$Time
  )

  expected_names <- c("logistic_est_table",
                      "logistic_s1_est",
                      "beta_est_table",
                      "beta_s2_est",
                      "beta_v_est",
                      "loglikelihood",
                      "joint_p")
  expect_equal(names(zibr_fit), expected_names)
  expect_equal(zibr_fit, real_expected, tolerance = 1e-3)
})

set.seed(19683)

sim <- simulate_zero_inflated_beta_random_effect_data(
  subject_n = 100, time_n = 5,
  X = as.matrix(c(rep(0, 50 * 5), rep(1, 50 * 5))),
  Z = as.matrix(c(rep(0, 50 * 5), rep(1, 50 * 5))),
  alpha = as.matrix(c(-0.5, 1)),
  beta = as.matrix(c(-0.5, 0.5)),
  s1 = 1, s2 = 0.8,
  v = 5,
  sim_seed = 100
)

sim_expected <- list(
  logistic_est_table = structure(
    c(-0.571900346260645, 0.828072571379781, 0.0069577928092327, 0.00547006539016526),
    .Dim = c(2L, 2L),
    .Dimnames = list(
      c("intersept", "var1"),
      c("Estimate", "Pvalue")
    )
  ),
  logistic_s1_est = 1.06801391077711,
  beta_est_table = structure(
    c(-0.593090577296489, 0.591745582740125, 4.18162741963046e-05, 0.00169945318503251),
    .Dim = c(2L, 2L),
    .Dimnames = list(
      c("intersept", "var1"),
      c("Estimate", "Pvalue")
    )
  ),
  beta_s2_est = 0.630386186272789,
  beta_v_est = 4.73406414312415,
  loglikelihood = NA,
  joint_p = NA
)

sim_expected_cov <- list(
  logistic_est_table = structure(
    c(-0.571900346260645, 0.828072571379781, 0.0069577928092327, 0.00547006539016526),
    .Dim = c(2L, 2L),
    .Dimnames = list(
      c("intersept", "var1"),
      c("Estimate", "Pvalue")
    )
  ),
  logistic_s1_est = 1.06801391077711,
  beta_est_table = structure(
    c(-0.593090577296489, 0.591745582740125, 4.18162741963046e-05, 0.00169945318503251),
    .Dim = c(2L, 2L),
    .Dimnames = list(
      c("intersept", "var1"),
      c("Estimate", "Pvalue")
    )
  ),
  beta_s2_est = 0.630386186272789,
  beta_v_est = 4.73406414312415,
  loglikelihood = -286.585518147651,
  joint_p = c(var1 = 0.000153328547781939)
)

test_that("zibr main function works on simulated data", {
  zibr_fit <- zibr(logistic_cov = sim$X,
                   beta_cov = sim$Z,
                   Y = sim$Y,
                   subject_ind = sim$subject_ind,
                   time_ind = sim$time_ind)

  expect_equal(zibr_fit, sim_expected, tolerance = 1e-3)
})

test_that("zibr main function works on simulated data with same covariates", {
  zibr_fit <- zibr(logistic_cov = sim$X,
                   beta_cov = sim$X,
                   Y = sim$Y,
                   subject_ind = sim$subject_ind,
                   time_ind = sim$time_ind)

  expect_equal(zibr_fit, sim_expected_cov, tolerance = 1e-3)
})
chvlyl/ZIBR documentation built on Oct. 22, 2023, 1:06 p.m.