tests/testthat/test-rvar-dist.R

test_that("distributional functions work on a scalar rvar", {
  x_values <- c(2,4,3,5)
  x <- rvar(x_values)

  x_density <- density(x_values, cut = 0)
  expect_equal(density(x, at = x_density$x), x_density$y)

  x_cdf <- ecdf(x_values)(x_values)
  expect_equal(cdf(x, x_values), x_cdf)

  expect_equal(quantile(x, 1:4/4), quantile(x_values, 1:4/4, names = FALSE))
})

test_that("distributional functions work on an rvar array", {
  x <- rvar(array(1:12, dim = c(3,2,2)))

  d11 <- c(density(1:3, n = 3, from = 1, to = 3)$y, rep(0, 9))
  d21 <- c(rep(0, 3), density(4:6, n = 3, from = 4, to = 6)$y, rep(0, 6))
  d12 <- c(rep(0, 6), density(7:9, n = 3, from = 7, to = 9)$y, rep(0, 3))
  d22 <- c(rep(0, 9), density(10:12, n = 3, from = 10, to = 12)$y)
  x_density <- array(c(d11, d21, d12, d22), dim = c(12, 2, 2))
  expect_equal(density(x, at = 1:12), x_density)

  cdf11 <- ecdf(1:3)(1:12)
  cdf21 <- ecdf(4:6)(1:12)
  cdf12 <- ecdf(7:9)(1:12)
  cdf22 <- ecdf(10:12)(1:12)
  x_cdf <- array(c(cdf11, cdf21, cdf12, cdf22), dim = c(12, 2, 2))
  expect_equal(cdf(x, 1:12), x_cdf)

  p <- ppoints(9, a = 1)
  q11 <- quantile(1:3, p)
  q21 <- quantile(4:6, p)
  q12 <- quantile(7:9, p)
  q22 <- quantile(10:12, p)
  x_quantiles <- array(c(q11, q21, q12, q22), dim = c(9, 2, 2), dimnames = list(NULL))
  expect_equal(quantile(x, p), x_quantiles)
})

test_that("distributional functions work on an rvar_factor", {
  x_values <- c(2,2,2,4,4,4,4,3,5,3)
  x_letters <- letters[x_values]
  x <- rvar_factor(x_letters, levels = letters[1:5])

  expect_equal(density(x, letters[1:6]), c(0, .3, .2, .4, .1, NA))

  expect_equal(cdf(x, letters[1:5]), c(NA, NA, NA, NA, NA))

  expect_equal(quantile(x, 1:4/4), c(NA, NA, NA, NA))
})

test_that("distributional functions work on an rvar_ordered", {
  x_values <- c(2,2,2,4,4,4,4,3,5,3)
  x_letters <- letters[x_values]
  x <- rvar_ordered(x_letters, levels = letters[1:6])

  expect_equal(density(x, letters[1:7]), c(0, .3, .2, .4, .1, 0, NA))

  expect_equal(cdf(x, letters[1:7]), c(0, .3, .5, .9, 1, 1, NA))

  expect_equal(quantile(x, c(.3, .5, .9, 1)), letters[2:5])
})

Try the posterior package in your browser

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

posterior documentation built on Nov. 2, 2023, 5:56 p.m.