tests/testthat/test-random_classifier.R

context("Random Guess Classifier")

suppressWarnings(RNGversion("3.5.0"))
set.seed(1234567)

test_that("Random Guess Classifier Approximates Limit Error", {
  n <- 400
  d <- 6
  K <- 2
  nrep <- 10

  pr <- c(0.9, 0.1)
  lhat.sim <- sapply(1:nrep, function(i) {
    dat=lol.sims.mean_diff(n, d, priors=pr)
    class <- lol.classify.randomGuess(dat$X, dat$Y)
    expect_equal(class$priors, pr, tolerance=0.05)
    Yhat <- predict(class, dat$X)
    sum(Yhat == dat$Y)/length(Yhat)
  })

  expect_equal(mean(lhat.sim), 0.9^2, tolerance=.1)
})

context("Random Chance Classifier")

suppressWarnings(RNGversion("3.5.0"))
set.seed(1234567)

test_that("Random Chance Classifier Approximates Limit Error", {
  n <- 400
  d <- 6
  K <- 2
  nrep <- 10

  pr <- c(0.9, 0.1)
  lhat.sim <- sapply(1:nrep, function(i) {
    dat=lol.sims.mean_diff(n, d, priors=pr)
    class <- lol.classify.randomChance(dat$X, dat$Y)
    expect_equal(class$priors, pr, tolerance=0.05)
    Yhat <- predict(class, dat$X)
    sum(Yhat == dat$Y)/length(Yhat)
  })

  expect_equal(mean(lhat.sim), 0.9, tolerance=.1)
})
neurodata/lol documentation built on March 3, 2021, 1:46 a.m.