tests/testthat/test_discrete_response.R

library(pense)
library(testthat)

test_that("Response with no variation", {
  # Generate dummy data with n=50 observations and p=25 possible predictors
  # (of which only the first 3 are truly relevant).
  n <- 50
  p <- 5
  set.seed(123)
  x <- matrix(rt(n * p, df = 5), ncol = p)
  y <- c(rep.int(0, n / 2 - 1), rep.int(1, n / 2 + 1)) # has a MAD of 0

  fit_cont <- expect_warning(
    pense_cv(x, y, alpha = 0.9, nlambda = 10, cv_k = 3),
    regexp = 'binary')
  expect_is(fit_cont, 'pense_cvfit')
  expect_equal(fit_cont$cv_measure, 'tau_size')

  expect_error(
    pense_cv(x, factor(y), alpha = 0.9, nlambda = 10, cv_k = 3, bdp = 0.5),
    regexp = 'M-scale of response is 0.')

  fit_bin <- pense_cv(x, factor(y), alpha = 0.9, nlambda = 10, cv_k = 3,
                      bdp = 0.25)
  expect_is(fit_bin, 'pense_cvfit')
  expect_equal(fit_bin$cv_measure, 'auroc')
})

Try the pense package in your browser

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

pense documentation built on Feb. 16, 2023, 9:36 p.m.