1
0
mirror of https://github.com/msberends/AMR.git synced 2025-10-25 13:16:19 +02:00

(v2.1.1.9190) antibiotics deprecation in antibiogram()

This commit is contained in:
2025-03-09 10:41:11 +01:00
parent c7af397edf
commit a2c2be23c1
26 changed files with 203 additions and 180 deletions

View File

@@ -65,6 +65,7 @@ jobs:
# do not check these folders # do not check these folders
rm -rf data-raw rm -rf data-raw
rm -rf tests rm -rf tests
rm -rf vignettes
- name: Lint - name: Lint
run: | run: |
@@ -76,7 +77,7 @@ jobs:
linters <- linters[!grepl("^(closed_curly|open_curly|paren_brace|semicolon_terminator|consecutive_stopifnot|no_tab|single_quotes|unnecessary_nested_if|unneeded_concatenation)_linter$", linters)] linters <- linters[!grepl("^(closed_curly|open_curly|paren_brace|semicolon_terminator|consecutive_stopifnot|no_tab|single_quotes|unnecessary_nested_if|unneeded_concatenation)_linter$", linters)]
linters <- linters[linters != "linter"] linters <- linters[linters != "linter"]
# and the ones we find unnnecessary # and the ones we find unnnecessary
linters <- linters[!grepl("^(extraction_operator|implicit_integer|line_length|object_length|object_name|object_usage|nonportable_path|is)_linter$", linters)] linters <- linters[!grepl("^(commented_code|extraction_operator|implicit_integer|indentation|line_length|namespace|nonportable_path|object_length|object_name|object_usage|is)_linter$", linters)]
# put the functions in a list # put the functions in a list
linters_list <- lapply(linters, function(l) eval(parse(text = paste0("lintr::", l, "()")), envir = asNamespace("lintr"))) linters_list <- lapply(linters, function(l) eval(parse(text = paste0("lintr::", l, "()")), envir = asNamespace("lintr")))
names(linters_list) <- linters names(linters_list) <- linters

View File

@@ -1,6 +1,6 @@
Package: AMR Package: AMR
Version: 2.1.1.9189 Version: 2.1.1.9190
Date: 2025-03-07 Date: 2025-03-09
Title: Antimicrobial Resistance Data Analysis Title: Antimicrobial Resistance Data Analysis
Description: Functions to simplify and standardise antimicrobial resistance (AMR) Description: Functions to simplify and standardise antimicrobial resistance (AMR)
data analysis and to work with microbial and antimicrobial properties by data analysis and to work with microbial and antimicrobial properties by

View File

@@ -1,4 +1,4 @@
# AMR 2.1.1.9189 # AMR 2.1.1.9190
*(this beta version will eventually become v3.0. We're happy to reach a new major milestone soon, which will be all about the new One Health support! Install this beta using [the instructions here](https://msberends.github.io/AMR/#latest-development-version).)* *(this beta version will eventually become v3.0. We're happy to reach a new major milestone soon, which will be all about the new One Health support! Install this beta using [the instructions here](https://msberends.github.io/AMR/#latest-development-version).)*
@@ -48,8 +48,9 @@ This package now supports not only tools for AMR data analysis in clinical setti
* To get quantitative values, `as.double()` on a `sir` object will return 1 for S, 2 for SDD/I, and 3 for R (NI will become `NA`). Other functions using `sir` classes (e.g., `summary()`) are updated to reflect the change to contain NI and SDD. * To get quantitative values, `as.double()` on a `sir` object will return 1 for S, 2 for SDD/I, and 3 for R (NI will become `NA`). Other functions using `sir` classes (e.g., `summary()`) are updated to reflect the change to contain NI and SDD.
* Fix for `conserve_capped_values`, which now again works as expected: in MIC values, `<x` will always be S, `>x` will always be R * Fix for `conserve_capped_values`, which now again works as expected: in MIC values, `<x` will always be S, `>x` will always be R
* `antibiogram()` function * `antibiogram()` function
* New argument `formatting_type` to set any of the 22 options for the formatting of all 'cells'. This defaults to `10` for non-WISCA and `14` for WISCA, changing the output of antibiograms to cells with more info. * Argument `antibiotics` has been renamed to `antimicrobials`. Using `antibiotics` will still work, but now returns a warning.
* For this reason, `add_total_n` is now `FALSE` at default since the denominators are added to the cells * Added argument `formatting_type` to set any of the 22 options for the formatting of all 'cells'. This defaults to `18` for non-WISCA and `14` for WISCA, changing the output of antibiograms to cells with more info.
* For this reason, `add_total_n` is now `FALSE` at default since the denominators are added to the cells for non-WISCA. For WISCA, the denominator is not useful anyway.
* The `ab_transform` argument now defaults to `"name"`, displaying antibiotic column names instead of codes * The `ab_transform` argument now defaults to `"name"`, displaying antibiotic column names instead of codes
* Antimicrobial selectors (previously: *antibiotic selectors*) * Antimicrobial selectors (previously: *antibiotic selectors*)
* 'Antibiotic selectors' are now called 'antimicrobial selectors' since their scope is broader than just antibiotics. All documentation have been updated, and `ab_class()` and `ab_selector()` have been replaced with `amr_class()` and `amr_selector()`. The old functions are now deprecated and will be removed in a future version. * 'Antibiotic selectors' are now called 'antimicrobial selectors' since their scope is broader than just antibiotics. All documentation have been updated, and `ab_class()` and `ab_selector()` have been replaced with `amr_class()` and `amr_selector()`. The old functions are now deprecated and will be removed in a future version.

View File

@@ -1,6 +1,6 @@
Metadata-Version: 2.2 Metadata-Version: 2.2
Name: AMR Name: AMR
Version: 2.1.1.9189 Version: 2.1.1.9190
Summary: A Python wrapper for the AMR R package Summary: A Python wrapper for the AMR R package
Home-page: https://github.com/msberends/AMR Home-page: https://github.com/msberends/AMR
Author: Matthijs Berends Author: Matthijs Berends

Binary file not shown.

Binary file not shown.

View File

@@ -2,7 +2,7 @@ from setuptools import setup, find_packages
setup( setup(
name='AMR', name='AMR',
version='2.1.1.9189', version='2.1.1.9190',
packages=find_packages(), packages=find_packages(),
install_requires=[ install_requires=[
'rpy2', 'rpy2',

View File

@@ -34,7 +34,7 @@
#' #'
#' Adhering to previously described approaches (see *Source*) and especially the Bayesian WISCA model (Weighted-Incidence Syndromic Combination Antibiogram) by Bielicki *et al.*, these functions provide flexible output formats including plots and tables, ideal for integration with R Markdown and Quarto reports. #' Adhering to previously described approaches (see *Source*) and especially the Bayesian WISCA model (Weighted-Incidence Syndromic Combination Antibiogram) by Bielicki *et al.*, these functions provide flexible output formats including plots and tables, ideal for integration with R Markdown and Quarto reports.
#' @param x a [data.frame] containing at least a column with microorganisms and columns with antimicrobial results (class 'sir', see [as.sir()]) #' @param x a [data.frame] containing at least a column with microorganisms and columns with antimicrobial results (class 'sir', see [as.sir()])
#' @param antibiotics vector of any antimicrobial name or code (will be evaluated with [as.ab()], column name of `x`, or (any combinations of) [antimicrobial selectors][antimicrobial_selectors] such as [aminoglycosides()] or [carbapenems()]. For combination antibiograms, this can also be set to values separated with `"+"`, such as `"TZP+TOB"` or `"cipro + genta"`, given that columns resembling such antimicrobials exist in `x`. See *Examples*. #' @param antimicrobials vector of any antimicrobial name or code (will be evaluated with [as.ab()], column name of `x`, or (any combinations of) [antimicrobial selectors][antimicrobial_selectors] such as [aminoglycosides()] or [carbapenems()]. For combination antibiograms, this can also be set to values separated with `"+"`, such as `"TZP+TOB"` or `"cipro + genta"`, given that columns resembling such antimicrobials exist in `x`. See *Examples*.
#' @param mo_transform a character to transform microorganism input - must be `"name"`, `"shortname"` (default), `"gramstain"`, or one of the column names of the [microorganisms] data set: `r vector_or(colnames(microorganisms), sort = FALSE, quotes = TRUE)`. Can also be `NULL` to not transform the input or `NA` to consider all microorganisms 'unknown'. #' @param mo_transform a character to transform microorganism input - must be `"name"`, `"shortname"` (default), `"gramstain"`, or one of the column names of the [microorganisms] data set: `r vector_or(colnames(microorganisms), sort = FALSE, quotes = TRUE)`. Can also be `NULL` to not transform the input or `NA` to consider all microorganisms 'unknown'.
#' @param ab_transform a character to transform antimicrobial input - must be one of the column names of the [antimicrobials] data set (defaults to `"name"`): `r vector_or(colnames(antimicrobials), sort = FALSE, quotes = TRUE)`. Can also be `NULL` to not transform the input. #' @param ab_transform a character to transform antimicrobial input - must be one of the column names of the [antimicrobials] data set (defaults to `"name"`): `r vector_or(colnames(antimicrobials), sort = FALSE, quotes = TRUE)`. Can also be `NULL` to not transform the input.
#' @param syndromic_group a column name of `x`, or values calculated to split rows of `x`, e.g. by using [ifelse()] or [`case_when()`][dplyr::case_when()]. See *Examples*. #' @param syndromic_group a column name of `x`, or values calculated to split rows of `x`, e.g. by using [ifelse()] or [`case_when()`][dplyr::case_when()]. See *Examples*.
@@ -107,7 +107,7 @@
#' #'
#' ```r #' ```r
#' antibiogram(your_data, #' antibiogram(your_data,
#' antibiotics = "TZP") #' antimicrobials = "TZP")
#' ``` #' ```
#' #'
#' 2. **Combination Antibiogram** #' 2. **Combination Antibiogram**
@@ -118,7 +118,7 @@
#' #'
#' ```r #' ```r
#' antibiogram(your_data, #' antibiogram(your_data,
#' antibiotics = c("TZP", "TZP+TOB", "TZP+GEN")) #' antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"))
#' ``` #' ```
#' #'
#' 3. **Syndromic Antibiogram** #' 3. **Syndromic Antibiogram**
@@ -129,7 +129,7 @@
#' #'
#' ```r #' ```r
#' antibiogram(your_data, #' antibiogram(your_data,
#' antibiotics = penicillins(), #' antimicrobials = penicillins(),
#' syndromic_group = "ward") #' syndromic_group = "ward")
#' ``` #' ```
#' #'
@@ -141,12 +141,12 @@
#' #'
#' ```r #' ```r
#' antibiogram(your_data, #' antibiogram(your_data,
#' antibiotics = c("TZP", "TZP+TOB", "TZP+GEN"), #' antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"),
#' wisca = TRUE) #' wisca = TRUE)
#' #'
#' # this is equal to: #' # this is equal to:
#' wisca(your_data, #' wisca(your_data,
#' antibiotics = c("TZP", "TZP+TOB", "TZP+GEN")) #' antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"))
#' ``` #' ```
#' #'
#' WISCA uses a sophisticated Bayesian decision model to combine both local and pooled antimicrobial resistance data. This approach not only evaluates local patterns but can also draw on multi-centre datasets to improve regimen accuracy, even in low-incidence infections like paediatric bloodstream infections (BSIs). #' WISCA uses a sophisticated Bayesian decision model to combine both local and pooled antimicrobial resistance data. This approach not only evaluates local patterns but can also draw on multi-centre datasets to improve regimen accuracy, even in low-incidence infections like paediatric bloodstream infections (BSIs).
@@ -161,7 +161,7 @@
#' library(dplyr) #' library(dplyr)
#' your_data %>% #' your_data %>%
#' group_by(has_sepsis, is_neonate, sex) %>% #' group_by(has_sepsis, is_neonate, sex) %>%
#' wisca(antibiotics = c("TZP", "TZP+TOB", "TZP+GEN")) #' wisca(antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"))
#' ``` #' ```
#' #'
#' ### Stepped Approach for Clinical Insight #' ### Stepped Approach for Clinical Insight
@@ -177,12 +177,12 @@
#' #'
#' ```r #' ```r
#' antibiogram(your_data, #' antibiogram(your_data,
#' antibiotics = selected_regimens, #' antimicrobials = selected_regimens,
#' mo_transform = NA) # all pathogens set to `NA` #' mo_transform = NA) # all pathogens set to `NA`
#' #'
#' # preferred: use WISCA #' # preferred: use WISCA
#' wisca(your_data, #' wisca(your_data,
#' antibiotics = selected_regimens) #' antimicrobials = selected_regimens)
#' ``` #' ```
#' #'
#' 2. **Refinement with Gram Stain Results** #' 2. **Refinement with Gram Stain Results**
@@ -194,7 +194,7 @@
#' #'
#' ```r #' ```r
#' antibiogram(your_data, #' antibiogram(your_data,
#' antibiotics = selected_regimens, #' antimicrobials = selected_regimens,
#' mo_transform = "gramstain") # all pathogens set to Gram-pos/Gram-neg #' mo_transform = "gramstain") # all pathogens set to Gram-pos/Gram-neg
#' ``` #' ```
#' #'
@@ -207,7 +207,7 @@
#' #'
#' ```r #' ```r
#' antibiogram(your_data, #' antibiogram(your_data,
#' antibiotics = selected_regimens, #' antimicrobials = selected_regimens,
#' mo_transform = "shortname") # all pathogens set to 'G. species', e.g., E. coli #' mo_transform = "shortname") # all pathogens set to 'G. species', e.g., E. coli
#' ``` #' ```
#' #'
@@ -301,17 +301,17 @@
#' # Traditional antibiogram ---------------------------------------------- #' # Traditional antibiogram ----------------------------------------------
#' #'
#' antibiogram(example_isolates, #' antibiogram(example_isolates,
#' antibiotics = c(aminoglycosides(), carbapenems()) #' antimicrobials = c(aminoglycosides(), carbapenems())
#' ) #' )
#' #'
#' antibiogram(example_isolates, #' antibiogram(example_isolates,
#' antibiotics = aminoglycosides(), #' antimicrobials = aminoglycosides(),
#' ab_transform = "atc", #' ab_transform = "atc",
#' mo_transform = "gramstain" #' mo_transform = "gramstain"
#' ) #' )
#' #'
#' antibiogram(example_isolates, #' antibiogram(example_isolates,
#' antibiotics = carbapenems(), #' antimicrobials = carbapenems(),
#' ab_transform = "name", #' ab_transform = "name",
#' mo_transform = "name" #' mo_transform = "name"
#' ) #' )
@@ -319,15 +319,15 @@
#' #'
#' # Combined antibiogram ------------------------------------------------- #' # Combined antibiogram -------------------------------------------------
#' #'
#' # combined antibiotics yield higher empiric coverage #' # combined antimicrobials yield higher empiric coverage
#' antibiogram(example_isolates, #' antibiogram(example_isolates,
#' antibiotics = c("TZP", "TZP+TOB", "TZP+GEN"), #' antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"),
#' mo_transform = "gramstain" #' mo_transform = "gramstain"
#' ) #' )
#' #'
#' # names of antibiotics do not need to resemble columns exactly: #' # names of antimicrobials do not need to resemble columns exactly:
#' antibiogram(example_isolates, #' antibiogram(example_isolates,
#' antibiotics = c("Cipro", "cipro + genta"), #' antimicrobials = c("Cipro", "cipro + genta"),
#' mo_transform = "gramstain", #' mo_transform = "gramstain",
#' ab_transform = "name", #' ab_transform = "name",
#' sep = " & " #' sep = " & "
@@ -338,7 +338,7 @@
#' #'
#' # the data set could contain a filter for e.g. respiratory specimens #' # the data set could contain a filter for e.g. respiratory specimens
#' antibiogram(example_isolates, #' antibiogram(example_isolates,
#' antibiotics = c(aminoglycosides(), carbapenems()), #' antimicrobials = c(aminoglycosides(), carbapenems()),
#' syndromic_group = "ward" #' syndromic_group = "ward"
#' ) #' )
#' #'
@@ -348,7 +348,7 @@
#' # with a custom language, though this will be determined automatically #' # with a custom language, though this will be determined automatically
#' # (i.e., this table will be in Spanish on Spanish systems) #' # (i.e., this table will be in Spanish on Spanish systems)
#' antibiogram(ex1, #' antibiogram(ex1,
#' antibiotics = aminoglycosides(), #' antimicrobials = aminoglycosides(),
#' ab_transform = "name", #' ab_transform = "name",
#' syndromic_group = ifelse(ex1$ward == "ICU", #' syndromic_group = ifelse(ex1$ward == "ICU",
#' "UCI", "No UCI" #' "UCI", "No UCI"
@@ -361,7 +361,7 @@
#' #'
#' # WISCA are not stratified by species, but rather on syndromes #' # WISCA are not stratified by species, but rather on syndromes
#' antibiogram(example_isolates, #' antibiogram(example_isolates,
#' antibiotics = c("TZP", "TZP+TOB", "TZP+GEN"), #' antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"),
#' syndromic_group = "ward", #' syndromic_group = "ward",
#' wisca = TRUE #' wisca = TRUE
#' ) #' )
@@ -370,7 +370,7 @@
#' # Print the output for R Markdown / Quarto ----------------------------- #' # Print the output for R Markdown / Quarto -----------------------------
#' #'
#' ureido <- antibiogram(example_isolates, #' ureido <- antibiogram(example_isolates,
#' antibiotics = ureidopenicillins(), #' antimicrobials = ureidopenicillins(),
#' syndromic_group = "ward", #' syndromic_group = "ward",
#' wisca = TRUE #' wisca = TRUE
#' ) #' )
@@ -385,11 +385,11 @@
#' # Generate plots with ggplot2 or base R -------------------------------- #' # Generate plots with ggplot2 or base R --------------------------------
#' #'
#' ab1 <- antibiogram(example_isolates, #' ab1 <- antibiogram(example_isolates,
#' antibiotics = c("AMC", "CIP", "TZP", "TZP+TOB"), #' antimicrobials = c("AMC", "CIP", "TZP", "TZP+TOB"),
#' mo_transform = "gramstain" #' mo_transform = "gramstain"
#' ) #' )
#' ab2 <- antibiogram(example_isolates, #' ab2 <- antibiogram(example_isolates,
#' antibiotics = c("AMC", "CIP", "TZP", "TZP+TOB"), #' antimicrobials = c("AMC", "CIP", "TZP", "TZP+TOB"),
#' mo_transform = "gramstain", #' mo_transform = "gramstain",
#' syndromic_group = "ward" #' syndromic_group = "ward"
#' ) #' )
@@ -405,7 +405,7 @@
#' plot(ab2) #' plot(ab2)
#' } #' }
antibiogram <- function(x, antibiogram <- function(x,
antibiotics = where(is.sir), antimicrobials = where(is.sir),
mo_transform = "shortname", mo_transform = "shortname",
ab_transform = "name", ab_transform = "name",
syndromic_group = NULL, syndromic_group = NULL,
@@ -422,14 +422,15 @@ antibiogram <- function(x,
simulations = 1000, simulations = 1000,
conf_interval = 0.95, conf_interval = 0.95,
interval_side = "two-tailed", interval_side = "two-tailed",
info = interactive()) { info = interactive(),
...) {
UseMethod("antibiogram") UseMethod("antibiogram")
} }
#' @method antibiogram default #' @method antibiogram default
#' @export #' @export
antibiogram.default <- function(x, antibiogram.default <- function(x,
antibiotics = where(is.sir), antimicrobials = where(is.sir),
mo_transform = "shortname", mo_transform = "shortname",
ab_transform = "name", ab_transform = "name",
syndromic_group = NULL, syndromic_group = NULL,
@@ -446,7 +447,8 @@ antibiogram.default <- function(x,
simulations = 1000, simulations = 1000,
conf_interval = 0.95, conf_interval = 0.95,
interval_side = "two-tailed", interval_side = "two-tailed",
info = interactive()) { info = interactive(),
...) {
meet_criteria(x, allow_class = "data.frame") meet_criteria(x, allow_class = "data.frame")
x <- ascertain_sir_classes(x, "x") x <- ascertain_sir_classes(x, "x")
meet_criteria(wisca, allow_class = "logical", has_length = 1) meet_criteria(wisca, allow_class = "logical", has_length = 1)
@@ -456,6 +458,10 @@ antibiogram.default <- function(x,
} }
mo_transform <- function(x) suppressMessages(suppressWarnings(paste(mo_genus(x, keep_synonyms = TRUE, language = NULL), mo_species(x, keep_synonyms = TRUE, language = NULL)))) mo_transform <- function(x) suppressMessages(suppressWarnings(paste(mo_genus(x, keep_synonyms = TRUE, language = NULL), mo_species(x, keep_synonyms = TRUE, language = NULL))))
} }
if ("antibiotics" %in% names(list(...))) {
deprecation_warning("antibiotics", "antimicrobials", fn = "antibiogram", is_argument = TRUE)
antimicrobials <- list(...)$antibiotics
}
if (!is.function(mo_transform)) { if (!is.function(mo_transform)) {
meet_criteria(mo_transform, allow_class = "character", has_length = 1, is_in = c("name", "shortname", "gramstain", colnames(AMR::microorganisms)), allow_NULL = TRUE, allow_NA = TRUE) meet_criteria(mo_transform, allow_class = "character", has_length = 1, is_in = c("name", "shortname", "gramstain", colnames(AMR::microorganisms)), allow_NULL = TRUE, allow_NA = TRUE)
} }
@@ -514,17 +520,17 @@ antibiogram.default <- function(x,
has_syndromic_group <- FALSE has_syndromic_group <- FALSE
} }
# get antibiotics # get antimicrobials
ab_trycatch <- tryCatch(colnames(suppressWarnings(x[, antibiotics, drop = FALSE])), error = function(e) NULL) ab_trycatch <- tryCatch(colnames(suppressWarnings(x[, antimicrobials, drop = FALSE])), error = function(e) NULL)
if (is.null(ab_trycatch)) { if (is.null(ab_trycatch)) {
stop_ifnot(is.character(suppressMessages(antibiotics)), "`antibiotics` must be an antimicrobial selector, or a character vector.") stop_ifnot(is.character(suppressMessages(antimicrobials)), "`antimicrobials` must be an antimicrobial selector, or a character vector.")
antibiotics.bak <- antibiotics antimicrobials.bak <- antimicrobials
# split antibiotics on separator and make it a list # split antimicrobials on separator and make it a list
antibiotics <- strsplit(gsub(" ", "", antibiotics), "+", fixed = TRUE) antimicrobials <- strsplit(gsub(" ", "", antimicrobials), "+", fixed = TRUE)
# get available antibiotics in data set # get available antimicrobials in data set
df_ab <- get_column_abx(x, verbose = FALSE, info = FALSE) df_ab <- get_column_abx(x, verbose = FALSE, info = FALSE)
# get antibiotics from user # get antimicrobials from user
user_ab <- suppressMessages(suppressWarnings(lapply(antibiotics, as.ab, flag_multiple_results = FALSE, info = FALSE))) user_ab <- suppressMessages(suppressWarnings(lapply(antimicrobials, as.ab, flag_multiple_results = FALSE, info = FALSE)))
non_existing <- character(0) non_existing <- character(0)
user_ab <- lapply(user_ab, function(x) { user_ab <- lapply(user_ab, function(x) {
out <- unname(df_ab[match(x, names(df_ab))]) out <- unname(df_ab[match(x, names(df_ab))])
@@ -535,14 +541,14 @@ antibiogram.default <- function(x,
user_ab <- user_ab[unlist(lapply(user_ab, length)) > 0] user_ab <- user_ab[unlist(lapply(user_ab, length)) > 0]
if (length(non_existing) > 0) { if (length(non_existing) > 0) {
warning_("The following antibiotics were not available and ignored: ", vector_and(ab_name(non_existing, language = NULL, tolower = TRUE), quotes = FALSE)) warning_("The following antimicrobials were not available and ignored: ", vector_and(ab_name(non_existing, language = NULL, tolower = TRUE), quotes = FALSE))
} }
# make list unique # make list unique
antibiotics <- unique(user_ab) antimicrobials <- unique(user_ab)
# go through list to set AMR in combinations # go through list to set AMR in combinations
for (i in seq_len(length(antibiotics))) { for (i in seq_len(length(antimicrobials))) {
abx <- antibiotics[[i]] abx <- antimicrobials[[i]]
for (ab in abx) { for (ab in abx) {
# make sure they are SIR columns # make sure they are SIR columns
x[, ab] <- as.sir(x[, ab, drop = TRUE]) x[, ab] <- as.sir(x[, ab, drop = TRUE])
@@ -568,20 +574,20 @@ antibiogram.default <- function(x,
)) ))
} }
} }
antibiotics[[i]] <- new_colname antimicrobials[[i]] <- new_colname
} }
antibiotics <- unlist(antibiotics) antimicrobials <- unlist(antimicrobials)
} else { } else {
antibiotics <- ab_trycatch antimicrobials <- ab_trycatch
} }
if (isTRUE(has_syndromic_group)) { if (isTRUE(has_syndromic_group)) {
out <- x %pm>% out <- x %pm>%
pm_select(.syndromic_group, .mo, antibiotics) %pm>% pm_select(.syndromic_group, .mo, antimicrobials) %pm>%
pm_group_by(.syndromic_group) pm_group_by(.syndromic_group)
} else { } else {
out <- x %pm>% out <- x %pm>%
pm_select(.mo, antibiotics) pm_select(.mo, antimicrobials)
} }
@@ -613,8 +619,6 @@ antibiogram.default <- function(x,
if (isTRUE(info) && mins > 0) { if (isTRUE(info) && mins > 0) {
message_("NOTE: ", mins, " combinations had less than `minimum = ", minimum, "` results and were ignored", add_fn = font_red) message_("NOTE: ", mins, " combinations had less than `minimum = ", minimum, "` results and were ignored", add_fn = font_red)
} }
} else if (isTRUE(info)) {
warning_("Number of tested isolates per regimen should exceed ", minimum, " for each species. Coverage estimates might be inaccurate.", call = FALSE)
} }
} }
if (NROW(out) == 0) { if (NROW(out) == 0) {
@@ -678,6 +682,10 @@ antibiogram.default <- function(x,
n_susceptible = sum(n_susceptible, na.rm = TRUE) n_susceptible = sum(n_susceptible, na.rm = TRUE)
) )
if (any(out_wisca$n_tested < minimum, na.rm = TRUE) && message_not_thrown_before("antibiogram", wisca)) {
warning_("Number of tested isolates should exceed ", minimum, " for each regimen (and group). WISCA coverage estimates might be inaccurate.", call = FALSE)
}
out_wisca$p_susceptible <- out_wisca$n_susceptible / out_wisca$n_tested out_wisca$p_susceptible <- out_wisca$n_susceptible / out_wisca$n_tested
if (isTRUE(has_syndromic_group)) { if (isTRUE(has_syndromic_group)) {
@@ -690,8 +698,8 @@ antibiogram.default <- function(x,
# create the WISCA parameters, including our priors/posteriors # create the WISCA parameters, including our priors/posteriors
out$gamma_posterior <- NA_real_ out$gamma_posterior <- NA_real_
out$beta_posterior1 <- NA_real_ out$beta_posterior_1 <- NA_real_
out$beta_posterior2 <- NA_real_ out$beta_posterior_2 <- NA_real_
for (i in seq_len(NROW(out))) { for (i in seq_len(NROW(out))) {
if (out$n_tested[i] == 0) { if (out$n_tested[i] == 0) {
@@ -699,10 +707,22 @@ antibiogram.default <- function(x,
} }
out_current <- out[i, , drop = FALSE] out_current <- out[i, , drop = FALSE]
priors <- calculate_priors(out_current, combine_SI = combine_SI)
out$gamma_posterior[i] <- priors$gamma_posterior ## calculate priors ----
out$beta_posterior1[i] <- priors$beta_posterior_1 # pathogen incidence (Dirichlet distribution)
out$beta_posterior2[i] <- priors$beta_posterior_2 gamma_prior <- rep(1, length(unique(out_current$mo))) # Dirichlet prior
gamma_posterior <- gamma_prior + out_current$n_total # Posterior parameters
# regimen susceptibility (Beta distribution)
beta_prior <- rep(1, length(unique(out_current$mo))) # Beta prior
r <- out_current$n_susceptible
n <- out_current$n_tested
beta_posterior_1 <- beta_prior + r # Posterior alpha
beta_posterior_2 <- beta_prior + (n - r) # Posterior beta
out$gamma_posterior[i] <- gamma_posterior
out$beta_posterior_1[i] <- beta_posterior_1
out$beta_posterior_2[i] <- beta_posterior_2
} }
wisca_parameters <- out wisca_parameters <- out
@@ -742,8 +762,8 @@ antibiogram.default <- function(x,
random_susceptibity <- stats::runif(1, min = 0, max = 1) random_susceptibity <- stats::runif(1, min = 0, max = 1)
simulated_susceptibility <- stats::qbeta( simulated_susceptibility <- stats::qbeta(
p = random_susceptibity, p = random_susceptibity,
shape1 = params_current$beta_posterior1, shape1 = params_current$beta_posterior_1,
shape2 = params_current$beta_posterior2 shape2 = params_current$beta_posterior_2
) )
sum(simulated_incidence * simulated_susceptibility, na.rm = TRUE) sum(simulated_incidence * simulated_susceptibility, na.rm = TRUE)
}) })
@@ -825,6 +845,9 @@ antibiogram.default <- function(x,
# 20. 5% (4-6%,15/300) # 20. 5% (4-6%,15/300)
# 21. 5 (4-6,N=15/300) # 21. 5 (4-6,N=15/300)
# 22. 5% (4-6%,N=15/300) # 22. 5% (4-6%,N=15/300)
if (wisca == TRUE && !formatting_type %in% c(1, 2, 13, 14) && info == TRUE && message_not_thrown_before("antibiogram", wisca, formatting_type)) {
message_("Using WISCA with a `formatting_type` that includes the denominator is not useful")
}
if (formatting_type == 1) out <- out %pm>% pm_summarise(out_value = round(coverage * 100, digits = digits)) if (formatting_type == 1) out <- out %pm>% pm_summarise(out_value = round(coverage * 100, digits = digits))
if (formatting_type == 2) out <- out %pm>% pm_summarise(out_value = n_susceptible) if (formatting_type == 2) out <- out %pm>% pm_summarise(out_value = n_susceptible)
if (formatting_type == 3) out <- out %pm>% pm_summarise(out_value = n_tested) if (formatting_type == 3) out <- out %pm>% pm_summarise(out_value = n_tested)
@@ -847,8 +870,9 @@ antibiogram.default <- function(x,
if (formatting_type == 20) out <- out %pm>% pm_summarise(out_value = paste0(round(coverage * 100, digits = digits), "% (", round(lower_ci * 100, digits = digits), "-", round(upper_ci * 100, digits = digits), "%,", n_susceptible, "/", n_tested, ")")) if (formatting_type == 20) out <- out %pm>% pm_summarise(out_value = paste0(round(coverage * 100, digits = digits), "% (", round(lower_ci * 100, digits = digits), "-", round(upper_ci * 100, digits = digits), "%,", n_susceptible, "/", n_tested, ")"))
if (formatting_type == 21) out <- out %pm>% pm_summarise(out_value = paste0(round(coverage * 100, digits = digits), " (", round(lower_ci * 100, digits = digits), "-", round(upper_ci * 100, digits = digits), ",N=", n_susceptible, "/", n_tested, ")")) if (formatting_type == 21) out <- out %pm>% pm_summarise(out_value = paste0(round(coverage * 100, digits = digits), " (", round(lower_ci * 100, digits = digits), "-", round(upper_ci * 100, digits = digits), ",N=", n_susceptible, "/", n_tested, ")"))
if (formatting_type == 22) out <- out %pm>% pm_summarise(out_value = paste0(round(coverage * 100, digits = digits), "% (", round(lower_ci * 100, digits = digits), "-", round(upper_ci * 100, digits = digits), "%,N=", n_susceptible, "/", n_tested, ")")) if (formatting_type == 22) out <- out %pm>% pm_summarise(out_value = paste0(round(coverage * 100, digits = digits), "% (", round(lower_ci * 100, digits = digits), "-", round(upper_ci * 100, digits = digits), "%,N=", n_susceptible, "/", n_tested, ")"))
out$out_value[out$out_value %like% "^NA"] <- NA_character_
# transform names of antibiotics # transform names of antimicrobials
ab_naming_function <- function(x, t, l, s) { ab_naming_function <- function(x, t, l, s) {
x <- strsplit(x, s, fixed = TRUE) x <- strsplit(x, s, fixed = TRUE)
out <- character(length = length(x)) out <- character(length = length(x))
@@ -979,7 +1003,7 @@ antibiogram.default <- function(x,
#' @method antibiogram grouped_df #' @method antibiogram grouped_df
#' @export #' @export
antibiogram.grouped_df <- function(x, antibiogram.grouped_df <- function(x,
antibiotics = where(is.sir), antimicrobials = where(is.sir),
mo_transform = NULL, mo_transform = NULL,
ab_transform = "name", ab_transform = "name",
syndromic_group = NULL, syndromic_group = NULL,
@@ -996,7 +1020,8 @@ antibiogram.grouped_df <- function(x,
simulations = 1000, simulations = 1000,
conf_interval = 0.95, conf_interval = 0.95,
interval_side = "two-tailed", interval_side = "two-tailed",
info = interactive()) { info = interactive(),
...) {
stop_ifnot(is.null(mo_transform), "`mo_transform` must not be set if creating an antibiogram using a grouped tibble. The groups will become the variables over which the antimicrobials are calculated, which could include the pathogen information (though not necessary). Nonetheless, this makes `mo_transform` redundant.", call = FALSE) stop_ifnot(is.null(mo_transform), "`mo_transform` must not be set if creating an antibiogram using a grouped tibble. The groups will become the variables over which the antimicrobials are calculated, which could include the pathogen information (though not necessary). Nonetheless, this makes `mo_transform` redundant.", call = FALSE)
stop_ifnot(is.null(syndromic_group), "`syndromic_group` must not be set if creating an antibiogram using a grouped tibble. The groups will become the variables over which the antimicrobials are calculated, making `syndromic_groups` redundant.", call = FALSE) stop_ifnot(is.null(syndromic_group), "`syndromic_group` must not be set if creating an antibiogram using a grouped tibble. The groups will become the variables over which the antimicrobials are calculated, making `syndromic_groups` redundant.", call = FALSE)
groups <- attributes(x)$groups groups <- attributes(x)$groups
@@ -1020,7 +1045,7 @@ antibiogram.grouped_df <- function(x,
next next
} }
new_out <- antibiogram(as.data.frame(x)[rows, , drop = FALSE], new_out <- antibiogram(as.data.frame(x)[rows, , drop = FALSE],
antibiotics = antibiotics, antimicrobials = antimicrobials,
mo_transform = NULL, mo_transform = NULL,
ab_transform = ab_transform, ab_transform = ab_transform,
syndromic_group = NULL, syndromic_group = NULL,
@@ -1037,7 +1062,8 @@ antibiogram.grouped_df <- function(x,
simulations = simulations, simulations = simulations,
conf_interval = conf_interval, conf_interval = conf_interval,
interval_side = interval_side, interval_side = interval_side,
info = FALSE info = FALSE,
...
) )
new_wisca_parameters <- attributes(new_out)$wisca_parameters new_wisca_parameters <- attributes(new_out)$wisca_parameters
new_long_numeric <- attributes(new_out)$long_numeric new_long_numeric <- attributes(new_out)$long_numeric
@@ -1098,7 +1124,7 @@ antibiogram.grouped_df <- function(x,
#' @export #' @export
#' @rdname antibiogram #' @rdname antibiogram
wisca <- function(x, wisca <- function(x,
antibiotics = where(is.sir), antimicrobials = where(is.sir),
ab_transform = "name", ab_transform = "name",
syndromic_group = NULL, syndromic_group = NULL,
add_total_n = FALSE, add_total_n = FALSE,
@@ -1113,10 +1139,11 @@ wisca <- function(x,
simulations = 1000, simulations = 1000,
conf_interval = 0.95, conf_interval = 0.95,
interval_side = "two-tailed", interval_side = "two-tailed",
info = interactive()) { info = interactive(),
...) {
antibiogram( antibiogram(
x = x, x = x,
antibiotics = antibiotics, antimicrobials = antimicrobials,
ab_transform = ab_transform, ab_transform = ab_transform,
mo_transform = NULL, mo_transform = NULL,
syndromic_group = syndromic_group, syndromic_group = syndromic_group,
@@ -1133,7 +1160,8 @@ wisca <- function(x,
simulations = simulations, simulations = simulations,
conf_interval = conf_interval, conf_interval = conf_interval,
interval_side = interval_side, interval_side = interval_side,
info = info info = info,
...
) )
} }
@@ -1145,26 +1173,6 @@ retrieve_wisca_parameters <- function(wisca_model, ...) {
attributes(wisca_model)$wisca_parameters attributes(wisca_model)$wisca_parameters
} }
calculate_priors <- function(data, combine_SI = TRUE) {
# Pathogen incidence (Dirichlet distribution)
gamma_prior <- rep(1, length(unique(data$mo))) # Dirichlet prior
gamma_posterior <- gamma_prior + data$n_total # Posterior parameters
# Regimen susceptibility (Beta distribution)
beta_prior <- rep(1, length(unique(data$mo))) # Beta prior
r <- data$n_susceptible # Number of pathogens tested susceptible
n <- data$n_tested # n_tested tested
beta_posterior_1 <- beta_prior + r # Posterior alpha
beta_posterior_2 <- beta_prior + (n - r) # Posterior beta
# Return parameters as a list
list(
gamma_posterior = gamma_posterior,
beta_posterior_1 = beta_posterior_1,
beta_posterior_2 = beta_posterior_2
)
}
# will be exported in R/zzz.R # will be exported in R/zzz.R
tbl_sum.antibiogram <- function(x, ...) { tbl_sum.antibiogram <- function(x, ...) {
dims <- paste(format(NROW(x), big.mark = ","), AMR_env$cross_icon, format(NCOL(x), big.mark = ",")) dims <- paste(format(NROW(x), big.mark = ","), AMR_env$cross_icon, format(NCOL(x), big.mark = ","))
@@ -1185,7 +1193,7 @@ tbl_format_footer.antibiogram <- function(x, ...) {
return(footer) return(footer)
} }
c(footer, font_subtle(paste0( c(footer, font_subtle(paste0(
"# Use `plot()` or `ggplot2::autoplot()` to create a plot of this antibiogram,\n", "# Use `ggplot2::autoplot()` or base R `plot()` to create a plot of this antibiogram,\n",
"# or use it directly in R Markdown or ", "# or use it directly in R Markdown or ",
font_url("https://quarto.org", "Quarto"), ", see ", word_wrap("?antibiogram") font_url("https://quarto.org", "Quarto"), ", see ", word_wrap("?antibiogram")
))) )))

View File

@@ -58,7 +58,7 @@
#' #'
#' The function [proportion_df()] takes any variable from `data` that has an [`sir`] class (created with [as.sir()]) and calculates the proportions S, I, and R. It also supports grouped variables. The function [sir_df()] works exactly like [proportion_df()], but adds the number of isolates. #' The function [proportion_df()] takes any variable from `data` that has an [`sir`] class (created with [as.sir()]) and calculates the proportions S, I, and R. It also supports grouped variables. The function [sir_df()] works exactly like [proportion_df()], but adds the number of isolates.
#' @section Combination Therapy: #' @section Combination Therapy:
#' When using more than one variable for `...` (= combination therapy), use `only_all_tested` to only count isolates that are tested for all antibiotics/variables that you test them for. See this example for two antimicrobials, Drug A and Drug B, about how [susceptibility()] works to calculate the %SI: #' When using more than one variable for `...` (= combination therapy), use `only_all_tested` to only count isolates that are tested for all antimicrobials/variables that you test them for. See this example for two antimicrobials, Drug A and Drug B, about how [susceptibility()] works to calculate the %SI:
#' #'
#' #'
#' ``` #' ```

View File

@@ -235,7 +235,7 @@ sir_calc_df <- function(type, # "proportion", "count" or "both"
translate_ab <- get_translate_ab(translate_ab) translate_ab <- get_translate_ab(translate_ab)
data.bak <- data data.bak <- data
# select only groups and antibiotics # select only groups and antimicrobials
if (is_null_or_grouped_tbl(data)) { if (is_null_or_grouped_tbl(data)) {
data_has_groups <- TRUE data_has_groups <- TRUE
groups <- get_group_names(data) groups <- get_group_names(data)

View File

@@ -40,22 +40,25 @@ NULL
#' @export #' @export
"antibiotics" "antibiotics"
# REMEMBER to also remove the deprecated `antibiotics` argument in `antibiogram()`
#' @rdname AMR-deprecated #' @rdname AMR-deprecated
#' @export #' @export
ab_class <- function(...) { ab_class <- function(...) {
deprecation_warning("ab_class", "amr_class") deprecation_warning("ab_class", "amr_class", is_function = TRUE)
amr_class(...) amr_class(...)
} }
#' @rdname AMR-deprecated #' @rdname AMR-deprecated
#' @export #' @export
ab_selector <- function(...) { ab_selector <- function(...) {
deprecation_warning("ab_selector", "amr_selector") deprecation_warning("ab_selector", "amr_selector", is_function = TRUE)
amr_selector(...) amr_selector(...)
} }
## Helper function ----
deprecation_warning <- function(old = NULL, new = NULL, extra_msg = NULL, is_function = TRUE, is_dataset = FALSE) { deprecation_warning <- function(old = NULL, new = NULL, fn = NULL, extra_msg = NULL, is_function = FALSE, is_dataset = FALSE, is_argument = FALSE) {
if (is.null(old)) { if (is.null(old)) {
warning_(extra_msg) warning_(extra_msg)
} else { } else {
@@ -68,22 +71,30 @@ deprecation_warning <- function(old = NULL, new = NULL, extra_msg = NULL, is_fun
type <- "function" type <- "function"
} else if (isTRUE(is_dataset)) { } else if (isTRUE(is_dataset)) {
type <- "dataset" type <- "dataset"
} else { } else if (isTRUE(is_argument)) {
type <- "argument" type <- "argument"
if (is.null(fn)) {
stop("Set 'fn' in deprecation_warning()")
}
} else {
stop("Set either 'is_function', 'is_dataset', or 'is_argument' to TRUE in deprecation_warning()")
} }
warning_( warning_(
ifelse(is.null(new), ifelse(is.null(new),
paste0("The `", old, "` ", type, " is no longer in use"), paste0("The `", old, "` ", type, " is no longer in use"),
ifelse(type == "dataset", ifelse(type == "dataset",
paste0("The `", old, "` ", type, " has been renamed to `", new, "`"), paste0("The `", old, "` ", type, " has been renamed to `", new, "`"),
paste0("The `", old, "` ", type, " has been replaced with `", new, "` and will be removed in a future version") ifelse(type == "argument",
paste0("The `", old, "` ", type, " in `", fn, "()` has been renamed to `", new, "`: `", fn, "(", new, " = ...)`"),
paste0("The `", old, "` ", type, " has been replaced with `", new, "`")
)
) )
), ),
ifelse(type == "dataset", ifelse(type == "dataset",
". The old name will be removed in future version, so please update your code.", ". The old name will be removed in future version, so please update your code.",
ifelse(type == "argument", ifelse(type == "argument",
". While the old argument still works, it will be removed in a future version, so please update your code.", ". While the old argument still works, it will be removed in a future version, so please update your code.",
", see `?AMR-deprecated`." " and will be removed in a future version, see `?AMR-deprecated`."
) )
), ),
ifelse(!is.null(extra_msg), ifelse(!is.null(extra_msg),

View File

@@ -204,14 +204,14 @@ AMR_env$cross_icon <- if (isTRUE(base::l10n_info()$`UTF-8`)) "\u00d7" else "x"
# reference data - they have additional data to improve algorithm speed # reference data - they have additional data to improve algorithm speed
# they cannot be part of R/sysdata.rda since CRAN thinks it would make the package too large (+3 MB) # they cannot be part of R/sysdata.rda since CRAN thinks it would make the package too large (+3 MB)
if (NROW(AB_LOOKUP) != NROW(AMR::antimicrobials)) { if (NROW(AB_LOOKUP) != NROW(AMR::antimicrobials)) {
# antibiotics data set was updated - run create_AB_AV_lookup() again # antimicrobials data set was updated - run create_AB_AV_lookup() again
AB_LOOKUP <- create_AB_AV_lookup(AMR::antimicrobials) AB_LOOKUP <- create_AB_AV_lookup(AMR::antimicrobials)
} }
# deprecated antibiotics data set # deprecated antibiotics data set
makeActiveBinding("antibiotics", function() { makeActiveBinding("antibiotics", function() {
if (interactive()) { if (interactive()) {
deprecation_warning(old = "antibiotics", new = "antimicrobials", is_function = FALSE, is_dataset = TRUE) deprecation_warning(old = "antibiotics", new = "antimicrobials", is_dataset = TRUE)
} }
AMR::antimicrobials AMR::antimicrobials
}, env = asNamespace(pkgname)) }, env = asNamespace(pkgname))

View File

@@ -492,9 +492,11 @@ write_md5 <- function(object) {
close(conn) close(conn)
} }
changed_md5 <- function(object) { changed_md5 <- function(object) {
path <- paste0("data-raw/", deparse(substitute(object)), ".md5")
if (!file.exists(path)) return(TRUE)
tryCatch( tryCatch(
{ {
conn <- file(paste0("data-raw/", deparse(substitute(object)), ".md5")) conn <- file(path)
compared <- md5(object) != readLines(con = conn) compared <- md5(object) != readLines(con = conn)
close(conn) close(conn)
compared compared

View File

@@ -1,6 +1,6 @@
This knowledge base contains all context you must know about the AMR package for R. You are a GPT trained to be an assistant for the AMR package in R. You are an incredible R specialist, especially trained in this package and in the tidyverse. This knowledge base contains all context you must know about the AMR package for R. You are a GPT trained to be an assistant for the AMR package in R. You are an incredible R specialist, especially trained in this package and in the tidyverse.
First and foremost, you are trained on version 2.1.1.9189. Remember this whenever someone asks which AMR package version youre at. First and foremost, you are trained on version 2.1.1.9190. Remember this whenever someone asks which AMR package version youre at.
Below are the contents of the file, the file, and all the files (documentation) in the package. Every file content is split using 100 hypens. Below are the contents of the file, the file, and all the files (documentation) in the package. Every file content is split using 100 hypens.
---------------------------------------------------------------------------------------------------- ----------------------------------------------------------------------------------------------------
@@ -420,7 +420,7 @@ The `AMR` package is a [free and open-source](#copyright) R package with [zero d
This work was published in the Journal of Statistical Software (Volume 104(3); [DOI 10.18637/jss.v104.i03](https://doi.org/10.18637/jss.v104.i03)) and formed the basis of two PhD theses ([DOI 10.33612/diss.177417131](https://doi.org/10.33612/diss.177417131) and [DOI 10.33612/diss.192486375](https://doi.org/10.33612/diss.192486375)). This work was published in the Journal of Statistical Software (Volume 104(3); [DOI 10.18637/jss.v104.i03](https://doi.org/10.18637/jss.v104.i03)) and formed the basis of two PhD theses ([DOI 10.33612/diss.177417131](https://doi.org/10.33612/diss.177417131) and [DOI 10.33612/diss.192486375](https://doi.org/10.33612/diss.192486375)).
After installing this package, R knows [**~52,000 distinct microbial species**](./reference/microorganisms.html) (updated December 2022) and all [**~600 antimicrobial and antiviral drugs**](./reference/antibiotics.html) by name and code (including ATC, EARS-Net, ASIARS-Net, PubChem, LOINC and SNOMED CT), and knows all about valid SIR and MIC values. The integral clinical breakpoint guidelines from CLSI and EUCAST are included, even with epidemiological cut-off (ECOFF) values. It supports and can read any data format, including WHONET data. This package works on Windows, macOS and Linux with all versions of R since R-3.0 (April 2013). **It was designed to work in any setting, including those with very limited resources**. It was created for both routine data analysis and academic research at the Faculty of Medical Sciences of the [University of Groningen](https://www.rug.nl), in collaboration with non-profit organisations [Certe Medical Diagnostics and Advice Foundation](https://www.certe.nl) and [University Medical Center Groningen](https://www.umcg.nl). After installing this package, R knows [**~52,000 distinct microbial species**](./reference/microorganisms.html) (updated December 2022) and all [**~600 antimicrobial and antiviral drugs**](./reference/antimicrobials.html) by name and code (including ATC, EARS-Net, ASIARS-Net, PubChem, LOINC and SNOMED CT), and knows all about valid SIR and MIC values. The integral clinical breakpoint guidelines from CLSI and EUCAST are included, even with epidemiological cut-off (ECOFF) values. It supports and can read any data format, including WHONET data. This package works on Windows, macOS and Linux with all versions of R since R-3.0 (April 2013). **It was designed to work in any setting, including those with very limited resources**. It was created for both routine data analysis and academic research at the Faculty of Medical Sciences of the [University of Groningen](https://www.rug.nl), in collaboration with non-profit organisations [Certe Medical Diagnostics and Advice Foundation](https://www.certe.nl) and [University Medical Center Groningen](https://www.umcg.nl).
##### Used in over 175 countries, available in 20 languages ##### Used in over 175 countries, available in 20 languages
@@ -475,7 +475,7 @@ If used inside [R Markdown](https://rmarkdown.rstudio.com) or [Quarto](https://q
```r ```r
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c(aminoglycosides(), carbapenems()), antimicrobials = c(aminoglycosides(), carbapenems()),
formatting_type = 14) formatting_type = 14)
``` ```
@@ -492,11 +492,11 @@ antibiogram(example_isolates,
| *S. hominis* | | 92% (84-97%) | | | | 85% (74-93%) | | *S. hominis* | | 92% (84-97%) | | | | 85% (74-93%) |
| *S. pneumoniae* | 0% (0-3%) | 0% (0-3%) | | 0% (0-3%) | | 0% (0-3%) | | *S. pneumoniae* | 0% (0-3%) | 0% (0-3%) | | 0% (0-3%) | | 0% (0-3%) |
In combination antibiograms, it is clear that combined antibiotics yield higher empiric coverage: In combination antibiograms, it is clear that combined antimicrobials yield higher empiric coverage:
```r ```r
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c("TZP", "TZP+TOB", "TZP+GEN"), antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"),
mo_transform = "gramstain", mo_transform = "gramstain",
formatting_type = 14) formatting_type = 14)
``` ```
@@ -510,7 +510,7 @@ Like many other functions in this package, `antibiogram()` comes with support fo
```r ```r
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c("cipro", "tobra", "genta"), # any arbitrary name or code will work antimicrobials = c("cipro", "tobra", "genta"), # any arbitrary name or code will work
mo_transform = "gramstain", mo_transform = "gramstain",
ab_transform = "name", ab_transform = "name",
formatting_type = 14, formatting_type = 14,
@@ -1670,23 +1670,23 @@ THE PART HEREAFTER CONTAINS CONTENTS FROM FILE 'man/antibiogram.Rd':
} }
} }
\usage{ \usage{
antibiogram(x, antibiotics = where(is.sir), mo_transform = "shortname", antibiogram(x, antimicrobials = where(is.sir), mo_transform = "shortname",
ab_transform = "name", syndromic_group = NULL, add_total_n = FALSE, ab_transform = "name", syndromic_group = NULL, add_total_n = FALSE,
only_all_tested = FALSE, digits = ifelse(wisca, 1, 0), only_all_tested = FALSE, digits = ifelse(wisca, 1, 0),
formatting_type = getOption("AMR_antibiogram_formatting_type", formatting_type = getOption("AMR_antibiogram_formatting_type",
ifelse(wisca, 14, 18)), col_mo = NULL, language = get_AMR_locale(), ifelse(wisca, 14, 18)), col_mo = NULL, language = get_AMR_locale(),
minimum = 30, combine_SI = TRUE, sep = " + ", wisca = FALSE, minimum = 30, combine_SI = TRUE, sep = " + ", wisca = FALSE,
simulations = 1000, conf_interval = 0.95, interval_side = "two-tailed", simulations = 1000, conf_interval = 0.95, interval_side = "two-tailed",
info = interactive()) info = interactive(), ...)
wisca(x, antibiotics = where(is.sir), ab_transform = "name", wisca(x, antimicrobials = where(is.sir), ab_transform = "name",
syndromic_group = NULL, add_total_n = FALSE, only_all_tested = FALSE, syndromic_group = NULL, add_total_n = FALSE, only_all_tested = FALSE,
digits = 1, digits = 1,
formatting_type = getOption("AMR_antibiogram_formatting_type", 14), formatting_type = getOption("AMR_antibiogram_formatting_type", 14),
col_mo = NULL, language = get_AMR_locale(), minimum = 30, col_mo = NULL, language = get_AMR_locale(), minimum = 30,
combine_SI = TRUE, sep = " + ", simulations = 1000, combine_SI = TRUE, sep = " + ", simulations = 1000,
conf_interval = 0.95, interval_side = "two-tailed", conf_interval = 0.95, interval_side = "two-tailed",
info = interactive()) info = interactive(), ...)
retrieve_wisca_parameters(wisca_model, ...) retrieve_wisca_parameters(wisca_model, ...)
@@ -1700,7 +1700,7 @@ retrieve_wisca_parameters(wisca_model, ...)
\arguments{ \arguments{
\item{x}{a \link{data.frame} containing at least a column with microorganisms and columns with antimicrobial results (class 'sir', see \code{\link[=as.sir]{as.sir()}})} \item{x}{a \link{data.frame} containing at least a column with microorganisms and columns with antimicrobial results (class 'sir', see \code{\link[=as.sir]{as.sir()}})}
\item{antibiotics}{vector of any antimicrobial name or code (will be evaluated with \code{\link[=as.ab]{as.ab()}}, column name of \code{x}, or (any combinations of) \link[=antimicrobial_selectors]{antimicrobial selectors} such as \code{\link[=aminoglycosides]{aminoglycosides()}} or \code{\link[=carbapenems]{carbapenems()}}. For combination antibiograms, this can also be set to values separated with \code{"+"}, such as \code{"TZP+TOB"} or \code{"cipro + genta"}, given that columns resembling such antimicrobials exist in \code{x}. See \emph{Examples}.} \item{antimicrobials}{vector of any antimicrobial name or code (will be evaluated with \code{\link[=as.ab]{as.ab()}}, column name of \code{x}, or (any combinations of) \link[=antimicrobial_selectors]{antimicrobial selectors} such as \code{\link[=aminoglycosides]{aminoglycosides()}} or \code{\link[=carbapenems]{carbapenems()}}. For combination antibiograms, this can also be set to values separated with \code{"+"}, such as \code{"TZP+TOB"} or \code{"cipro + genta"}, given that columns resembling such antimicrobials exist in \code{x}. See \emph{Examples}.}
\item{mo_transform}{a character to transform microorganism input - must be \code{"name"}, \code{"shortname"} (default), \code{"gramstain"}, or one of the column names of the \link{microorganisms} data set: "mo", "fullname", "status", "kingdom", "phylum", "class", "order", "family", "genus", "species", "subspecies", "rank", "ref", "oxygen_tolerance", "source", "lpsn", "lpsn_parent", "lpsn_renamed_to", "mycobank", "mycobank_parent", "mycobank_renamed_to", "gbif", "gbif_parent", "gbif_renamed_to", "prevalence", or "snomed". Can also be \code{NULL} to not transform the input or \code{NA} to consider all microorganisms 'unknown'.} \item{mo_transform}{a character to transform microorganism input - must be \code{"name"}, \code{"shortname"} (default), \code{"gramstain"}, or one of the column names of the \link{microorganisms} data set: "mo", "fullname", "status", "kingdom", "phylum", "class", "order", "family", "genus", "species", "subspecies", "rank", "ref", "oxygen_tolerance", "source", "lpsn", "lpsn_parent", "lpsn_renamed_to", "mycobank", "mycobank_parent", "mycobank_renamed_to", "gbif", "gbif_parent", "gbif_renamed_to", "prevalence", or "snomed". Can also be \code{NULL} to not transform the input or \code{NA} to consider all microorganisms 'unknown'.}
@@ -1736,10 +1736,10 @@ retrieve_wisca_parameters(wisca_model, ...)
\item{info}{a \link{logical} to indicate info should be printed - the default is \code{TRUE} only in interactive mode} \item{info}{a \link{logical} to indicate info should be printed - the default is \code{TRUE} only in interactive mode}
\item{wisca_model}{the outcome of \code{\link[=wisca]{wisca()}} or \code{\link[=antibiogram]{antibiogram(..., wisca = TRUE)}}}
\item{...}{when used in \link[knitr:kable]{R Markdown or Quarto}: arguments passed on to \code{\link[knitr:kable]{knitr::kable()}} (otherwise, has no use)} \item{...}{when used in \link[knitr:kable]{R Markdown or Quarto}: arguments passed on to \code{\link[knitr:kable]{knitr::kable()}} (otherwise, has no use)}
\item{wisca_model}{the outcome of \code{\link[=wisca]{wisca()}} or \code{\link[=antibiogram]{antibiogram(..., wisca = TRUE)}}}
\item{object}{an \code{\link[=antibiogram]{antibiogram()}} object} \item{object}{an \code{\link[=antibiogram]{antibiogram()}} object}
\item{italicise}{a \link{logical} to indicate whether the microorganism names in the \link[knitr:kable]{knitr} table should be made italic, using \code{\link[=italicise_taxonomy]{italicise_taxonomy()}}.} \item{italicise}{a \link{logical} to indicate whether the microorganism names in the \link[knitr:kable]{knitr} table should be made italic, using \code{\link[=italicise_taxonomy]{italicise_taxonomy()}}.}
@@ -1805,7 +1805,7 @@ Case example: Susceptibility of \emph{Pseudomonas aeruginosa} to piperacillin/ta
Code example: Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data, \if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data,
antibiotics = "TZP") antimicrobials = "TZP")
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
\item \strong{Combination Antibiogram} \item \strong{Combination Antibiogram}
@@ -1814,7 +1814,7 @@ Case example: Additional susceptibility of \emph{Pseudomonas aeruginosa} to TZP
Code example: Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data, \if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data,
antibiotics = c("TZP", "TZP+TOB", "TZP+GEN")) antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"))
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
\item \strong{Syndromic Antibiogram} \item \strong{Syndromic Antibiogram}
@@ -1823,7 +1823,7 @@ Case example: Susceptibility of \emph{Pseudomonas aeruginosa} to TZP among respi
Code example: Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data, \if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data,
antibiotics = penicillins(), antimicrobials = penicillins(),
syndromic_group = "ward") syndromic_group = "ward")
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
\item \strong{Weighted-Incidence Syndromic Combination Antibiogram (WISCA)} \item \strong{Weighted-Incidence Syndromic Combination Antibiogram (WISCA)}
@@ -1833,12 +1833,12 @@ WISCA can be applied to any antibiogram, see the section \emph{Explaining WISCA}
Code example: Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data, \if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data,
antibiotics = c("TZP", "TZP+TOB", "TZP+GEN"), antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"),
wisca = TRUE) wisca = TRUE)
# this is equal to: # this is equal to:
wisca(your_data, wisca(your_data,
antibiotics = c("TZP", "TZP+TOB", "TZP+GEN")) antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"))
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
WISCA uses a sophisticated Bayesian decision model to combine both local and pooled antimicrobial resistance data. This approach not only evaluates local patterns but can also draw on multi-centre datasets to improve regimen accuracy, even in low-incidence infections like paediatric bloodstream infections (BSIs). WISCA uses a sophisticated Bayesian decision model to combine both local and pooled antimicrobial resistance data. This approach not only evaluates local patterns but can also draw on multi-centre datasets to improve regimen accuracy, even in low-incidence infections like paediatric bloodstream infections (BSIs).
@@ -1854,7 +1854,7 @@ Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{library(dplyr) \if{html}{\out{<div class="sourceCode r">}}\preformatted{library(dplyr)
your_data \%>\% your_data \%>\%
group_by(has_sepsis, is_neonate, sex) \%>\% group_by(has_sepsis, is_neonate, sex) \%>\%
wisca(antibiotics = c("TZP", "TZP+TOB", "TZP+GEN")) wisca(antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"))
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
} }
@@ -1870,12 +1870,12 @@ At admission, no pathogen information is available.
\item Code example: \item Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data, \if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data,
antibiotics = selected_regimens, antimicrobials = selected_regimens,
mo_transform = NA) # all pathogens set to `NA` mo_transform = NA) # all pathogens set to `NA`
# preferred: use WISCA # preferred: use WISCA
wisca(your_data, wisca(your_data,
antibiotics = selected_regimens) antimicrobials = selected_regimens)
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
} }
\item \strong{Refinement with Gram Stain Results} \item \strong{Refinement with Gram Stain Results}
@@ -1886,7 +1886,7 @@ When a blood culture becomes positive, the Gram stain provides an initial and cr
\item Code example: \item Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data, \if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data,
antibiotics = selected_regimens, antimicrobials = selected_regimens,
mo_transform = "gramstain") # all pathogens set to Gram-pos/Gram-neg mo_transform = "gramstain") # all pathogens set to Gram-pos/Gram-neg
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
} }
@@ -1898,7 +1898,7 @@ After cultivation of the pathogen, full pathogen identification allows precise t
\item Code example: \item Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data, \if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data,
antibiotics = selected_regimens, antimicrobials = selected_regimens,
mo_transform = "shortname") # all pathogens set to 'G. species', e.g., E. coli mo_transform = "shortname") # all pathogens set to 'G. species', e.g., E. coli
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
} }
@@ -1989,17 +1989,17 @@ example_isolates
# Traditional antibiogram ---------------------------------------------- # Traditional antibiogram ----------------------------------------------
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c(aminoglycosides(), carbapenems()) antimicrobials = c(aminoglycosides(), carbapenems())
) )
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = aminoglycosides(), antimicrobials = aminoglycosides(),
ab_transform = "atc", ab_transform = "atc",
mo_transform = "gramstain" mo_transform = "gramstain"
) )
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = carbapenems(), antimicrobials = carbapenems(),
ab_transform = "name", ab_transform = "name",
mo_transform = "name" mo_transform = "name"
) )
@@ -2007,15 +2007,15 @@ antibiogram(example_isolates,
# Combined antibiogram ------------------------------------------------- # Combined antibiogram -------------------------------------------------
# combined antibiotics yield higher empiric coverage # combined antimicrobials yield higher empiric coverage
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c("TZP", "TZP+TOB", "TZP+GEN"), antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"),
mo_transform = "gramstain" mo_transform = "gramstain"
) )
# names of antibiotics do not need to resemble columns exactly: # names of antimicrobials do not need to resemble columns exactly:
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c("Cipro", "cipro + genta"), antimicrobials = c("Cipro", "cipro + genta"),
mo_transform = "gramstain", mo_transform = "gramstain",
ab_transform = "name", ab_transform = "name",
sep = " & " sep = " & "
@@ -2026,7 +2026,7 @@ antibiogram(example_isolates,
# the data set could contain a filter for e.g. respiratory specimens # the data set could contain a filter for e.g. respiratory specimens
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c(aminoglycosides(), carbapenems()), antimicrobials = c(aminoglycosides(), carbapenems()),
syndromic_group = "ward" syndromic_group = "ward"
) )
@@ -2036,7 +2036,7 @@ ex1 <- example_isolates[which(mo_genus() == "Escherichia"), ]
# with a custom language, though this will be determined automatically # with a custom language, though this will be determined automatically
# (i.e., this table will be in Spanish on Spanish systems) # (i.e., this table will be in Spanish on Spanish systems)
antibiogram(ex1, antibiogram(ex1,
antibiotics = aminoglycosides(), antimicrobials = aminoglycosides(),
ab_transform = "name", ab_transform = "name",
syndromic_group = ifelse(ex1$ward == "ICU", syndromic_group = ifelse(ex1$ward == "ICU",
"UCI", "No UCI" "UCI", "No UCI"
@@ -2049,7 +2049,7 @@ antibiogram(ex1,
# WISCA are not stratified by species, but rather on syndromes # WISCA are not stratified by species, but rather on syndromes
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c("TZP", "TZP+TOB", "TZP+GEN"), antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"),
syndromic_group = "ward", syndromic_group = "ward",
wisca = TRUE wisca = TRUE
) )
@@ -2058,7 +2058,7 @@ antibiogram(example_isolates,
# Print the output for R Markdown / Quarto ----------------------------- # Print the output for R Markdown / Quarto -----------------------------
ureido <- antibiogram(example_isolates, ureido <- antibiogram(example_isolates,
antibiotics = ureidopenicillins(), antimicrobials = ureidopenicillins(),
syndromic_group = "ward", syndromic_group = "ward",
wisca = TRUE wisca = TRUE
) )
@@ -2073,11 +2073,11 @@ if (requireNamespace("knitr")) {
# Generate plots with ggplot2 or base R -------------------------------- # Generate plots with ggplot2 or base R --------------------------------
ab1 <- antibiogram(example_isolates, ab1 <- antibiogram(example_isolates,
antibiotics = c("AMC", "CIP", "TZP", "TZP+TOB"), antimicrobials = c("AMC", "CIP", "TZP", "TZP+TOB"),
mo_transform = "gramstain" mo_transform = "gramstain"
) )
ab2 <- antibiogram(example_isolates, ab2 <- antibiogram(example_isolates,
antibiotics = c("AMC", "CIP", "TZP", "TZP+TOB"), antimicrobials = c("AMC", "CIP", "TZP", "TZP+TOB"),
mo_transform = "gramstain", mo_transform = "gramstain",
syndromic_group = "ward" syndromic_group = "ward"
) )
@@ -4287,7 +4287,7 @@ This AMR package honours this insight. Use \code{\link[=susceptibility]{suscepti
\section{Combination Therapy}{ \section{Combination Therapy}{
When using more than one variable for \code{...} (= combination therapy), use \code{only_all_tested} to only count isolates that are tested for all antibiotics/variables that you test them for. See this example for two antimicrobials, Drug A and Drug B, about how \code{\link[=susceptibility]{susceptibility()}} works to calculate the \%SI: When using more than one variable for \code{...} (= combination therapy), use \code{only_all_tested} to only count isolates that are tested for all antimicrobials/variables that you test them for. See this example for two antimicrobials, Drug A and Drug B, about how \code{\link[=susceptibility]{susceptibility()}} works to calculate the \%SI:
\if{html}{\out{<div class="sourceCode">}}\preformatted{-------------------------------------------------------------------- \if{html}{\out{<div class="sourceCode">}}\preformatted{--------------------------------------------------------------------
only_all_tested = FALSE only_all_tested = TRUE only_all_tested = FALSE only_all_tested = TRUE
@@ -7852,7 +7852,7 @@ The function \code{\link[=proportion_df]{proportion_df()}} takes any variable fr
} }
\section{Combination Therapy}{ \section{Combination Therapy}{
When using more than one variable for \code{...} (= combination therapy), use \code{only_all_tested} to only count isolates that are tested for all antibiotics/variables that you test them for. See this example for two antimicrobials, Drug A and Drug B, about how \code{\link[=susceptibility]{susceptibility()}} works to calculate the \%SI: When using more than one variable for \code{...} (= combination therapy), use \code{only_all_tested} to only count isolates that are tested for all antimicrobials/variables that you test them for. See this example for two antimicrobials, Drug A and Drug B, about how \code{\link[=susceptibility]{susceptibility()}} works to calculate the \%SI:
\if{html}{\out{<div class="sourceCode">}}\preformatted{-------------------------------------------------------------------- \if{html}{\out{<div class="sourceCode">}}\preformatted{--------------------------------------------------------------------
only_all_tested = FALSE only_all_tested = TRUE only_all_tested = FALSE only_all_tested = TRUE

View File

@@ -26,7 +26,7 @@ The `AMR` package is a [free and open-source](#copyright) R package with [zero d
This work was published in the Journal of Statistical Software (Volume 104(3); [DOI 10.18637/jss.v104.i03](https://doi.org/10.18637/jss.v104.i03)) and formed the basis of two PhD theses ([DOI 10.33612/diss.177417131](https://doi.org/10.33612/diss.177417131) and [DOI 10.33612/diss.192486375](https://doi.org/10.33612/diss.192486375)). This work was published in the Journal of Statistical Software (Volume 104(3); [DOI 10.18637/jss.v104.i03](https://doi.org/10.18637/jss.v104.i03)) and formed the basis of two PhD theses ([DOI 10.33612/diss.177417131](https://doi.org/10.33612/diss.177417131) and [DOI 10.33612/diss.192486375](https://doi.org/10.33612/diss.192486375)).
After installing this package, R knows [**~52,000 distinct microbial species**](./reference/microorganisms.html) (updated December 2022) and all [**~600 antimicrobial and antiviral drugs**](./reference/antibiotics.html) by name and code (including ATC, EARS-Net, ASIARS-Net, PubChem, LOINC and SNOMED CT), and knows all about valid SIR and MIC values. The integral clinical breakpoint guidelines from CLSI and EUCAST are included, even with epidemiological cut-off (ECOFF) values. It supports and can read any data format, including WHONET data. This package works on Windows, macOS and Linux with all versions of R since R-3.0 (April 2013). **It was designed to work in any setting, including those with very limited resources**. It was created for both routine data analysis and academic research at the Faculty of Medical Sciences of the [University of Groningen](https://www.rug.nl), in collaboration with non-profit organisations [Certe Medical Diagnostics and Advice Foundation](https://www.certe.nl) and [University Medical Center Groningen](https://www.umcg.nl). After installing this package, R knows [**~52,000 distinct microbial species**](./reference/microorganisms.html) (updated December 2022) and all [**~600 antimicrobial and antiviral drugs**](./reference/antimicrobials.html) by name and code (including ATC, EARS-Net, ASIARS-Net, PubChem, LOINC and SNOMED CT), and knows all about valid SIR and MIC values. The integral clinical breakpoint guidelines from CLSI and EUCAST are included, even with epidemiological cut-off (ECOFF) values. It supports and can read any data format, including WHONET data. This package works on Windows, macOS and Linux with all versions of R since R-3.0 (April 2013). **It was designed to work in any setting, including those with very limited resources**. It was created for both routine data analysis and academic research at the Faculty of Medical Sciences of the [University of Groningen](https://www.rug.nl), in collaboration with non-profit organisations [Certe Medical Diagnostics and Advice Foundation](https://www.certe.nl) and [University Medical Center Groningen](https://www.umcg.nl).
##### Used in over 175 countries, available in 20 languages ##### Used in over 175 countries, available in 20 languages
@@ -81,7 +81,7 @@ If used inside [R Markdown](https://rmarkdown.rstudio.com) or [Quarto](https://q
```r ```r
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c(aminoglycosides(), carbapenems()), antimicrobials = c(aminoglycosides(), carbapenems()),
formatting_type = 14) formatting_type = 14)
``` ```
@@ -98,11 +98,11 @@ antibiogram(example_isolates,
| *S. hominis* | | 92% (84-97%) | | | | 85% (74-93%) | | *S. hominis* | | 92% (84-97%) | | | | 85% (74-93%) |
| *S. pneumoniae* | 0% (0-3%) | 0% (0-3%) | | 0% (0-3%) | | 0% (0-3%) | | *S. pneumoniae* | 0% (0-3%) | 0% (0-3%) | | 0% (0-3%) | | 0% (0-3%) |
In combination antibiograms, it is clear that combined antibiotics yield higher empiric coverage: In combination antibiograms, it is clear that combined antimicrobials yield higher empiric coverage:
```r ```r
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c("TZP", "TZP+TOB", "TZP+GEN"), antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"),
mo_transform = "gramstain", mo_transform = "gramstain",
formatting_type = 14) formatting_type = 14)
``` ```
@@ -116,7 +116,7 @@ Like many other functions in this package, `antibiogram()` comes with support fo
```r ```r
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c("cipro", "tobra", "genta"), # any arbitrary name or code will work antimicrobials = c("cipro", "tobra", "genta"), # any arbitrary name or code will work
mo_transform = "gramstain", mo_transform = "gramstain",
ab_transform = "name", ab_transform = "name",
formatting_type = 14, formatting_type = 14,

View File

@@ -18,23 +18,23 @@
} }
} }
\usage{ \usage{
antibiogram(x, antibiotics = where(is.sir), mo_transform = "shortname", antibiogram(x, antimicrobials = where(is.sir), mo_transform = "shortname",
ab_transform = "name", syndromic_group = NULL, add_total_n = FALSE, ab_transform = "name", syndromic_group = NULL, add_total_n = FALSE,
only_all_tested = FALSE, digits = ifelse(wisca, 1, 0), only_all_tested = FALSE, digits = ifelse(wisca, 1, 0),
formatting_type = getOption("AMR_antibiogram_formatting_type", formatting_type = getOption("AMR_antibiogram_formatting_type",
ifelse(wisca, 14, 18)), col_mo = NULL, language = get_AMR_locale(), ifelse(wisca, 14, 18)), col_mo = NULL, language = get_AMR_locale(),
minimum = 30, combine_SI = TRUE, sep = " + ", wisca = FALSE, minimum = 30, combine_SI = TRUE, sep = " + ", wisca = FALSE,
simulations = 1000, conf_interval = 0.95, interval_side = "two-tailed", simulations = 1000, conf_interval = 0.95, interval_side = "two-tailed",
info = interactive()) info = interactive(), ...)
wisca(x, antibiotics = where(is.sir), ab_transform = "name", wisca(x, antimicrobials = where(is.sir), ab_transform = "name",
syndromic_group = NULL, add_total_n = FALSE, only_all_tested = FALSE, syndromic_group = NULL, add_total_n = FALSE, only_all_tested = FALSE,
digits = 1, digits = 1,
formatting_type = getOption("AMR_antibiogram_formatting_type", 14), formatting_type = getOption("AMR_antibiogram_formatting_type", 14),
col_mo = NULL, language = get_AMR_locale(), minimum = 30, col_mo = NULL, language = get_AMR_locale(), minimum = 30,
combine_SI = TRUE, sep = " + ", simulations = 1000, combine_SI = TRUE, sep = " + ", simulations = 1000,
conf_interval = 0.95, interval_side = "two-tailed", conf_interval = 0.95, interval_side = "two-tailed",
info = interactive()) info = interactive(), ...)
retrieve_wisca_parameters(wisca_model, ...) retrieve_wisca_parameters(wisca_model, ...)
@@ -48,7 +48,7 @@ retrieve_wisca_parameters(wisca_model, ...)
\arguments{ \arguments{
\item{x}{a \link{data.frame} containing at least a column with microorganisms and columns with antimicrobial results (class 'sir', see \code{\link[=as.sir]{as.sir()}})} \item{x}{a \link{data.frame} containing at least a column with microorganisms and columns with antimicrobial results (class 'sir', see \code{\link[=as.sir]{as.sir()}})}
\item{antibiotics}{vector of any antimicrobial name or code (will be evaluated with \code{\link[=as.ab]{as.ab()}}, column name of \code{x}, or (any combinations of) \link[=antimicrobial_selectors]{antimicrobial selectors} such as \code{\link[=aminoglycosides]{aminoglycosides()}} or \code{\link[=carbapenems]{carbapenems()}}. For combination antibiograms, this can also be set to values separated with \code{"+"}, such as \code{"TZP+TOB"} or \code{"cipro + genta"}, given that columns resembling such antimicrobials exist in \code{x}. See \emph{Examples}.} \item{antimicrobials}{vector of any antimicrobial name or code (will be evaluated with \code{\link[=as.ab]{as.ab()}}, column name of \code{x}, or (any combinations of) \link[=antimicrobial_selectors]{antimicrobial selectors} such as \code{\link[=aminoglycosides]{aminoglycosides()}} or \code{\link[=carbapenems]{carbapenems()}}. For combination antibiograms, this can also be set to values separated with \code{"+"}, such as \code{"TZP+TOB"} or \code{"cipro + genta"}, given that columns resembling such antimicrobials exist in \code{x}. See \emph{Examples}.}
\item{mo_transform}{a character to transform microorganism input - must be \code{"name"}, \code{"shortname"} (default), \code{"gramstain"}, or one of the column names of the \link{microorganisms} data set: "mo", "fullname", "status", "kingdom", "phylum", "class", "order", "family", "genus", "species", "subspecies", "rank", "ref", "oxygen_tolerance", "source", "lpsn", "lpsn_parent", "lpsn_renamed_to", "mycobank", "mycobank_parent", "mycobank_renamed_to", "gbif", "gbif_parent", "gbif_renamed_to", "prevalence", or "snomed". Can also be \code{NULL} to not transform the input or \code{NA} to consider all microorganisms 'unknown'.} \item{mo_transform}{a character to transform microorganism input - must be \code{"name"}, \code{"shortname"} (default), \code{"gramstain"}, or one of the column names of the \link{microorganisms} data set: "mo", "fullname", "status", "kingdom", "phylum", "class", "order", "family", "genus", "species", "subspecies", "rank", "ref", "oxygen_tolerance", "source", "lpsn", "lpsn_parent", "lpsn_renamed_to", "mycobank", "mycobank_parent", "mycobank_renamed_to", "gbif", "gbif_parent", "gbif_renamed_to", "prevalence", or "snomed". Can also be \code{NULL} to not transform the input or \code{NA} to consider all microorganisms 'unknown'.}
@@ -84,10 +84,10 @@ retrieve_wisca_parameters(wisca_model, ...)
\item{info}{a \link{logical} to indicate info should be printed - the default is \code{TRUE} only in interactive mode} \item{info}{a \link{logical} to indicate info should be printed - the default is \code{TRUE} only in interactive mode}
\item{wisca_model}{the outcome of \code{\link[=wisca]{wisca()}} or \code{\link[=antibiogram]{antibiogram(..., wisca = TRUE)}}}
\item{...}{when used in \link[knitr:kable]{R Markdown or Quarto}: arguments passed on to \code{\link[knitr:kable]{knitr::kable()}} (otherwise, has no use)} \item{...}{when used in \link[knitr:kable]{R Markdown or Quarto}: arguments passed on to \code{\link[knitr:kable]{knitr::kable()}} (otherwise, has no use)}
\item{wisca_model}{the outcome of \code{\link[=wisca]{wisca()}} or \code{\link[=antibiogram]{antibiogram(..., wisca = TRUE)}}}
\item{object}{an \code{\link[=antibiogram]{antibiogram()}} object} \item{object}{an \code{\link[=antibiogram]{antibiogram()}} object}
\item{italicise}{a \link{logical} to indicate whether the microorganism names in the \link[knitr:kable]{knitr} table should be made italic, using \code{\link[=italicise_taxonomy]{italicise_taxonomy()}}.} \item{italicise}{a \link{logical} to indicate whether the microorganism names in the \link[knitr:kable]{knitr} table should be made italic, using \code{\link[=italicise_taxonomy]{italicise_taxonomy()}}.}
@@ -153,7 +153,7 @@ Case example: Susceptibility of \emph{Pseudomonas aeruginosa} to piperacillin/ta
Code example: Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data, \if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data,
antibiotics = "TZP") antimicrobials = "TZP")
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
\item \strong{Combination Antibiogram} \item \strong{Combination Antibiogram}
@@ -162,7 +162,7 @@ Case example: Additional susceptibility of \emph{Pseudomonas aeruginosa} to TZP
Code example: Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data, \if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data,
antibiotics = c("TZP", "TZP+TOB", "TZP+GEN")) antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"))
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
\item \strong{Syndromic Antibiogram} \item \strong{Syndromic Antibiogram}
@@ -171,7 +171,7 @@ Case example: Susceptibility of \emph{Pseudomonas aeruginosa} to TZP among respi
Code example: Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data, \if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data,
antibiotics = penicillins(), antimicrobials = penicillins(),
syndromic_group = "ward") syndromic_group = "ward")
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
\item \strong{Weighted-Incidence Syndromic Combination Antibiogram (WISCA)} \item \strong{Weighted-Incidence Syndromic Combination Antibiogram (WISCA)}
@@ -181,12 +181,12 @@ WISCA can be applied to any antibiogram, see the section \emph{Explaining WISCA}
Code example: Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data, \if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data,
antibiotics = c("TZP", "TZP+TOB", "TZP+GEN"), antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"),
wisca = TRUE) wisca = TRUE)
# this is equal to: # this is equal to:
wisca(your_data, wisca(your_data,
antibiotics = c("TZP", "TZP+TOB", "TZP+GEN")) antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"))
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
WISCA uses a sophisticated Bayesian decision model to combine both local and pooled antimicrobial resistance data. This approach not only evaluates local patterns but can also draw on multi-centre datasets to improve regimen accuracy, even in low-incidence infections like paediatric bloodstream infections (BSIs). WISCA uses a sophisticated Bayesian decision model to combine both local and pooled antimicrobial resistance data. This approach not only evaluates local patterns but can also draw on multi-centre datasets to improve regimen accuracy, even in low-incidence infections like paediatric bloodstream infections (BSIs).
@@ -202,7 +202,7 @@ Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{library(dplyr) \if{html}{\out{<div class="sourceCode r">}}\preformatted{library(dplyr)
your_data \%>\% your_data \%>\%
group_by(has_sepsis, is_neonate, sex) \%>\% group_by(has_sepsis, is_neonate, sex) \%>\%
wisca(antibiotics = c("TZP", "TZP+TOB", "TZP+GEN")) wisca(antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"))
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
} }
@@ -218,12 +218,12 @@ At admission, no pathogen information is available.
\item Code example: \item Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data, \if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data,
antibiotics = selected_regimens, antimicrobials = selected_regimens,
mo_transform = NA) # all pathogens set to `NA` mo_transform = NA) # all pathogens set to `NA`
# preferred: use WISCA # preferred: use WISCA
wisca(your_data, wisca(your_data,
antibiotics = selected_regimens) antimicrobials = selected_regimens)
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
} }
\item \strong{Refinement with Gram Stain Results} \item \strong{Refinement with Gram Stain Results}
@@ -234,7 +234,7 @@ When a blood culture becomes positive, the Gram stain provides an initial and cr
\item Code example: \item Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data, \if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data,
antibiotics = selected_regimens, antimicrobials = selected_regimens,
mo_transform = "gramstain") # all pathogens set to Gram-pos/Gram-neg mo_transform = "gramstain") # all pathogens set to Gram-pos/Gram-neg
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
} }
@@ -246,7 +246,7 @@ After cultivation of the pathogen, full pathogen identification allows precise t
\item Code example: \item Code example:
\if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data, \if{html}{\out{<div class="sourceCode r">}}\preformatted{antibiogram(your_data,
antibiotics = selected_regimens, antimicrobials = selected_regimens,
mo_transform = "shortname") # all pathogens set to 'G. species', e.g., E. coli mo_transform = "shortname") # all pathogens set to 'G. species', e.g., E. coli
}\if{html}{\out{</div>}} }\if{html}{\out{</div>}}
} }
@@ -337,17 +337,17 @@ example_isolates
# Traditional antibiogram ---------------------------------------------- # Traditional antibiogram ----------------------------------------------
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c(aminoglycosides(), carbapenems()) antimicrobials = c(aminoglycosides(), carbapenems())
) )
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = aminoglycosides(), antimicrobials = aminoglycosides(),
ab_transform = "atc", ab_transform = "atc",
mo_transform = "gramstain" mo_transform = "gramstain"
) )
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = carbapenems(), antimicrobials = carbapenems(),
ab_transform = "name", ab_transform = "name",
mo_transform = "name" mo_transform = "name"
) )
@@ -355,15 +355,15 @@ antibiogram(example_isolates,
# Combined antibiogram ------------------------------------------------- # Combined antibiogram -------------------------------------------------
# combined antibiotics yield higher empiric coverage # combined antimicrobials yield higher empiric coverage
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c("TZP", "TZP+TOB", "TZP+GEN"), antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"),
mo_transform = "gramstain" mo_transform = "gramstain"
) )
# names of antibiotics do not need to resemble columns exactly: # names of antimicrobials do not need to resemble columns exactly:
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c("Cipro", "cipro + genta"), antimicrobials = c("Cipro", "cipro + genta"),
mo_transform = "gramstain", mo_transform = "gramstain",
ab_transform = "name", ab_transform = "name",
sep = " & " sep = " & "
@@ -374,7 +374,7 @@ antibiogram(example_isolates,
# the data set could contain a filter for e.g. respiratory specimens # the data set could contain a filter for e.g. respiratory specimens
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c(aminoglycosides(), carbapenems()), antimicrobials = c(aminoglycosides(), carbapenems()),
syndromic_group = "ward" syndromic_group = "ward"
) )
@@ -384,7 +384,7 @@ ex1 <- example_isolates[which(mo_genus() == "Escherichia"), ]
# with a custom language, though this will be determined automatically # with a custom language, though this will be determined automatically
# (i.e., this table will be in Spanish on Spanish systems) # (i.e., this table will be in Spanish on Spanish systems)
antibiogram(ex1, antibiogram(ex1,
antibiotics = aminoglycosides(), antimicrobials = aminoglycosides(),
ab_transform = "name", ab_transform = "name",
syndromic_group = ifelse(ex1$ward == "ICU", syndromic_group = ifelse(ex1$ward == "ICU",
"UCI", "No UCI" "UCI", "No UCI"
@@ -397,7 +397,7 @@ antibiogram(ex1,
# WISCA are not stratified by species, but rather on syndromes # WISCA are not stratified by species, but rather on syndromes
antibiogram(example_isolates, antibiogram(example_isolates,
antibiotics = c("TZP", "TZP+TOB", "TZP+GEN"), antimicrobials = c("TZP", "TZP+TOB", "TZP+GEN"),
syndromic_group = "ward", syndromic_group = "ward",
wisca = TRUE wisca = TRUE
) )
@@ -406,7 +406,7 @@ antibiogram(example_isolates,
# Print the output for R Markdown / Quarto ----------------------------- # Print the output for R Markdown / Quarto -----------------------------
ureido <- antibiogram(example_isolates, ureido <- antibiogram(example_isolates,
antibiotics = ureidopenicillins(), antimicrobials = ureidopenicillins(),
syndromic_group = "ward", syndromic_group = "ward",
wisca = TRUE wisca = TRUE
) )
@@ -421,11 +421,11 @@ if (requireNamespace("knitr")) {
# Generate plots with ggplot2 or base R -------------------------------- # Generate plots with ggplot2 or base R --------------------------------
ab1 <- antibiogram(example_isolates, ab1 <- antibiogram(example_isolates,
antibiotics = c("AMC", "CIP", "TZP", "TZP+TOB"), antimicrobials = c("AMC", "CIP", "TZP", "TZP+TOB"),
mo_transform = "gramstain" mo_transform = "gramstain"
) )
ab2 <- antibiogram(example_isolates, ab2 <- antibiogram(example_isolates,
antibiotics = c("AMC", "CIP", "TZP", "TZP+TOB"), antimicrobials = c("AMC", "CIP", "TZP", "TZP+TOB"),
mo_transform = "gramstain", mo_transform = "gramstain",
syndromic_group = "ward" syndromic_group = "ward"
) )

View File

@@ -85,7 +85,7 @@ This AMR package honours this insight. Use \code{\link[=susceptibility]{suscepti
\section{Combination Therapy}{ \section{Combination Therapy}{
When using more than one variable for \code{...} (= combination therapy), use \code{only_all_tested} to only count isolates that are tested for all antibiotics/variables that you test them for. See this example for two antimicrobials, Drug A and Drug B, about how \code{\link[=susceptibility]{susceptibility()}} works to calculate the \%SI: When using more than one variable for \code{...} (= combination therapy), use \code{only_all_tested} to only count isolates that are tested for all antimicrobials/variables that you test them for. See this example for two antimicrobials, Drug A and Drug B, about how \code{\link[=susceptibility]{susceptibility()}} works to calculate the \%SI:
\if{html}{\out{<div class="sourceCode">}}\preformatted{-------------------------------------------------------------------- \if{html}{\out{<div class="sourceCode">}}\preformatted{--------------------------------------------------------------------
only_all_tested = FALSE only_all_tested = TRUE only_all_tested = FALSE only_all_tested = TRUE

View File

@@ -99,7 +99,7 @@ The function \code{\link[=proportion_df]{proportion_df()}} takes any variable fr
} }
\section{Combination Therapy}{ \section{Combination Therapy}{
When using more than one variable for \code{...} (= combination therapy), use \code{only_all_tested} to only count isolates that are tested for all antibiotics/variables that you test them for. See this example for two antimicrobials, Drug A and Drug B, about how \code{\link[=susceptibility]{susceptibility()}} works to calculate the \%SI: When using more than one variable for \code{...} (= combination therapy), use \code{only_all_tested} to only count isolates that are tested for all antimicrobials/variables that you test them for. See this example for two antimicrobials, Drug A and Drug B, about how \code{\link[=susceptibility]{susceptibility()}} works to calculate the \%SI:
\if{html}{\out{<div class="sourceCode">}}\preformatted{-------------------------------------------------------------------- \if{html}{\out{<div class="sourceCode">}}\preformatted{--------------------------------------------------------------------
only_all_tested = FALSE only_all_tested = TRUE only_all_tested = FALSE only_all_tested = TRUE