tests/testthat/test-performance_aic.R

test_that("performance_aic works", {
  skip_if_not_installed("parameters")
  data(fish, package = "parameters")

  model_norm <- lm(count ~ factor(persons), fish)
  model_pois <- glm(count ~ factor(persons), fish, family = poisson())
  expect_equal(performance_aic(model_norm), 1930.755, tolerance = 1e-2)
  expect_equal(performance_aic(model_pois), 2758.236, tolerance = 1e-2)
})

test_that("performance_aic for log-model works", {
  skip_if_not_installed("parameters")
  data(fish, package = "parameters")
  model_lnorm <- lm(log1p(count) ~ factor(persons), fish)
  expect_equal(performance_aic(model_lnorm), 1025.352, tolerance = 1e-2)
})

test_that("performance_aic Jacobian", {
  m1 <- lm(disp ~ hp, data = mtcars)
  m2 <- lm(sqrt(disp) ~ hp, data = mtcars)
  expect_equal(performance_aic(m1), 372.8247, tolerance = 1e-2)
  expect_equal(performance_aic(m2), 367.1239, tolerance = 1e-2)
})

test_that("performance_aic lme4 default", {
  skip_if_not_installed("lme4")
  m1 <- lme4::lmer(Sepal.Length ~ Petal.Length + (1 | Species), data = iris)
  expect_equal(performance_aic(m1), AIC(m1), tolerance = 1e-2)
  expect_equal(performance_aic(m1, estimator = "ML"), 125.0043, tolerance = 1e-2)
})

Try the performance package in your browser

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

performance documentation built on Nov. 2, 2023, 5:48 p.m.