| Type: | Package | 
| Title: | Stratified Evaluation of Subgroup Classification Accuracy | 
| Version: | 0.2.0 | 
| Description: | Enables simultaneous statistical inference for the accuracy of multiple classifiers in multiple subgroups (strata). For instance, allows to perform multiple comparisons in diagnostic accuracy studies with co-primary endpoints sensitivity and specificity (Westphal M, Zapf A. Statistical inference for diagnostic test accuracy studies with multiple comparisons. Statistical Methods in Medical Research. 2024;0(0). <doi:10.1177/09622802241236933>). | 
| License: | MIT + file LICENSE | 
| Encoding: | UTF-8 | 
| LazyData: | true | 
| Imports: | bindata, boot, copula, corrplot, dplyr, extraDistr, magrittr, Matrix, multcomp, mvtnorm, ggplot2 | 
| Suggests: | testthat (≥ 3.0.0), knitr, rmarkdown, covr, badger, glmnet, splitstackshape | 
| RoxygenNote: | 7.3.2 | 
| VignetteBuilder: | knitr, rmarkdown | 
| Config/testthat/edition: | 3 | 
| URL: | https://github.com/maxwestphal/cases, https://maxwestphal.github.io/cases/ | 
| BugReports: | https://github.com/maxwestphal/cases/issues | 
| Depends: | R (≥ 2.10) | 
| NeedsCompilation: | no | 
| Packaged: | 2025-01-08 07:22:51 UTC; maxwe | 
| Author: | Max Westphal | 
| Maintainer: | Max Westphal <dev@maxwestphal.io> | 
| Repository: | CRAN | 
| Date/Publication: | 2025-01-09 17:50:02 UTC | 
cases package
Description
Enables simultaneous statistical inference for the accuracy of multiple classifiers in multiple subgroups (strata). For instance, allows to perform multiple comparisons in diagnostic accuracy studies with co-primary endpoints sensitivity (true positive rate, TPR) and specificity (true negative rate, TNR).
Details
The package functionality and syntax is described in the vignettes, see examples.
Author(s)
Maintainer: Max Westphal dev@maxwestphal.io (ORCID)
References
Westphal M, Zapf A. Statistical inference for diagnostic test accuracy studies with multiple comparisons. Statistical Methods in Medical Research. 2024;0(0). doi:10.1177/09622802241236933
See Also
Useful links:
- Report bugs at https://github.com/maxwestphal/cases/issues 
Examples
# overview over package functionality:
vignette("package_overview")
# a real-world data example:
vignette("example_wdbc")
Pipe operator
Description
See magrittr::%>% for details.
Usage
lhs %>% rhs
Arguments
| lhs | the value to be piped in  | 
| rhs | the function to be applied with first argument  | 
Value
the result of rhs(lhs, ...)
Categorize continuous values
Description
This function allows to split continuous values, e.g. (risk) scores or (bio)markers, into two or more categories by specifying one or more cutoff values.
Usage
categorize(
  values,
  cutoffs = rep(0, ncol(values)),
  map = 1:ncol(values),
  labels = NULL
)
Arguments
| values | (matrix)  | 
| cutoffs | (numeric | matrix)  | 
| map | (numeric)  | 
| labels | (character)  | 
Value
(matrix) 
 numeric (n x k) matrix with categorical outcomes after categorizing.
Examples
set.seed(123)
M <- as.data.frame(mvtnorm::rmvnorm(20, mean = rep(0, 3), sigma = 2 * diag(3)))
M
categorize(M)
C <- matrix(rep(c(-1, 0, 1, -2, 0, 2), 3), ncol = 3, byrow = TRUE)
C
w <- c(1, 1, 2, 2, 3, 3)
categorize(M, C, w)
Compare predictions and labels
Description
Compare predictions and labels
Usage
compare(
  predictions,
  labels,
  partition = TRUE,
  names = c(specificity = 0, sensitivity = 1)
)
Arguments
| predictions | (numeric | character)  | 
| labels | (numeric | character)  | 
| partition | (logical)  | 
| names | (character | NULL)  | 
Value
(list | matrix) 
 list of matrices (one for each unique value of labels) with
values 1 (correct prediction) and 0 (false prediction).
If partition=TRUE, the matrices are combined in a single matrix with rbind.
Examples
pred <- matrix(c(1, 1, 0), 5, 3)
labels <- c(1, 1, 0, 0, 1)
compare(pred, labels, FALSE)
compare(pred, labels, TRUE)
Create an AR(1) correlation matrix
Description
Create an AR(1) correlation matrix
Usage
cormat_ar1(m, rho, d = TRUE)
Arguments
| m | (numeric)  | 
| rho | (numeric)  | 
| d | (logical | numeric)  | 
Value
(matrix) 
AR(1) correlation matrix R with entries R_{ij} = \rho^{|i-j|}
Create an equicorrelation matrix
Description
Create an equicorrelation matrix
Usage
cormat_equi(m, rho, d = TRUE)
Arguments
| m | (numeric)  | 
| rho | (numeric)  | 
| d | (logical | numeric)  | 
Value
(matrix) 
AR(1) correlation matrix R with entries R_{ij} = \rho, i\neq j
Breast Cancer Wisconsin (Diagnostic) Data Set
Description
Dataset documentation can be found at the source website and references below.
Usage
data_wdbc
Format
data_wdbc
A data frame with 569 rows (patients) and 31 columns (1 target, 30 features).
Details
The ID variable was removed. Diagnosis (1= malignant, 0 = benign). Feature variables have been renamed.
Source
https://archive.ics.uci.edu/ml/datasets/breast+cancer+wisconsin+(diagnostic)
References
- W.N. Street, W.H. Wolberg and O.L. Mangasarian. Nuclear feature extraction for breast tumor diagnosis. IS&T/SPIE 1993 International Symposium on Electronic Imaging: Science and Technology, volume 1905, pages 861-870, San Jose, CA, 1993. 
- O.L. Mangasarian, W.N. Street and W.H. Wolberg. Breast cancer diagnosis and prognosis via linear programming. Operations Research, 43(4), pages 570-577, July-August 1995. 
Define a contrast (matrix) to specify exact hypothesis system
Description
Define a contrast (matrix) to specify exact hypothesis system
Usage
define_contrast(type = c("raw", "one", "all"), comparator = NA)
Arguments
| type | (character)  | 
| comparator | (numeric | character)  | 
Details
- "raw" contrast: compare all candidates against specified benchmark values 
- "one" ('all vs. one' or 'Dunnett') contrast: compare all candidates to a single comparator. 
- "all" ('all vs. all' or 'Tukey') contrast: compare all candidates against each other. 
Value
(cases_contrast) 
 object to be passed to evaluate
Examples
define_contrast("one", 1)
Generate binary data
Description
Generate binary data
Usage
draw_data(
  n = 200,
  prev = c(0.5, 0.5),
  random = FALSE,
  m = 10,
  method = c("roc", "lfc", "pr"),
  pars = list(),
  ...
)
Arguments
| n | (numeric)  | 
| prev | (numeric)  | 
| random | (logical)  | 
| m | (numeric)  | 
| method | (character)  | 
| pars | (list)  | 
| ... | (any)  | 
Value
(matrix) 
 generated binary data (possibly stratified for subgroups)
Examples
draw_data()
Generate binary data (LFC model)
Description
Generate binary data (LFC model)
Usage
draw_data_lfc(
  n = 100,
  prev = c(0.5, 0.5),
  random = FALSE,
  m = 10,
  se = 0.8,
  sp = 0.8,
  B = round(m/2),
  L = 1,
  Rse = diag(rep(1, m)),
  Rsp = diag(rep(1, m)),
  modnames = paste0("model", 1:m),
  ...
)
Arguments
| n | (numeric)  | 
| prev | (numeric)  | 
| random | (logical)  | 
| m | (numeric)  | 
| se | (numeric)  | 
| sp | (numeric)  | 
| B | (numeric)  | 
| L | (numeric)  | 
| Rse | (matrix)  | 
| Rsp | (maxtrix)  | 
| modnames | (modnames)  | 
| ... | (any)  | 
Value
(list) 
 list of matrices including generated binary datasets
(1: correct prediction, 0: incorrect prediction) for each subgroup (specificity, sensitivity)
Examples
data <- draw_data_lfc()
head(data)
Sample binary data (single sample)
Description
This function is wrapper for rmvbin.
Usage
draw_data_prb(n = 100, pr = c(0.8, 0.8), R = diag(length(pr)))
Arguments
| n | (numeric)  | 
| pr | (numeric)  | 
| R | (matrix)  | 
Value
(matrix) 
 matrix with n rows and length(pr) columns of randomly generated binary (0, 1) data
Generate binary data (ROC model)
Description
Generate binary data (ROC model)
Usage
draw_data_roc(
  n = 100,
  prev = c(0.5, 0.5),
  random = FALSE,
  m = 10,
  auc = seq(0.85, 0.95, length.out = 5),
  rho = c(0.25, 0.25),
  dist = c("normal", "exponential"),
  e = 10,
  k = 100,
  delta = 0,
  modnames = paste0("model", 1:m),
  corrplot = FALSE,
  ...
)
Arguments
| n | (numeric)  | 
| prev | (numeric)  | 
| random | (logical)  | 
| m | (numeric)  | 
| auc | (numeric)  | 
| rho | (numeric)  | 
| dist | (character)  | 
| e | (numeric)  | 
| k | (numeric)  | 
| delta | (numeric)  | 
| modnames | (character)  | 
| corrplot | (logical)  | 
| ... | (any)  | 
Value
(list) 
 list of matrices including generated binary datasets
(1: correct prediction, 0: incorrect prediction) for each subgroup (specificity, sensitivity)
Examples
data <- draw_data_roc()
head(data)
Evaluate the accuracy of multiple (candidate) classifiers in several subgroups
Description
Assess classification accuracy of multiple classifcation rules stratified by subgroups, e.g. in diseased (sensitivity) and healthy (specificity) individuals.
Usage
evaluate(
  data,
  contrast = define_contrast("raw"),
  benchmark = 0.5,
  alpha = 0.05,
  alternative = c("two.sided", "greater", "less"),
  adjustment = c("none", "bonferroni", "maxt", "bootstrap", "mbeta"),
  transformation = c("none", "logit", "arcsin"),
  analysis = c("co-primary", "full"),
  regu = FALSE,
  pars = list(),
  ...
)
Arguments
| data | (list)  | 
| contrast | ( | 
| benchmark | (numeric)  | 
| alpha | (numeric)  | 
| alternative | (character)  | 
| adjustment | (character)  | 
| transformation | (character)  | 
| analysis | (character)  | 
| regu | (numeric | logical)  | 
| pars | (list)  | 
| ... | (any)  | 
Details
Adjustment methods (adjustment) and additional parameters (pars or ...):
"none" (default): no adjustment for multiplicity
"bonferroni": Bonferroni adjustment
"maxt": maxT adjustment, based on a multivariate normal approximation of the vector of test statistics
"bootstrap": Bootstrap approach
- nboot: number of bootstrap draws (default: 2000) 
- type: type of bootstrap, "pairs" (default) or "wild" 
- dist: residual distribution for wild bootstrap, "Normal" (default) or "Rademacher" 
- proj_est: should bootstrapped estimates for wild bootstrap be projected into unit interval? (default: TRUE) 
- res_tra: type of residual transformation for wild boostrap, 0,1,2 or 3 (default: 0 = no transformation) (for details on res_tra options, see this presentation by James G. MacKinnon (2012) and references therein) 
"mbeta": A heuristic Bayesian approach which is based on a multivariate beta-binomial model.
- nrep: number of posterior draws (default: 5000) 
- lfc_pr: prior probability of 'least-favorable parameter configuration' (default: 1 if analysis == "co-primary", 0 if analysis == "full"). 
Value
(cases_results) 
list of analysis results including (adjusted) confidence intervals and p-values
Examples
#
data <- draw_data_roc()
evaluate(data)
Generate data sets under least favorable parameter configurations
Description
Generates a (simulation) instance, a list of multiple datasets to be processed (analyzed) with process_instance. Ground truth parameters (Sensitvity & Specificity) are least-favorable in the sense that the type-I error rate of the subsequently applied multiple test procedures is maximized.
This function is only needed for simulation via batchtools, not relevant in interactive use!
Usage
generate_instance_lfc(
  nrep = 10,
  n = 100,
  prev = 0.5,
  random = FALSE,
  m = 10,
  se = 0.8,
  sp = 0.8,
  L = 1,
  rhose = 0,
  rhosp = 0,
  cortype = "equi",
  ...,
  data = NULL,
  job = NULL
)
Arguments
| nrep | (numeric)  | 
| n | (numeric)  | 
| prev | (numeric)  | 
| random | (logical)  | 
| m | (numeric)  | 
| se | (numeric)  | 
| sp | (numeric)  | 
| L | (numeric)  | 
| rhose | (numeric)  | 
| rhosp | (numeric)  | 
| cortype | (character)  | 
| ... | (any)  | 
| data | (NULL)  | 
| job | (NULL)  | 
Details
Utilizes same arguments as draw_data_lfc unless mentioned otherwise above.
Value
(list) 
 a single (LFC) simulation instance of length nrep
Generate data sets under realistic parameter configurations
Description
Generates a (simulation) instance, a list of multiple datasets to be processed (analyzed) with process_instance. Ground truth parameters (Sensitvity & Specificity) are initially generated according to a generative model whereby multiple decision rules (with different parameter values) are derived by thresholding multiple biomarkers.
This function is only needed for simulation via batchtools, not relevant in interactive use!
Usage
generate_instance_roc(
  nrep = 10,
  n = 100,
  prev = 0.5,
  random = FALSE,
  m = 10,
  auc = "seq(0.85, 0.95, length.out = 5)",
  rhose = 0.5,
  rhosp = 0.5,
  dist = "normal",
  e = 10,
  k = 100,
  delta = 0,
  ...,
  data = NULL,
  job = NULL
)
Arguments
| nrep | (numeric)  | 
| n | (numeric)  | 
| prev | (numeric)  | 
| random | (logical)  | 
| m | (numeric)  | 
| auc | (numeric)  | 
| rhose | (numeric)  | 
| rhosp | (numeric)  | 
| dist | (character)  | 
| e | (numeric)  | 
| k | (numeric)  | 
| delta | (numeric)  | 
| ... | (any)  | 
| data | (NULL)  | 
| job | (NULL)  | 
Details
Utilizes same arguments as draw_data_roc unless mentioned otherwise above.
Value
(list) 
 a single (ROC) simulation instance of length nrep
Analyze simulated synthetic datasets.
Description
Process data instances, a list of multiple datasets generated via generate_instance_lfc or generate_instance_roc. This function applies evaluate to all datasets.
This function is only needed for simulation via batchtools, not relevant in interactive use!
Usage
process_instance(
  instance = NULL,
  contrast = "cases::define_contrast('raw', NA)",
  benchmark = 0.5,
  alpha = 0.05,
  alternative = "greater",
  adjustment = "none",
  transformation = "none",
  analysis = "co-primary",
  regu = "c(1,1/2,1/4)",
  pars = "list()",
  ...,
  data = NULL,
  job = list(id = NA)
)
Arguments
| instance | (list)  | 
| contrast | ( | 
| benchmark | (numeric)  | 
| alpha | (numeric)  | 
| alternative | (character)  | 
| adjustment | (character)  | 
| transformation | (character)  | 
| analysis | (character)  | 
| regu | (numeric | logical)  | 
| pars | (list)  | 
| ... | (any)  | 
| data | (NULL)  | 
| job | (NULL)  | 
Details
Utilizes same arguments as evaluate unless mentioned otherwise above.
Value
(list) 
 standardized evaluation results
Visualize evaluation results
Description
Currently, this implementation is only intended for situations with ...
- two groups (e.g. healthy (<-> specificity) and diseased (<-> sensitivity)) 
- alternative = "greater" 
- contrast = define_contrast("raw) 
Usage
visualize(x, ...)
Arguments
| x | 
 | 
| ... | 
 | 
Value
a ggplot