tests/testthat/test-decision1S_boundary.R

test_that("decision1S_boundary works for normal outcome", {
  prior <- mixnorm(rob = c(0.2, 0, 2), inf = c(0.8, 2, 2), sigma = 5)

  dec <- decision1S(pc = 0.95, qc = 0.6, lower.tail = TRUE)
  result <- decision1S_boundary(prior, n = 50, decision = dec)
  expect_equal(result, -0.7359727, tolerance = 1e-5)

  dec <- decision1S(pc = 0.8, qc = 1.5, lower.tail = FALSE)
  result <- decision1S_boundary(prior, n = 50, decision = dec)
  expect_equal(result, 2.105779, tolerance = 1e-5)
})

test_that("Mixed lower.tail usage works for normal decision boundary calculation", {
  prior <- mixnorm(rob = c(0.2, 0, 2), inf = c(0.8, 2, 2), sigma = 5)

  dec_lower <- decision1S(pc = 0.5, qc = 1.5, lower.tail = TRUE)
  result_lower <- decision1S_boundary(
    prior,
    n = 50,
    decision = dec_lower
  )

  dec_upper <- decision1S(pc = 0.6, qc = 0.5, lower.tail = FALSE)
  result_upper <- decision1S_boundary(
    prior,
    n = 50,
    decision = dec_upper
  )
  assert_true(result_lower != result_upper)

  decMixed <- decision1S(
    qc = c(1.5, 0.5),
    pc = c(0.5, 0.6),
    lower.tail = c(TRUE, FALSE)
  )
  result <- decision1S_boundary(prior, 50, decMixed)
  expected <- c(lower_or_equal_than = result_lower, higher_than = result_upper)
  expect_equal(result, expected)
})

test_that("decision1S_boundary works for binomial outcome", {
  prior <- mixbeta(rob = c(0.2, 2, 2), inf = c(0.8, 5, 5))

  dec <- decision1S(pc = 0.95, qc = 0.6, lower.tail = TRUE)
  result <- decision1S_boundary(prior, n = 50, decision = dec)
  expect_equal(result, 24)

  dec <- decision1S(pc = 0.6, qc = 0.6, lower.tail = FALSE)
  result <- decision1S_boundary(prior, n = 50, decision = dec)
  expect_equal(result, 31)
})

test_that("Mixed lower.tail usage works for binomial decision boundary calculation", {
  prior <- mixbeta(rob = c(0.2, 2, 2), inf = c(0.8, 5, 5))

  dec_lower <- decision1S(pc = 0.5, qc = 0.7, lower.tail = TRUE)
  result_lower <- decision1S_boundary(
    prior,
    n = 50,
    decision = dec_lower
  )

  dec_upper <- decision1S(pc = 0.6, qc = 0.5, lower.tail = FALSE)
  result_upper <- decision1S_boundary(
    prior,
    n = 50,
    decision = dec_upper
  )
  assert_true(result_lower != result_upper)

  decMixed <- decision1S(
    qc = c(0.7, 0.5),
    pc = c(0.5, 0.6),
    lower.tail = c(TRUE, FALSE)
  )
  result <- decision1S_boundary(prior, n = 50, decision = decMixed)
  expected <- c(lower_or_equal_than = result_lower, higher_than = result_upper)
  expect_equal(result, expected)
})

test_that("decision1S_boundary works for Poisson outcome", {
  prior <- mixgamma(rob = c(0.2, 2, 2), inf = c(0.8, 5, 5))

  dec <- decision1S(pc = 0.95, qc = 0.6, lower.tail = TRUE)
  result <- decision1S_boundary(prior, n = 50, decision = dec)
  expect_equal(result, 19)

  dec <- decision1S(pc = 0.6, qc = 0.6, lower.tail = FALSE)
  result <- decision1S_boundary(prior, n = 50, decision = dec)
  expect_equal(result, 30)
})

test_that("Mixed lower.tail usage works for Poisson decision boundary calculation", {
  prior <- mixgamma(rob = c(0.2, 2, 2), inf = c(0.8, 5, 5))

  dec_lower <- decision1S(pc = 0.5, qc = 0.7, lower.tail = TRUE)
  result_lower <- decision1S_boundary(
    prior,
    n = 50,
    decision = dec_lower
  )

  dec_upper <- decision1S(pc = 0.6, qc = 0.5, lower.tail = FALSE)
  result_upper <- decision1S_boundary(
    prior,
    n = 50,
    decision = dec_upper
  )
  assert_true(result_lower != result_upper)

  decMixed <- decision1S(
    qc = c(0.7, 0.5),
    pc = c(0.5, 0.6),
    lower.tail = c(TRUE, FALSE)
  )
  result <- decision1S_boundary(prior, n = 50, decision = decMixed)
  expected <- c(lower_or_equal_than = result_lower, higher_than = result_upper)
  expect_equal(result, expected)
})

Try the RBesT package in your browser

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

RBesT documentation built on March 13, 2026, 5:06 p.m.