mirror of
https://github.com/msberends/AMR.git
synced 2025-01-13 14:11:37 +01:00
new EUCAST rules: clinical breakpoints
This commit is contained in:
parent
d5a41de711
commit
693f64bdbf
@ -1,6 +1,6 @@
|
|||||||
Package: AMR
|
Package: AMR
|
||||||
Version: 0.4.0.9003
|
Version: 0.4.0.9004
|
||||||
Date: 2018-10-16
|
Date: 2018-10-17
|
||||||
Title: Antimicrobial Resistance Analysis
|
Title: Antimicrobial Resistance Analysis
|
||||||
Authors@R: c(
|
Authors@R: c(
|
||||||
person(
|
person(
|
||||||
@ -47,6 +47,7 @@ Depends:
|
|||||||
Imports:
|
Imports:
|
||||||
backports,
|
backports,
|
||||||
curl,
|
curl,
|
||||||
|
crayon (>= 1.3.0),
|
||||||
data.table (>= 1.9.0),
|
data.table (>= 1.9.0),
|
||||||
dplyr (>= 0.7.0),
|
dplyr (>= 0.7.0),
|
||||||
hms,
|
hms,
|
||||||
|
@ -161,6 +161,13 @@ exportMethods(skewness.default)
|
|||||||
exportMethods(skewness.matrix)
|
exportMethods(skewness.matrix)
|
||||||
exportMethods(summary.mic)
|
exportMethods(summary.mic)
|
||||||
exportMethods(summary.rsi)
|
exportMethods(summary.rsi)
|
||||||
|
importFrom(crayon,bgGreen)
|
||||||
|
importFrom(crayon,bgRed)
|
||||||
|
importFrom(crayon,bgYellow)
|
||||||
|
importFrom(crayon,black)
|
||||||
|
importFrom(crayon,blue)
|
||||||
|
importFrom(crayon,bold)
|
||||||
|
importFrom(crayon,green)
|
||||||
importFrom(curl,nslookup)
|
importFrom(curl,nslookup)
|
||||||
importFrom(data.table,as.data.table)
|
importFrom(data.table,as.data.table)
|
||||||
importFrom(data.table,data.table)
|
importFrom(data.table,data.table)
|
||||||
|
11
NEWS.md
11
NEWS.md
@ -4,13 +4,21 @@
|
|||||||
* Function `count_all` to get all available isolates (that like all `portion_*` and `count_*` functions also supports `summarise` and `group_by`), the old `n_rsi` is now an alias of `count_all`
|
* Function `count_all` to get all available isolates (that like all `portion_*` and `count_*` functions also supports `summarise` and `group_by`), the old `n_rsi` is now an alias of `count_all`
|
||||||
|
|
||||||
#### Changed
|
#### Changed
|
||||||
|
* Big changes to the `EUCAST_rules` function:
|
||||||
|
* It now also applies rules from the EUCAST 'Breakpoint tables for bacteria', version 8.1, 2018, http://www.eucast.org/clinical_breakpoints/ (see Source of the function)
|
||||||
|
* There's better error handling when rules cannot be applied (i.e. new values could not be inserted)
|
||||||
|
* A new `verbose` parameter can be set to `TRUE` to get very specific messages about which columns and rows were affected
|
||||||
|
* The amount of affected values will now only be measured once per row/column combination
|
||||||
|
* Data set `septic_patients` now reflects these changes
|
||||||
* Added parameter `combine_IR` (TRUE/FALSE) to functions `portion_df` and `count_df`, to indicate that all values of I and R must be merged into one, so the output only consists of S vs. IR (susceptible vs. non-susceptible)
|
* Added parameter `combine_IR` (TRUE/FALSE) to functions `portion_df` and `count_df`, to indicate that all values of I and R must be merged into one, so the output only consists of S vs. IR (susceptible vs. non-susceptible)
|
||||||
* Fix for `portion_*(..., as_percent = TRUE)` when minimal amount of isolates would not be met
|
* Fix for `portion_*(..., as_percent = TRUE)` when minimal amount of isolates would not be met
|
||||||
* Using `portion_*` functions now throws a warning when total available isolate is below parameter `minimum`
|
* Using `portion_*` functions now throws a warning when total available isolate is below parameter `minimum`
|
||||||
* `as.mo` will not set package name as attribute anymore
|
* Functions `as.mo`, `as.rsi` and `as.mic` will not set package name as attribute anymore
|
||||||
|
* Data set `septic_patients` is now a `data.frame`, not a tibble anymore
|
||||||
* Check for `hms::is.hms` in frequency tables
|
* Check for `hms::is.hms` in frequency tables
|
||||||
* Removed diacritics from all authors (columns `microorganisms$ref` and `microorganisms.old$ref`) to comply with CRAN policy to only allow ASCII characters
|
* Removed diacritics from all authors (columns `microorganisms$ref` and `microorganisms.old$ref`) to comply with CRAN policy to only allow ASCII characters
|
||||||
* Fix for `mo_property` not working properly
|
* Fix for `mo_property` not working properly
|
||||||
|
* Fix for `EUCAST_rules` where some Streptococci would become ceftazidime R in EUCAST rule 4.5
|
||||||
* Support for class `difftime` in frequency tables
|
* Support for class `difftime` in frequency tables
|
||||||
* Support for named vectors of class `mo`, useful for `top_freq()`
|
* Support for named vectors of class `mo`, useful for `top_freq()`
|
||||||
* AI improvements for `as.mo`:
|
* AI improvements for `as.mo`:
|
||||||
@ -22,6 +30,7 @@
|
|||||||
* In `g.test`, when `sum(x)` is below 1000, suggest Fisher's Exact Test
|
* In `g.test`, when `sum(x)` is below 1000, suggest Fisher's Exact Test
|
||||||
|
|
||||||
#### Other
|
#### Other
|
||||||
|
* New dependency on package `crayon`, to support formatted text in the console
|
||||||
* Updated vignettes to comply with README
|
* Updated vignettes to comply with README
|
||||||
|
|
||||||
|
|
||||||
|
3
R/data.R
3
R/data.R
@ -186,7 +186,7 @@
|
|||||||
#' Data set with 2000 blood culture isolates of septic patients
|
#' Data set with 2000 blood culture isolates of septic patients
|
||||||
#'
|
#'
|
||||||
#' An anonymised data set containing 2,000 microbial blood culture isolates with their full antibiograms found in septic patients in 4 different hospitals in the Netherlands, between 2001 and 2017. It is true, genuine data. This \code{data.frame} can be used to practice AMR analysis. For examples, press F1.
|
#' An anonymised data set containing 2,000 microbial blood culture isolates with their full antibiograms found in septic patients in 4 different hospitals in the Netherlands, between 2001 and 2017. It is true, genuine data. This \code{data.frame} can be used to practice AMR analysis. For examples, press F1.
|
||||||
#' @format A \code{\link{tibble}} with 2,000 observations and 49 variables:
|
#' @format A \code{\link{data.frame}} with 2,000 observations and 49 variables:
|
||||||
#' \describe{
|
#' \describe{
|
||||||
#' \item{\code{date}}{date of receipt at the laboratory}
|
#' \item{\code{date}}{date of receipt at the laboratory}
|
||||||
#' \item{\code{hospital_id}}{ID of the hospital, from A to D}
|
#' \item{\code{hospital_id}}{ID of the hospital, from A to D}
|
||||||
@ -199,7 +199,6 @@
|
|||||||
#' \item{\code{mo}}{ID of microorganism, see \code{\link{microorganisms}}}
|
#' \item{\code{mo}}{ID of microorganism, see \code{\link{microorganisms}}}
|
||||||
#' \item{\code{peni:rifa}}{40 different antibiotics with class \code{rsi} (see \code{\link{as.rsi}}); these column names occur in \code{\link{antibiotics}} data set and can be translated with \code{\link{abname}}}
|
#' \item{\code{peni:rifa}}{40 different antibiotics with class \code{rsi} (see \code{\link{as.rsi}}); these column names occur in \code{\link{antibiotics}} data set and can be translated with \code{\link{abname}}}
|
||||||
#' }
|
#' }
|
||||||
# source MOLIS (LIS of Certe) - \url{https://www.certe.nl}
|
|
||||||
#' @examples
|
#' @examples
|
||||||
#' # ----------- #
|
#' # ----------- #
|
||||||
#' # PREPARATION #
|
#' # PREPARATION #
|
||||||
|
1088
R/eucast.R
1088
R/eucast.R
File diff suppressed because it is too large
Load Diff
7
R/mic.R
7
R/mic.R
@ -22,7 +22,7 @@
|
|||||||
#' @rdname as.mic
|
#' @rdname as.mic
|
||||||
#' @param x vector
|
#' @param x vector
|
||||||
#' @param na.rm a logical indicating whether missing values should be removed
|
#' @param na.rm a logical indicating whether missing values should be removed
|
||||||
#' @return Ordered factor with new class \code{mic} and new attribute \code{package}
|
#' @return Ordered factor with new class \code{mic}
|
||||||
#' @keywords mic
|
#' @keywords mic
|
||||||
#' @export
|
#' @export
|
||||||
#' @importFrom dplyr %>%
|
#' @importFrom dplyr %>%
|
||||||
@ -148,11 +148,8 @@ as.mic <- function(x, na.rm = FALSE) {
|
|||||||
list_missing, call. = FALSE)
|
list_missing, call. = FALSE)
|
||||||
}
|
}
|
||||||
|
|
||||||
x <- factor(x = x,
|
x <- factor(x, levels = lvls, ordered = TRUE)
|
||||||
levels = lvls,
|
|
||||||
ordered = TRUE)
|
|
||||||
class(x) <- c('mic', 'ordered', 'factor')
|
class(x) <- c('mic', 'ordered', 'factor')
|
||||||
attr(x, 'package') <- 'AMR'
|
|
||||||
x
|
x
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
5
R/rsi.R
5
R/rsi.R
@ -22,7 +22,7 @@
|
|||||||
#' @rdname as.rsi
|
#' @rdname as.rsi
|
||||||
#' @param x vector
|
#' @param x vector
|
||||||
#' @details The function \code{is.rsi.eligible} returns \code{TRUE} when a columns contains only valid antimicrobial interpretations (S and/or I and/or R), and \code{FALSE} otherwise.
|
#' @details The function \code{is.rsi.eligible} returns \code{TRUE} when a columns contains only valid antimicrobial interpretations (S and/or I and/or R), and \code{FALSE} otherwise.
|
||||||
#' @return Ordered factor with new class \code{rsi} and new attribute \code{package}
|
#' @return Ordered factor with new class \code{rsi}
|
||||||
#' @keywords rsi
|
#' @keywords rsi
|
||||||
#' @export
|
#' @export
|
||||||
#' @importFrom dplyr %>%
|
#' @importFrom dplyr %>%
|
||||||
@ -81,9 +81,8 @@ as.rsi <- function(x) {
|
|||||||
list_missing, call. = FALSE)
|
list_missing, call. = FALSE)
|
||||||
}
|
}
|
||||||
|
|
||||||
x <- x %>% factor(levels = c("S", "I", "R"), ordered = TRUE)
|
x <- factor(x, levels = c("S", "I", "R"), ordered = TRUE)
|
||||||
class(x) <- c('rsi', 'ordered', 'factor')
|
class(x) <- c('rsi', 'ordered', 'factor')
|
||||||
attr(x, 'package') <- 'AMR'
|
|
||||||
x
|
x
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
37
README.md
37
README.md
@ -202,7 +202,7 @@ Adjust it with any parameter you know from the `ggplot2` package:
|
|||||||
septic_patients %>%
|
septic_patients %>%
|
||||||
select(amox, nitr, fosf, trim, cipr) %>%
|
select(amox, nitr, fosf, trim, cipr) %>%
|
||||||
ggplot_rsi(datalabels = FALSE,
|
ggplot_rsi(datalabels = FALSE,
|
||||||
width = 0.5, colour = "black", size = 1, linetype = 2, alpha = 0.25)
|
width = 0.5, colour = "purple", size = 1, linetype = 2, alpha = 0.5)
|
||||||
```
|
```
|
||||||
|
|
||||||
![example_3_rsi](man/figures/rsi_example3.png)
|
![example_3_rsi](man/figures/rsi_example3.png)
|
||||||
@ -225,6 +225,41 @@ septic_patients %>%
|
|||||||
|
|
||||||
You could use this to group on anything in your plots: Gram stain, age (group), genus, geographic location, et cetera.
|
You could use this to group on anything in your plots: Gram stain, age (group), genus, geographic location, et cetera.
|
||||||
|
|
||||||
|
Is there a significant difference between hospital A and D when it comes to Fosfomycin?
|
||||||
|
```r
|
||||||
|
check_A_and_D <- septic_patients %>%
|
||||||
|
filter(hospital_id %in% c("A", "D")) %>% # filter on only hospitals A and D
|
||||||
|
select(hospital_id, fosf) %>% # select the hospitals and fosfomycin
|
||||||
|
group_by(hospital_id) %>%
|
||||||
|
count_df(combine_IR = TRUE) %>% # count all isolates per group (hospital_id)
|
||||||
|
tidyr::spread(hospital_id, Value) %>% # transform output so A and D are columns
|
||||||
|
select(A, D) %>% # and select these only
|
||||||
|
as.matrix() # transform to good old matrix for fisher.test
|
||||||
|
|
||||||
|
check_A_and_D
|
||||||
|
# A D
|
||||||
|
# [1,] 24 33
|
||||||
|
# [2,] 25 77
|
||||||
|
```
|
||||||
|
|
||||||
|
Total sum is lower than 1,000 so we'd prefer a [Fisher's exact test](https://en.wikipedia.org/wiki/Fisher%27s_exact_test), not a [*G*-test](https://en.wikipedia.org/wiki/G-test) (or its formerly used equivalent, the famous [Chi<sup>2</sup> test](https://en.wikipedia.org/wiki/Chi-squared_test)):
|
||||||
|
```
|
||||||
|
fisher.test(check_A_and_D)
|
||||||
|
#
|
||||||
|
# Fisher's Exact Test for Count Data
|
||||||
|
#
|
||||||
|
# data: .
|
||||||
|
# p-value = 0.03104
|
||||||
|
# alternative hypothesis: true odds ratio is not equal to 1
|
||||||
|
# 95 percent confidence interval:
|
||||||
|
# 1.054283 4.735995
|
||||||
|
# sample estimates:
|
||||||
|
# odds ratio
|
||||||
|
# 2.228006
|
||||||
|
```
|
||||||
|
|
||||||
|
Well, there you go!
|
||||||
|
|
||||||
#### MIC
|
#### MIC
|
||||||
|
|
||||||
```r
|
```r
|
||||||
|
Binary file not shown.
@ -3,15 +3,24 @@
|
|||||||
\name{EUCAST_rules}
|
\name{EUCAST_rules}
|
||||||
\alias{EUCAST_rules}
|
\alias{EUCAST_rules}
|
||||||
\alias{interpretive_reading}
|
\alias{interpretive_reading}
|
||||||
\title{EUCAST expert rules}
|
\title{EUCAST rules}
|
||||||
\source{
|
\source{
|
||||||
EUCAST Expert Rules Version 2.0: \cr
|
\itemize{
|
||||||
|
\item{
|
||||||
|
EUCAST Expert Rules. Version 2.0, 2012. \cr
|
||||||
Leclercq et al. \strong{EUCAST expert rules in antimicrobial susceptibility testing.} \emph{Clin Microbiol Infect.} 2013;19(2):141-60. \cr
|
Leclercq et al. \strong{EUCAST expert rules in antimicrobial susceptibility testing.} \emph{Clin Microbiol Infect.} 2013;19(2):141-60. \cr
|
||||||
\url{https://doi.org/10.1111/j.1469-0691.2011.03703.x} \cr
|
\url{https://doi.org/10.1111/j.1469-0691.2011.03703.x}
|
||||||
\cr
|
}
|
||||||
EUCAST Expert Rules Version 3.1 (Intrinsic Resistance and Exceptional Phenotypes Tables): \cr
|
\item{
|
||||||
|
EUCAST Expert Rules, Intrinsic Resistance and Exceptional Phenotypes Tables. Version 3.1, 2016. \cr
|
||||||
\url{http://www.eucast.org/fileadmin/src/media/PDFs/EUCAST_files/Expert_Rules/Expert_rules_intrinsic_exceptional_V3.1.pdf}
|
\url{http://www.eucast.org/fileadmin/src/media/PDFs/EUCAST_files/Expert_Rules/Expert_rules_intrinsic_exceptional_V3.1.pdf}
|
||||||
}
|
}
|
||||||
|
\item{
|
||||||
|
EUCAST Breakpoint tables for interpretation of MICs and zone diameters. Version 8.1, 2018. \cr
|
||||||
|
\url{http://www.eucast.org/fileadmin/src/media/PDFs/EUCAST_files/Breakpoint_tables/v_8.1_Breakpoint_Tables.xlsx}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
\usage{
|
\usage{
|
||||||
EUCAST_rules(tbl, col_mo = "mo", info = TRUE, amcl = "amcl",
|
EUCAST_rules(tbl, col_mo = "mo", info = TRUE, amcl = "amcl",
|
||||||
amik = "amik", amox = "amox", ampi = "ampi", azit = "azit",
|
amik = "amik", amox = "amox", ampi = "ampi", azit = "azit",
|
||||||
@ -25,11 +34,11 @@ EUCAST_rules(tbl, col_mo = "mo", info = TRUE, amcl = "amcl",
|
|||||||
line = "line", mero = "mero", mezl = "mezl", mino = "mino",
|
line = "line", mero = "mero", mezl = "mezl", mino = "mino",
|
||||||
moxi = "moxi", nali = "nali", neom = "neom", neti = "neti",
|
moxi = "moxi", nali = "nali", neom = "neom", neti = "neti",
|
||||||
nitr = "nitr", norf = "norf", novo = "novo", oflo = "oflo",
|
nitr = "nitr", norf = "norf", novo = "novo", oflo = "oflo",
|
||||||
peni = "peni", pita = "pita", poly = "poly", pris = "pris",
|
oxac = "oxac", peni = "peni", pita = "pita", poly = "poly",
|
||||||
qida = "qida", rifa = "rifa", roxi = "roxi", siso = "siso",
|
pris = "pris", qida = "qida", rifa = "rifa", roxi = "roxi",
|
||||||
teic = "teic", tetr = "tetr", tica = "tica", tige = "tige",
|
siso = "siso", teic = "teic", tetr = "tetr", tica = "tica",
|
||||||
tobr = "tobr", trim = "trim", trsu = "trsu", vanc = "vanc",
|
tige = "tige", tobr = "tobr", trim = "trim", trsu = "trsu",
|
||||||
col_bactid = "bactid")
|
vanc = "vanc", col_bactid = "bactid", verbose = FALSE)
|
||||||
|
|
||||||
interpretive_reading(...)
|
interpretive_reading(...)
|
||||||
}
|
}
|
||||||
@ -40,23 +49,25 @@ interpretive_reading(...)
|
|||||||
|
|
||||||
\item{info}{print progress}
|
\item{info}{print progress}
|
||||||
|
|
||||||
\item{amcl, amik, amox, ampi, azit, azlo, aztr, cefa, cfep, cfot, cfox, cfra, cfta, cftr, cfur, chlo, cipr, clar, clin, clox, coli, czol, dapt, doxy, erta, eryt, fosf, fusi, gent, imip, kana, levo, linc, line, mero, mezl, mino, moxi, nali, neom, neti, nitr, norf, novo, oflo, peni, pita, poly, pris, qida, rifa, roxi, siso, teic, tetr, tica, tige, tobr, trim, trsu, vanc}{column name of an antibiotic. Use \code{NA} to skip a column, like \code{tica = NA}. Non-existing columns will anyway be skipped. See the Antibiotics section for an explanation of the abbreviations.}
|
\item{amcl, amik, amox, ampi, azit, azlo, aztr, cefa, cfep, cfot, cfox, cfra, cfta, cftr, cfur, chlo, cipr, clar, clin, clox, coli, czol, dapt, doxy, erta, eryt, fosf, fusi, gent, imip, kana, levo, linc, line, mero, mezl, mino, moxi, nali, neom, neti, nitr, norf, novo, oflo, oxac, peni, pita, poly, pris, qida, rifa, roxi, siso, teic, tetr, tica, tige, tobr, trim, trsu, vanc}{column name of an antibiotic. Use \code{NA} to skip a column, like \code{tica = NA}. Non-existing columns will anyway be skipped. See the Antibiotics section for an explanation of the abbreviations.}
|
||||||
|
|
||||||
\item{col_bactid}{Deprecated. Use \code{col_mo} instead.}
|
\item{col_bactid}{Deprecated. Use \code{col_mo} instead.}
|
||||||
|
|
||||||
|
\item{verbose}{a logical to indicate whether extensive info should be printed to the console about which rows and columns are effected with their old and new values}
|
||||||
|
|
||||||
\item{...}{parameters that are passed on to \code{EUCAST_rules}}
|
\item{...}{parameters that are passed on to \code{EUCAST_rules}}
|
||||||
}
|
}
|
||||||
\value{
|
\value{
|
||||||
table with edited variables of antibiotics.
|
table with edited variables of antibiotics.
|
||||||
}
|
}
|
||||||
\description{
|
\description{
|
||||||
Apply expert rules (like intrinsic resistance), as defined by the European Committee on Antimicrobial Susceptibility Testing (EUCAST, \url{http://eucast.org}), see \emph{Source}.
|
Apply susceptibility rules as defined by the European Committee on Antimicrobial Susceptibility Testing (EUCAST, \url{http://eucast.org}), see \emph{Source}. This includes (1) expert rules, (2) intrinsic resistance and (3) inferred resistance as defined in their breakpoint tables.
|
||||||
}
|
}
|
||||||
\section{Antibiotics}{
|
\section{Antibiotics}{
|
||||||
|
|
||||||
Abbrevations of the column containing antibiotics:
|
Abbrevations of the column containing antibiotics:
|
||||||
|
|
||||||
\strong{amcl}: amoxicillin and beta-lactamase inhibitor (\emph{J01CR02}),
|
\strong{amcl}: amoxicillin+clavulanic acid (\emph{J01CR02}),
|
||||||
\strong{amik}: amikacin (\emph{J01GB06}),
|
\strong{amik}: amikacin (\emph{J01GB06}),
|
||||||
\strong{amox}: amoxicillin (\emph{J01CA04}),
|
\strong{amox}: amoxicillin (\emph{J01CA04}),
|
||||||
\strong{ampi}: ampicillin (\emph{J01CA01}),
|
\strong{ampi}: ampicillin (\emph{J01CA01}),
|
||||||
@ -85,7 +96,7 @@ Abbrevations of the column containing antibiotics:
|
|||||||
\strong{fosf}: fosfomycin (\emph{J01XX01}),
|
\strong{fosf}: fosfomycin (\emph{J01XX01}),
|
||||||
\strong{fusi}: fusidic acid (\emph{J01XC01}),
|
\strong{fusi}: fusidic acid (\emph{J01XC01}),
|
||||||
\strong{gent}: gentamicin (\emph{J01GB03}),
|
\strong{gent}: gentamicin (\emph{J01GB03}),
|
||||||
\strong{imip}: imipenem and cilastatin (\emph{J01DH51}),
|
\strong{imip}: imipenem (\emph{J01DH51}),
|
||||||
\strong{kana}: kanamycin (\emph{J01GB04}),
|
\strong{kana}: kanamycin (\emph{J01GB04}),
|
||||||
\strong{levo}: levofloxacin (\emph{J01MA12}),
|
\strong{levo}: levofloxacin (\emph{J01MA12}),
|
||||||
\strong{linc}: lincomycin (\emph{J01FF02}),
|
\strong{linc}: lincomycin (\emph{J01FF02}),
|
||||||
@ -101,8 +112,8 @@ Abbrevations of the column containing antibiotics:
|
|||||||
\strong{norf}: norfloxacin (\emph{J01MA06}),
|
\strong{norf}: norfloxacin (\emph{J01MA06}),
|
||||||
\strong{novo}: novobiocin (an ATCvet code: \emph{QJ01XX95}),
|
\strong{novo}: novobiocin (an ATCvet code: \emph{QJ01XX95}),
|
||||||
\strong{oflo}: ofloxacin (\emph{J01MA01}),
|
\strong{oflo}: ofloxacin (\emph{J01MA01}),
|
||||||
\strong{peni}: penicillins, combinations with other antibacterials (\emph{J01RA01}),
|
\strong{peni}: penicillin (\emph{J01RA01}),
|
||||||
\strong{pita}: piperacillin and beta-lactamase inhibitor (\emph{J01CR05}),
|
\strong{pita}: piperacillin+tazobactam (\emph{J01CR05}),
|
||||||
\strong{poly}: polymyxin B (\emph{J01XB02}),
|
\strong{poly}: polymyxin B (\emph{J01XB02}),
|
||||||
\strong{pris}: pristinamycin (\emph{J01FG01}),
|
\strong{pris}: pristinamycin (\emph{J01FG01}),
|
||||||
\strong{qida}: quinupristin/dalfopristin (\emph{J01FG02}),
|
\strong{qida}: quinupristin/dalfopristin (\emph{J01FG02}),
|
||||||
|
@ -175,7 +175,7 @@ When \code{country} will be left blank, guidelines will be taken from EUCAST Exp
|
|||||||
|
|
||||||
Abbrevations of the column containing antibiotics:
|
Abbrevations of the column containing antibiotics:
|
||||||
|
|
||||||
\strong{amcl}: amoxicillin and beta-lactamase inhibitor (\emph{J01CR02}),
|
\strong{amcl}: amoxicillin+clavulanic acid (\emph{J01CR02}),
|
||||||
\strong{amik}: amikacin (\emph{J01GB06}),
|
\strong{amik}: amikacin (\emph{J01GB06}),
|
||||||
\strong{amox}: amoxicillin (\emph{J01CA04}),
|
\strong{amox}: amoxicillin (\emph{J01CA04}),
|
||||||
\strong{ampi}: ampicillin (\emph{J01CA01}),
|
\strong{ampi}: ampicillin (\emph{J01CA01}),
|
||||||
@ -204,7 +204,7 @@ Abbrevations of the column containing antibiotics:
|
|||||||
\strong{fosf}: fosfomycin (\emph{J01XX01}),
|
\strong{fosf}: fosfomycin (\emph{J01XX01}),
|
||||||
\strong{fusi}: fusidic acid (\emph{J01XC01}),
|
\strong{fusi}: fusidic acid (\emph{J01XC01}),
|
||||||
\strong{gent}: gentamicin (\emph{J01GB03}),
|
\strong{gent}: gentamicin (\emph{J01GB03}),
|
||||||
\strong{imip}: imipenem and cilastatin (\emph{J01DH51}),
|
\strong{imip}: imipenem (\emph{J01DH51}),
|
||||||
\strong{kana}: kanamycin (\emph{J01GB04}),
|
\strong{kana}: kanamycin (\emph{J01GB04}),
|
||||||
\strong{levo}: levofloxacin (\emph{J01MA12}),
|
\strong{levo}: levofloxacin (\emph{J01MA12}),
|
||||||
\strong{linc}: lincomycin (\emph{J01FF02}),
|
\strong{linc}: lincomycin (\emph{J01FF02}),
|
||||||
@ -220,8 +220,8 @@ Abbrevations of the column containing antibiotics:
|
|||||||
\strong{norf}: norfloxacin (\emph{J01MA06}),
|
\strong{norf}: norfloxacin (\emph{J01MA06}),
|
||||||
\strong{novo}: novobiocin (an ATCvet code: \emph{QJ01XX95}),
|
\strong{novo}: novobiocin (an ATCvet code: \emph{QJ01XX95}),
|
||||||
\strong{oflo}: ofloxacin (\emph{J01MA01}),
|
\strong{oflo}: ofloxacin (\emph{J01MA01}),
|
||||||
\strong{peni}: penicillins, combinations with other antibacterials (\emph{J01RA01}),
|
\strong{peni}: penicillin (\emph{J01RA01}),
|
||||||
\strong{pita}: piperacillin and beta-lactamase inhibitor (\emph{J01CR05}),
|
\strong{pita}: piperacillin+tazobactam (\emph{J01CR05}),
|
||||||
\strong{poly}: polymyxin B (\emph{J01XB02}),
|
\strong{poly}: polymyxin B (\emph{J01XB02}),
|
||||||
\strong{pris}: pristinamycin (\emph{J01FG01}),
|
\strong{pris}: pristinamycin (\emph{J01FG01}),
|
||||||
\strong{qida}: quinupristin/dalfopristin (\emph{J01FG02}),
|
\strong{qida}: quinupristin/dalfopristin (\emph{J01FG02}),
|
||||||
|
@ -15,7 +15,7 @@ is.mic(x)
|
|||||||
\item{na.rm}{a logical indicating whether missing values should be removed}
|
\item{na.rm}{a logical indicating whether missing values should be removed}
|
||||||
}
|
}
|
||||||
\value{
|
\value{
|
||||||
Ordered factor with new class \code{mic} and new attribute \code{package}
|
Ordered factor with new class \code{mic}
|
||||||
}
|
}
|
||||||
\description{
|
\description{
|
||||||
This transforms a vector to a new class \code{mic}, which is an ordered factor with valid MIC values as levels. Invalid MIC values will be translated as \code{NA} with a warning.
|
This transforms a vector to a new class \code{mic}, which is an ordered factor with valid MIC values as levels. Invalid MIC values will be translated as \code{NA} with a warning.
|
||||||
|
@ -16,7 +16,7 @@ is.rsi.eligible(x)
|
|||||||
\item{x}{vector}
|
\item{x}{vector}
|
||||||
}
|
}
|
||||||
\value{
|
\value{
|
||||||
Ordered factor with new class \code{rsi} and new attribute \code{package}
|
Ordered factor with new class \code{rsi}
|
||||||
}
|
}
|
||||||
\description{
|
\description{
|
||||||
This transforms a vector to a new class \code{rsi}, which is an ordered factor with levels \code{S < I < R}. Invalid antimicrobial interpretations will be translated as \code{NA} with a warning.
|
This transforms a vector to a new class \code{rsi}, which is an ordered factor with levels \code{S < I < R}. Invalid antimicrobial interpretations will be translated as \code{NA} with a warning.
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 27 KiB After Width: | Height: | Size: 28 KiB |
Binary file not shown.
Before Width: | Height: | Size: 28 KiB After Width: | Height: | Size: 29 KiB |
Binary file not shown.
Before Width: | Height: | Size: 20 KiB After Width: | Height: | Size: 20 KiB |
@ -4,7 +4,7 @@
|
|||||||
\name{septic_patients}
|
\name{septic_patients}
|
||||||
\alias{septic_patients}
|
\alias{septic_patients}
|
||||||
\title{Data set with 2000 blood culture isolates of septic patients}
|
\title{Data set with 2000 blood culture isolates of septic patients}
|
||||||
\format{A \code{\link{tibble}} with 2,000 observations and 49 variables:
|
\format{A \code{\link{data.frame}} with 2,000 observations and 49 variables:
|
||||||
\describe{
|
\describe{
|
||||||
\item{\code{date}}{date of receipt at the laboratory}
|
\item{\code{date}}{date of receipt at the laboratory}
|
||||||
\item{\code{hospital_id}}{ID of the hospital, from A to D}
|
\item{\code{hospital_id}}{ID of the hospital, from A to D}
|
||||||
|
@ -2,18 +2,18 @@ context("count.R")
|
|||||||
|
|
||||||
test_that("counts work", {
|
test_that("counts work", {
|
||||||
# amox resistance in `septic_patients`
|
# amox resistance in `septic_patients`
|
||||||
expect_equal(count_R(septic_patients$amox), 662)
|
expect_equal(count_R(septic_patients$amox), 683)
|
||||||
expect_equal(count_I(septic_patients$amox), 3)
|
expect_equal(count_I(septic_patients$amox), 3)
|
||||||
expect_equal(count_S(septic_patients$amox), 335)
|
expect_equal(count_S(septic_patients$amox), 486)
|
||||||
expect_equal(count_R(septic_patients$amox) + count_I(septic_patients$amox),
|
expect_equal(count_R(septic_patients$amox) + count_I(septic_patients$amox),
|
||||||
count_IR(septic_patients$amox))
|
count_IR(septic_patients$amox))
|
||||||
expect_equal(count_S(septic_patients$amox) + count_I(septic_patients$amox),
|
expect_equal(count_S(septic_patients$amox) + count_I(septic_patients$amox),
|
||||||
count_SI(septic_patients$amox))
|
count_SI(septic_patients$amox))
|
||||||
|
|
||||||
library(dplyr)
|
library(dplyr)
|
||||||
expect_equal(septic_patients %>% count_S(amcl), 1057)
|
expect_equal(septic_patients %>% count_S(amcl), 1291)
|
||||||
expect_equal(septic_patients %>% count_S(amcl, gent), 1396)
|
expect_equal(septic_patients %>% count_S(amcl, gent), 1609)
|
||||||
expect_equal(septic_patients %>% count_all(amcl, gent), 1517)
|
expect_equal(septic_patients %>% count_all(amcl, gent), 1747)
|
||||||
expect_identical(septic_patients %>% count_all(amcl, gent),
|
expect_identical(septic_patients %>% count_all(amcl, gent),
|
||||||
septic_patients %>% count_S(amcl, gent) +
|
septic_patients %>% count_S(amcl, gent) +
|
||||||
septic_patients %>% count_IR(amcl, gent))
|
septic_patients %>% count_IR(amcl, gent))
|
||||||
|
@ -8,14 +8,12 @@ test_that("EUCAST rules work", {
|
|||||||
expect_identical(colnames(septic_patients),
|
expect_identical(colnames(septic_patients),
|
||||||
colnames(suppressWarnings(EUCAST_rules(septic_patients))))
|
colnames(suppressWarnings(EUCAST_rules(septic_patients))))
|
||||||
|
|
||||||
a <- data.frame(mo =
|
a <- data.frame(mo = c("KLEPNE", # Klebsiella pneumoniae
|
||||||
c("KLEPNE", # Klebsiella pneumoniae
|
|
||||||
"PSEAER", # Pseudomonas aeruginosa
|
"PSEAER", # Pseudomonas aeruginosa
|
||||||
"ENTAER"), # Enterobacter aerogenes
|
"ENTAER"), # Enterobacter aerogenes
|
||||||
amox = "-", # Amoxicillin
|
amox = "-", # Amoxicillin
|
||||||
stringsAsFactors = FALSE)
|
stringsAsFactors = FALSE)
|
||||||
b <- data.frame(mo =
|
b <- data.frame(mo = c("KLEPNE", # Klebsiella pneumoniae
|
||||||
c("KLEPNE", # Klebsiella pneumoniae
|
|
||||||
"PSEAER", # Pseudomonas aeruginosa
|
"PSEAER", # Pseudomonas aeruginosa
|
||||||
"ENTAER"), # Enterobacter aerogenes
|
"ENTAER"), # Enterobacter aerogenes
|
||||||
amox = "R", # Amoxicillin
|
amox = "R", # Amoxicillin
|
||||||
@ -23,13 +21,11 @@ test_that("EUCAST rules work", {
|
|||||||
expect_identical(suppressWarnings(EUCAST_rules(a, info = FALSE)), b)
|
expect_identical(suppressWarnings(EUCAST_rules(a, info = FALSE)), b)
|
||||||
expect_identical(suppressWarnings(interpretive_reading(a, info = TRUE)), b)
|
expect_identical(suppressWarnings(interpretive_reading(a, info = TRUE)), b)
|
||||||
|
|
||||||
a <- data.frame(mo =
|
a <- data.frame(mo = c("STAAUR", # Staphylococcus aureus
|
||||||
c("STAAUR", # Staphylococcus aureus
|
|
||||||
"STCGRA"), # Streptococcus pyognenes (Lancefield Group A)
|
"STCGRA"), # Streptococcus pyognenes (Lancefield Group A)
|
||||||
coli = "-", # Colistin
|
coli = "-", # Colistin
|
||||||
stringsAsFactors = FALSE)
|
stringsAsFactors = FALSE)
|
||||||
b <- data.frame(mo =
|
b <- data.frame(mo = c("STAAUR", # Staphylococcus aureus
|
||||||
c("STAAUR", # Staphylococcus aureus
|
|
||||||
"STCGRA"), # Streptococcus pyognenes (Lancefield Group A)
|
"STCGRA"), # Streptococcus pyognenes (Lancefield Group A)
|
||||||
coli = "R", # Colistin
|
coli = "R", # Colistin
|
||||||
stringsAsFactors = FALSE)
|
stringsAsFactors = FALSE)
|
||||||
@ -48,17 +44,35 @@ test_that("EUCAST rules work", {
|
|||||||
unique() %>%
|
unique() %>%
|
||||||
as.character()),
|
as.character()),
|
||||||
"R")
|
"R")
|
||||||
|
|
||||||
# azit and clar must be equal to eryt
|
# azit and clar must be equal to eryt
|
||||||
expect_equal(suppressWarnings(
|
a <- suppressWarnings(
|
||||||
septic_patients %>%
|
septic_patients %>%
|
||||||
mutate(azit = as.rsi("R"),
|
transmute(mo,
|
||||||
|
eryt,
|
||||||
|
azit = as.rsi("R"),
|
||||||
clar = as.rsi("R")) %>%
|
clar = as.rsi("R")) %>%
|
||||||
EUCAST_rules(col_mo = "mo") %>%
|
EUCAST_rules(col_mo = "mo") %>%
|
||||||
pull(clar)),
|
pull(clar))
|
||||||
suppressWarnings(
|
b <- suppressWarnings(
|
||||||
septic_patients %>%
|
septic_patients %>%
|
||||||
|
select(mo, eryt) %>%
|
||||||
EUCAST_rules(col_mo = "mo") %>%
|
EUCAST_rules(col_mo = "mo") %>%
|
||||||
left_join_microorganisms() %>%
|
pull(eryt))
|
||||||
pull(eryt)))
|
|
||||||
|
expect_identical(a[!is.na(b)],
|
||||||
|
b[!is.na(b)])
|
||||||
|
|
||||||
|
# amox is inferred by benzylpenicillin in Kingella kingae
|
||||||
|
expect_equal(
|
||||||
|
as.list(EUCAST_rules(
|
||||||
|
data.frame(mo = as.mo("Kingella kingae"),
|
||||||
|
peni = "S",
|
||||||
|
amox = "-",
|
||||||
|
stringsAsFactors = FALSE)
|
||||||
|
, info = FALSE))$amox,
|
||||||
|
"S")
|
||||||
|
|
||||||
|
expect_message(suppressWarnings(EUCAST_rules(septic_patients, verbose = TRUE)))
|
||||||
|
|
||||||
})
|
})
|
||||||
|
@ -2,8 +2,8 @@ context("portion.R")
|
|||||||
|
|
||||||
test_that("portions works", {
|
test_that("portions works", {
|
||||||
# amox resistance in `septic_patients`
|
# amox resistance in `septic_patients`
|
||||||
expect_equal(portion_R(septic_patients$amox), 0.662, tolerance = 0.0001)
|
expect_equal(portion_R(septic_patients$amox), 0.5827645, tolerance = 0.0001)
|
||||||
expect_equal(portion_I(septic_patients$amox), 0.003, tolerance = 0.0001)
|
expect_equal(portion_I(septic_patients$amox), 0.0025597, tolerance = 0.0001)
|
||||||
expect_equal(1 - portion_R(septic_patients$amox) - portion_I(septic_patients$amox),
|
expect_equal(1 - portion_R(septic_patients$amox) - portion_I(septic_patients$amox),
|
||||||
portion_S(septic_patients$amox))
|
portion_S(septic_patients$amox))
|
||||||
expect_equal(portion_R(septic_patients$amox) + portion_I(septic_patients$amox),
|
expect_equal(portion_R(septic_patients$amox) + portion_I(septic_patients$amox),
|
||||||
@ -12,17 +12,17 @@ test_that("portions works", {
|
|||||||
portion_SI(septic_patients$amox))
|
portion_SI(septic_patients$amox))
|
||||||
|
|
||||||
expect_equal(septic_patients %>% portion_S(amcl),
|
expect_equal(septic_patients %>% portion_S(amcl),
|
||||||
0.6706853,
|
0.7062363,
|
||||||
tolerance = 0.001)
|
tolerance = 0.001)
|
||||||
expect_equal(septic_patients %>% portion_S(amcl, gent),
|
expect_equal(septic_patients %>% portion_S(amcl, gent),
|
||||||
0.9202373,
|
0.9210074,
|
||||||
tolerance = 0.001)
|
tolerance = 0.001)
|
||||||
|
|
||||||
# amcl+genta susceptibility around 92.1%
|
# amcl+genta susceptibility around 92.1%
|
||||||
expect_equal(suppressWarnings(rsi(septic_patients$amcl,
|
expect_equal(suppressWarnings(rsi(septic_patients$amcl,
|
||||||
septic_patients$gent,
|
septic_patients$gent,
|
||||||
interpretation = "S")),
|
interpretation = "S")),
|
||||||
0.9202373,
|
0.9210074,
|
||||||
tolerance = 0.000001)
|
tolerance = 0.000001)
|
||||||
|
|
||||||
# percentages
|
# percentages
|
||||||
@ -57,7 +57,7 @@ test_that("portions works", {
|
|||||||
septic_patients$gent)))
|
septic_patients$gent)))
|
||||||
expect_equal(suppressWarnings(n_rsi(as.character(septic_patients$amcl,
|
expect_equal(suppressWarnings(n_rsi(as.character(septic_patients$amcl,
|
||||||
septic_patients$gent))),
|
septic_patients$gent))),
|
||||||
1576)
|
1828)
|
||||||
|
|
||||||
# check for errors
|
# check for errors
|
||||||
expect_error(portion_IR("test", minimum = "test"))
|
expect_error(portion_IR("test", minimum = "test"))
|
||||||
@ -83,16 +83,16 @@ test_that("portions works", {
|
|||||||
})
|
})
|
||||||
|
|
||||||
test_that("old rsi works", {
|
test_that("old rsi works", {
|
||||||
# amox resistance in `septic_patients` should be around 66.33%
|
# amox resistance in `septic_patients` should be around 58.53%
|
||||||
expect_equal(suppressWarnings(rsi(septic_patients$amox)), 0.665, tolerance = 0.0001)
|
expect_equal(suppressWarnings(rsi(septic_patients$amox)), 0.5853, tolerance = 0.0001)
|
||||||
expect_equal(suppressWarnings(rsi(septic_patients$amox, interpretation = "S")), 1 - 0.665, tolerance = 0.0001)
|
expect_equal(suppressWarnings(rsi(septic_patients$amox, interpretation = "S")), 1 - 0.5853, tolerance = 0.0001)
|
||||||
|
|
||||||
# pita+genta susceptibility around 98.09%
|
# pita+genta susceptibility around 98.09%
|
||||||
expect_equal(suppressWarnings(rsi(septic_patients$pita,
|
expect_equal(suppressWarnings(rsi(septic_patients$pita,
|
||||||
septic_patients$gent,
|
septic_patients$gent,
|
||||||
interpretation = "S",
|
interpretation = "S",
|
||||||
info = TRUE)),
|
info = TRUE)),
|
||||||
0.9540412,
|
0.9498886,
|
||||||
tolerance = 0.0001)
|
tolerance = 0.0001)
|
||||||
|
|
||||||
# count of cases
|
# count of cases
|
||||||
|
Loading…
Reference in New Issue
Block a user