inst/tinytest/test_pkg_MASS.R

if (!requireNamespace("gridExtra", quietly = TRUE)) {
  exit_file("Package gridExtra missing")
}

# Load required packages
suppressMessages({
  library(gridExtra)
})

# Tests for package MASS
if (require(MASS, quietly = TRUE)) {

  # Load Friedman benchmark data
  friedman2 <- readRDS("friedman.rds")$friedman2  # classification (binary)

  # Linear discriminant analysis; MASS::lda() ----------------------------------

  # Fit model(s)
  fit_lda <- lda(y ~ . ^ 2, data = friedman2)

  # Partial dependence for x.3
  pd_lda <- partial(fit_lda, pred.var = "x.3")
  pd_lda_prob <- partial(fit_lda, pred.var = "x.3", prob = TRUE)

  # ICE curves for x.3
  ice_lda <- partial(fit_lda, pred.var = "x.3", ice = TRUE, center = TRUE)
  ice_lda_prob <- partial(fit_lda, pred.var = "x.3", prob = TRUE,
                          ice = TRUE, center = TRUE)

  # Expectation(s)
  expect_true(inherits(pd_lda, what = "partial"))
  expect_true(inherits(pd_lda_prob, what = "partial"))
  expect_true(inherits(ice_lda, what = "cice"))
  expect_true(inherits(ice_lda_prob, what = "cice"))

  # Display plots in a grid
  grid.arrange(
    plotPartial(pd_lda),
    plotPartial(pd_lda_prob),
    plotPartial(ice_lda),
    plotPartial(ice_lda_prob),
    nrow = 2
  )

  # Quadratic discriminant analysis; MASS::qda() -------------------------------

  # Fit model(s)
  fit_qda <- qda(y ~ ., data = friedman2)

  # Partial dependence for x.3
  pd_qda <- partial(fit_qda, pred.var = "x.3")
  pd_qda_prob <- partial(fit_qda, pred.var = "x.3", prob = TRUE)

  # ICE curves for x.3
  ice_qda <- partial(fit_qda, pred.var = "x.3", ice = TRUE, center = TRUE)
  ice_qda_prob <- partial(fit_qda, pred.var = "x.3", prob = TRUE,
                          ice = TRUE, center = TRUE)

  # Expectation(s)
  expect_true(inherits(pd_qda, what = "partial"))
  expect_true(inherits(pd_qda_prob, what = "partial"))
  expect_true(inherits(ice_qda, what = "cice"))
  expect_true(inherits(ice_qda_prob, what = "cice"))

  # Display plots in a grid
  grid.arrange(
    plotPartial(pd_qda),
    plotPartial(pd_qda_prob),
    plotPartial(ice_qda),
    plotPartial(ice_qda_prob),
    nrow = 2
  )

}

Try the pdp package in your browser

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

pdp documentation built on June 8, 2022, 1:07 a.m.