inst/shinyApp/ui/15_auc.R

# auc
# UI ----
aucpage <- tabItem(tabName = "auc",
        h2("AUC (Area under the curve)"),
        "The AUC refers to the areas under the Receiver Operating Characteristic (ROC) curve - the grey area in the figure below. The higher the AUC, the better a predictive model performs.",
        plotOutput("auc_fig"),
        tags$br(),
        "Please enter the following",
        sliderInput("auc_auc", "AUC",
                    min = 0, max = 1, value = .5),
        sliderInput("auc_prev", "Prevalence",
                    min = 0, max = 1, value = .4),
        tags$br(),
        "Please enter one of the following",
        uiOutput("auc_resetable_input"),
        actionButton("auc_reset_input",
                     "Reset 'Total sample size' or 'Confidence interval width'"),
        tags$hr(),
        verbatimTextOutput("auc_out"),
        tableOutput("auc_tab"),
        "Code to replicate in R:",
        verbatimTextOutput("auc_code"),
        h3("References"),
        "Hanley, JA and McNeil, BJ (1982) The Meaning and Use of the Area under a Receiver Operating Characteristic (ROC) Curve.",
        tags$i("Radiology"), "148, 29-36")

# SERVER ----
auc_fn <- function(input, code = FALSE){
        db(input, "auc")
        if(is.na(input$auc_n) & is.na(input$auc_ciwidth)) {
                cat("Awaiting 'number of observations' or 'confidence interval width'")
        } else {
                z <- ifelse(is.na(input$auc_n),
                            paste0("conf.width = ", input$auc_ciwidth),
                            paste0("n = ", input$auc_n))
                x <- paste0("prec_auc(auc = ", input$auc_auc,
                            ", prev = ", input$auc_prev,
                            ", ", z, ", conf.level = ", input$conflevel,
                            ")")
                if(code){
                        cat(x)
                } else {
                        eval(parse(text = x))
                }
        }
}

Try the presize package in your browser

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

presize documentation built on March 7, 2023, 8:28 p.m.