tests/testthat/test-sample.R

test_that("Sampling from a Dirichlet distribution works", {
  withr::local_seed(42)
  samp <- sample_dirichlet(10000, alpha = c(1, 1, 1))
  expect_equal(dim(samp), c(3, 10000))
  expect_equal(colSums(samp), rep(1, 10000))
  expect_equal(rowMeans(samp), rep(1 / 3, 3), tolerance = 1e-2)
  expect_equal(apply(samp, 1, sd), rep(1 / (3 * sqrt(2)), 3), tolerance = 1e-2)

  ## Corner cases
  sd1 <- sample_dirichlet(1, alpha = c(2, 2, 2))
  expect_equal(dim(sd1), c(3, 1))
  sd0 <- sample_dirichlet(0, alpha = c(3, 3, 3))
  expect_equal(dim(sd0), c(3, 0))

  ## Errors
  expect_error(
    sample_dirichlet(-1, alpha = c(1, 1, 1, 1)),
    "should be non-negative"
  )
  expect_error(
    sample_dirichlet(5, alpha = c(1)),
    "must have at least two entries"
  )
  expect_error(sample_dirichlet(5, alpha = c(0, 1, 1)), "must be positive")
  expect_error(sample_dirichlet(5, alpha = c(1, -1, -1)), "must be positive")
})
igraph/rigraph documentation built on Oct. 17, 2024, 12:34 p.m.