R/Bradley1978.R

Defines functions Bradley1978

Documented in Bradley1978

#' Bradley's (1978) empirical robustness interval
#'
#' Robustness interval criteria for empirical detection rate estimates and
#' empirical coverage estimates defined by Bradley (1978).
#' See \code{\link{EDR}} and \code{\link{ECR}} to obtain such estimates.
#'
#' @param rate (optional) numeric vector containing the empirical detection
#'   rate(s) or empirical confidence interval estimates.
#'   If supplied a character vector with elements defined in
#'   \code{out.labels} or a logical vector will be returned indicating whether the
#'   detection rate estimate is considered 'robust'.
#'
#'   When the input is an empirical coverage rate the argument \code{CI} must be
#'   set to \code{TRUE}.
#'
#'   If this input is missing, the interval criteria will be printed to the console
#'
#' @param alpha Type I error rate to evaluated (default is .05)
#'
#' @param type character vector indicating the type of interval classification to use.
#'   Default is 'liberal', however can be 'stringent' to use Bradley's more
#'   stringent robustness criteria
#'
#' @param CI logical; should this robust interval be constructed on empirical detection
#'   rates (\code{FALSE}) or empirical coverage rates (\code{TRUE})?
#'
#' @param out.logical logical; should the output vector be TRUE/FALSE indicating whether
#'   the supplied empirical detection rate/CI should be considered "robust"? Default is
#'   FALSE, in which case the out.labels elements are used instead
#'
#' @param out.labels character vector of length three indicating the classification
#'   labels according to the desired robustness interval
#'
#' @param unname logical; apply \code{\link{unname}} to the results to remove any variable
#'   names?
#'
#' @seealso \code{\link{EDR}}, \code{\link{ECR}}, \code{\link{Serlin2000}}
#'
#' @references
#'
#' Bradley, J. V. (1978). Robustness? \emph{British Journal of Mathematical and
#' Statistical Psychology, 31}, 144-152.
#'
#' Chalmers, R. P., & Adkins, M. C.  (2020). Writing Effective and Reliable Monte Carlo Simulations
#' with the SimDesign Package. \code{The Quantitative Methods for Psychology, 16}(4), 248-280.
#' \doi{10.20982/tqmp.16.4.p248}
#'
#' Sigal, M. J., & Chalmers, R. P. (2016). Play it again: Teaching statistics with Monte
#' Carlo simulation. \code{Journal of Statistics Education, 24}(3), 136-156.
#' \doi{10.1080/10691898.2016.1246953}
#'
#' @export
#'
#' @author Phil Chalmers \email{rphilip.chalmers@@gmail.com}
#'
#' @examples
#'
#' # interval criteria used for empirical detection rates
#' Bradley1978()
#' Bradley1978(type = 'stringent')
#' Bradley1978(alpha = .01, type = 'stringent')
#'
#' # intervals applied to empirical detection rate estimates
#' edr <- c(test1 = .05, test2 = .027, test3 = .051, test4 = .076, test5 = .024)
#'
#' Bradley1978(edr)
#' Bradley1978(edr, out.logical=TRUE) # is robust?
#'
#' #####
#' # interval criteria used for coverage estimates
#'
#' Bradley1978(CI = TRUE)
#' Bradley1978(CI = TRUE, type = 'stringent')
#' Bradley1978(CI = TRUE, alpha = .01, type = 'stringent')
#'
#' # intervals applied to empirical coverage rate estimates
#' ecr <- c(test1 = .950, test2 = .973, test3 = .949, test4 = .924, test5 = .976)
#'
#' Bradley1978(ecr, CI=TRUE)
#' Bradley1978(ecr, CI=TRUE, out.logical=TRUE) # is robust?
#'
Bradley1978 <- function(rate, alpha = .05, type = 'liberal', CI = FALSE,
                        out.logical = FALSE,
                        out.labels = c('conservative', 'robust', 'liberal'),
                        unname = FALSE){
    stopifnot(type %in% c('liberal', 'stringent'))
    stopifnot(length(alpha) == 1L)
    stopifnot(alpha <= 1 && alpha >= 0)
    if(type == 'stringent') bnds <- c(0.9, 1.1)
    if(type == 'liberal') bnds <- c(.5, 1.5)
    bounds <- bnds * alpha
    if(CI){
        bounds <- sort(1 - bounds)
        out.labels <- c(out.labels[3L:1L])
    }
    if(missing(rate)){
        ret <- bounds
        names(ret) <- paste0(type, c('.lower', '.upper'))
    } else {
        if(is.data.frame(rate) || is.matrix(rate)) rate <- as.numeric(rate)
        stopifnot(all(rate <= 1 & rate >= 0))
        if(out.logical){
            ret <- rate >= bounds[1L] & rate <= bounds[2]
        } else {
            ret <- rep(out.labels[2], length(rate))
            names(ret) <- names(rate)
            ret[rate < bounds[1L]] <- out.labels[1L]
            ret[rate > bounds[2L]] <- out.labels[3L]
        }
        if(unname) ret <- unname(ret)
    }
    ret
}

Try the SimDesign package in your browser

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

SimDesign documentation built on Oct. 17, 2023, 5:07 p.m.