1
0
mirror of https://github.com/msberends/AMR.git synced 2025-01-14 00:11:50 +01:00

eucast updates

This commit is contained in:
dr. M.S. (Matthijs) Berends 2018-11-01 17:06:08 +01:00
parent d3f5236690
commit f7687557c9
5 changed files with 147 additions and 76 deletions

View File

@ -13,6 +13,7 @@
* Better error handling when rules cannot be applied (i.e. new values could not be inserted) * Better error handling when rules cannot be applied (i.e. new values could not be inserted)
* The number of affected values will now only be measured once per row/column combination * The number of affected values will now only be measured once per row/column combination
* Data set `septic_patients` now reflects these changes * Data set `septic_patients` now reflects these changes
* Small fixes to EUCAST clinical breakpoint rules
* Tremendous speed improvement for `as.mo` (and subsequently all `mo_*` functions), as empty values wil be ignored *a priori* * Tremendous speed improvement for `as.mo` (and subsequently all `mo_*` functions), as empty values wil be ignored *a priori*
* Fewer than 3 characters as input for `as.mo` will return NA * Fewer than 3 characters as input for `as.mo` will return NA
* 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)

View File

@ -23,7 +23,7 @@
#' @param col_mo column name of the microbial ID in \code{tbl} - values in this column should be present in \code{microorganisms$mo}, see \code{\link{microorganisms}} #' @param col_mo column name of the microbial ID in \code{tbl} - values in this column should be present in \code{microorganisms$mo}, see \code{\link{microorganisms}}
#' @param info print progress #' @param info print progress
#' @param rules a character vector that specifies which rules should be applied - one or more of \code{c("breakpoints", "expert", "other", "all")} #' @param rules a character vector that specifies which rules should be applied - one or more of \code{c("breakpoints", "expert", "other", "all")}
#' @param 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, see Details #' @param 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,pipe,pita,poly,pris,qida,rifa,roxi,siso,teic,tetr,tica,tige,tobr,trim,trsu,vanc column name of an antibiotic, see Details
#' @param col_bactid Deprecated. Use \code{col_mo} instead. #' @param col_bactid Deprecated. Use \code{col_mo} instead.
#' @param verbose a logical to indicate whether extensive info should be returned as a \code{data.frame} with info about which rows and columns are effected #' @param verbose a logical to indicate whether extensive info should be returned as a \code{data.frame} with info about which rows and columns are effected
#' @param ... parameters that are passed on to \code{EUCAST_rules} #' @param ... parameters that are passed on to \code{EUCAST_rules}
@ -77,6 +77,7 @@
#' \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}: penicillin (\emph{J01RA01}), #' \strong{peni}: penicillin (\emph{J01RA01}),
#' \strong{pipe}: piperacillin (\emph{J01CA12}),
#' \strong{pita}: piperacillin+tazobactam (\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}),
@ -199,6 +200,7 @@ EUCAST_rules <- function(tbl,
oflo = 'oflo', oflo = 'oflo',
oxac = 'oxac', oxac = 'oxac',
peni = 'peni', peni = 'peni',
pipe = 'pipe',
pita = 'pita', pita = 'pita',
poly = 'poly', poly = 'poly',
pris = 'pris', pris = 'pris',
@ -257,8 +259,8 @@ EUCAST_rules <- function(tbl,
cfox, cfta, cftr, cfur, chlo, cipr, clar, clin, clox, coli, cfox, cfta, cftr, cfur, chlo, cipr, clar, clin, clox, coli,
czol, dapt, doxy, erta, eryt, fosf, fusi, gent, imip, kana, czol, dapt, doxy, erta, eryt, fosf, fusi, gent, imip, kana,
levo, linc, line, mero, mezl, mino, moxi, nali, neom, neti, nitr, levo, linc, line, mero, mezl, mino, moxi, nali, neom, neti, nitr,
novo, norf, oflo, oxac, peni, pita, poly, pris, qida, rifa, roxi, siso, novo, norf, oflo, oxac, peni, pipe, pita, poly, pris, qida, rifa,
teic, tetr, tica, tige, tobr, trim, trsu, vanc) roxi, siso, teic, tetr, tica, tige, tobr, trim, trsu, vanc)
col.list <- check_available_columns(tbl = tbl, col.list = col.list, info = info) col.list <- check_available_columns(tbl = tbl, col.list = col.list, info = info)
amcl <- col.list[amcl] amcl <- col.list[amcl]
amik <- col.list[amik] amik <- col.list[amik]
@ -307,6 +309,7 @@ EUCAST_rules <- function(tbl,
oflo <- col.list[oflo] oflo <- col.list[oflo]
oxac <- col.list[oxac] oxac <- col.list[oxac]
peni <- col.list[peni] peni <- col.list[peni]
pipe <- col.list[pipe]
pita <- col.list[pita] pita <- col.list[pita]
poly <- col.list[poly] poly <- col.list[poly]
pris <- col.list[pris] pris <- col.list[pris]
@ -404,7 +407,7 @@ EUCAST_rules <- function(tbl,
cephalosporins <- c(cfep, cfot, cfox, cfra, cfta, cftr, cfur, czol) cephalosporins <- c(cfep, cfot, cfox, cfra, cfta, cftr, cfur, czol)
carbapenems <- c(erta, imip, mero) carbapenems <- c(erta, imip, mero)
aminopenicillins <- c(ampi, amox) aminopenicillins <- c(ampi, amox)
ureidopenicillins <- c(pita, azlo, mezl) ureidopenicillins <- c(pipe, pita, azlo, mezl)
fluoroquinolones <- c(oflo, cipr, norf, levo, moxi) fluoroquinolones <- c(oflo, cipr, norf, levo, moxi)
all_betalactam <- c(aminopenicillins, ureidopenicillins, cephalosporins, carbapenems, amcl, oxac, clox, peni) all_betalactam <- c(aminopenicillins, ureidopenicillins, cephalosporins, carbapenems, amcl, oxac, clox, peni)
@ -483,7 +486,7 @@ EUCAST_rules <- function(tbl,
rows = which(tbl$genus == "Staphylococcus" rows = which(tbl$genus == "Staphylococcus"
& tbl[, peni] == 'S' & tbl[, peni] == 'S'
& tbl[, cfox] == 'S'), & tbl[, cfox] == 'S'),
cols = c(ampi, amox, pita, tica)) cols = c(ampi, amox, pipe, tica))
edit_rsi(to = 'S', edit_rsi(to = 'S',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$genus == "Staphylococcus" rows = which(tbl$genus == "Staphylococcus"
@ -503,7 +506,7 @@ EUCAST_rules <- function(tbl,
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Staphylococcus saprophyticus" rows = which(tbl$fullname %like% "^Staphylococcus saprophyticus"
& tbl[, ampi] == 'S'), & tbl[, ampi] == 'S'),
cols = c(ampi, amox, amcl, pita)) cols = c(amox, amcl, pipe, pita))
} }
if (!is.na(cfox)) { if (!is.na(cfox)) {
# inferred from cefoxitin # inferred from cefoxitin
@ -564,11 +567,11 @@ EUCAST_rules <- function(tbl,
changed_results <- 0 changed_results <- 0
cat(rule) cat(rule)
} }
if (!is.na(peni)) { if (!is.na(ampi)) { # penicillin group
edit_rsi(to = 'R', edit_rsi(to = 'R',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Enterococcus faecium" rows = which(tbl$fullname %like% "^Enterococcus faecium"
& tbl[, peni] == 'R'), & tbl[, ampi] == 'R'),
cols = all_betalactam) cols = all_betalactam)
} }
if (!is.na(ampi)) { if (!is.na(ampi)) {
@ -576,17 +579,17 @@ EUCAST_rules <- function(tbl,
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$genus == "Enterococcus" rows = which(tbl$genus == "Enterococcus"
& tbl[, ampi] == 'S'), & tbl[, ampi] == 'S'),
cols = c(amox, amcl, pita)) cols = c(amox, amcl, pipe, pita))
edit_rsi(to = 'I', edit_rsi(to = 'I',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$genus == "Enterococcus" rows = which(tbl$genus == "Enterococcus"
& tbl[, ampi] == 'I'), & tbl[, ampi] == 'I'),
cols = c(amox, amcl, pita)) cols = c(amox, amcl, pipe, pita))
edit_rsi(to = 'R', edit_rsi(to = 'R',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$genus == "Enterococcus" rows = which(tbl$genus == "Enterococcus"
& tbl[, ampi] == 'R'), & tbl[, ampi] == 'R'),
cols = c(amox, amcl, pita)) cols = c(amox, amcl, pipe, pita))
} }
if (!is.na(norf)) { if (!is.na(norf)) {
edit_rsi(to = 'S', edit_rsi(to = 'S',
@ -678,24 +681,24 @@ EUCAST_rules <- function(tbl,
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Streptococcus pneumoniae" rows = which(tbl$fullname %like% "^Streptococcus pneumoniae"
& tbl[, peni] == 'S'), & tbl[, peni] == 'S'),
cols = c(ampi, amox, amcl, pita)) cols = c(ampi, amox, amcl, pipe, pita))
} }
if (!is.na(ampi)) { if (!is.na(ampi)) {
edit_rsi(to = 'S', edit_rsi(to = 'S',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Streptococcus pneumoniae" rows = which(tbl$fullname %like% "^Streptococcus pneumoniae"
& tbl[, ampi] == 'S'), & tbl[, ampi] == 'S'),
cols = c(ampi, amox, amcl, pita)) cols = c(amox, amcl, pipe, pita))
edit_rsi(to = 'I', edit_rsi(to = 'I',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Streptococcus pneumoniae" rows = which(tbl$fullname %like% "^Streptococcus pneumoniae"
& tbl[, ampi] == 'I'), & tbl[, ampi] == 'I'),
cols = c(ampi, amox, amcl, pita)) cols = c(amox, amcl, pipe, pita))
edit_rsi(to = 'R', edit_rsi(to = 'R',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Streptococcus pneumoniae" rows = which(tbl$fullname %like% "^Streptococcus pneumoniae"
& tbl[, ampi] == 'R'), & tbl[, ampi] == 'R'),
cols = c(ampi, amox, amcl, pita)) cols = c(amox, amcl, pipe, pita))
} }
if (!is.na(norf)) { if (!is.na(norf)) {
edit_rsi(to = 'S', edit_rsi(to = 'S',
@ -743,22 +746,29 @@ EUCAST_rules <- function(tbl,
"intermedius", "mitis", "mutans", "oligofermentans", "oralis", "intermedius", "mitis", "mutans", "oligofermentans", "oralis",
"parasanguinis", "peroris", "pseudopneumoniae", "salivarius", "parasanguinis", "peroris", "pseudopneumoniae", "salivarius",
"sanguinis", "sinensis", "sobrinus", "thermophilus", "vestibularis") "sanguinis", "sinensis", "sobrinus", "thermophilus", "vestibularis")
if (!is.na(peni)) {
edit_rsi(to = 'S',
rule = c(rule_group, rule),
rows = which(tbl$genus == "Streptococcus" & tbl$species %in% viridans_group
& tbl[, peni] == 'S'),
cols = c(ampi, amox, amcl, pipe, pita))
}
if (!is.na(ampi)) { if (!is.na(ampi)) {
edit_rsi(to = 'S', edit_rsi(to = 'S',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$genus == "Streptococcus" & tbl$species %in% viridans_group rows = which(tbl$genus == "Streptococcus" & tbl$species %in% viridans_group
& tbl[, ampi] == 'S'), & tbl[, ampi] == 'S'),
cols = c(ampi, amox, amcl, pita)) cols = c(amox, amcl, pipe, pita))
edit_rsi(to = 'I', edit_rsi(to = 'I',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$genus == "Streptococcus" & tbl$species %in% viridans_group rows = which(tbl$genus == "Streptococcus" & tbl$species %in% viridans_group
& tbl[, ampi] == 'I'), & tbl[, ampi] == 'I'),
cols = c(ampi, amox, amcl, pita)) cols = c(amox, amcl, pipe, pita))
edit_rsi(to = 'R', edit_rsi(to = 'R',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$genus == "Streptococcus" & tbl$species %in% viridans_group rows = which(tbl$genus == "Streptococcus" & tbl$species %in% viridans_group
& tbl[, ampi] == 'R'), & tbl[, ampi] == 'R'),
cols = c(ampi, amox, amcl, pita)) cols = c(amox, amcl, pipe, pita))
} }
if (info == TRUE) { if (info == TRUE) {
txt_ok() txt_ok()
@ -775,17 +785,24 @@ EUCAST_rules <- function(tbl,
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Haemophilus influenzae" rows = which(tbl$fullname %like% "^Haemophilus influenzae"
& tbl[, ampi] == 'S'), & tbl[, ampi] == 'S'),
cols = c(amox, pita)) cols = c(amox, pipe))
edit_rsi(to = 'I', edit_rsi(to = 'I',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Haemophilus influenzae" rows = which(tbl$fullname %like% "^Haemophilus influenzae"
& tbl[, ampi] == 'I'), & tbl[, ampi] == 'I'),
cols = c(amox, pita)) cols = c(amox, pipe))
edit_rsi(to = 'R', edit_rsi(to = 'R',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Haemophilus influenzae" rows = which(tbl$fullname %like% "^Haemophilus influenzae"
& tbl[, ampi] == 'R'), & tbl[, ampi] == 'R'),
cols = c(amox, pita)) cols = c(amox, pipe))
}
if (!is.na(peni)) {
edit_rsi(to = 'S',
rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Haemophilus influenzae"
& tbl[, peni] == 'S'),
cols = c(ampi, amox, amcl, pipe, pita))
} }
if (!is.na(amcl)) { if (!is.na(amcl)) {
edit_rsi(to = 'S', edit_rsi(to = 'S',
@ -889,28 +906,28 @@ EUCAST_rules <- function(tbl,
if (!is.na(peni)) { if (!is.na(peni)) {
edit_rsi(to = 'S', edit_rsi(to = 'S',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which((tbl$genus %in% c("Clostridium", "Actinomyces", "Propionibacterium", rows = which(tbl$genus %in% c("Clostridium", "Actinomyces", "Propionibacterium",
"Bifidobacterium", "Eggerthella", "Eubacterium", "Cutibacterium", # new name of Propionibacterium
"Lactobacillus ", "Actinomyces") "Bifidobacterium", "Eggerthella", "Eubacterium",
| tbl$fullname %like% "^Propionibacterium acnes") "Lactobacillus ", "Actinomyces")
& tbl[, peni] == 'S'), & tbl[, peni] == 'S'),
cols = c(ampi, amox, pita, tica)) cols = c(ampi, amox, pipe, pita, tica))
edit_rsi(to = 'I', edit_rsi(to = 'I',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which((tbl$genus %in% c("Clostridium", "Actinomyces", "Propionibacterium", rows = which(tbl$genus %in% c("Clostridium", "Actinomyces", "Propionibacterium",
"Bifidobacterium", "Eggerthella", "Eubacterium", "Cutibacterium", # new name of Propionibacterium
"Lactobacillus ", "Actinomyces") "Bifidobacterium", "Eggerthella", "Eubacterium",
| tbl$fullname %like% "^Propionibacterium acnes") "Lactobacillus ", "Actinomyces")
& tbl[, peni] == 'I'), & tbl[, peni] == 'I'),
cols = c(ampi, amox, pita, tica)) cols = c(ampi, amox, pipe, pita, tica))
edit_rsi(to = 'R', edit_rsi(to = 'R',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which((tbl$genus %in% c("Clostridium", "Actinomyces", "Propionibacterium", rows = which(tbl$genus %in% c("Clostridium", "Actinomyces", "Propionibacterium",
"Bifidobacterium", "Eggerthella", "Eubacterium", "Cutibacterium", # new name of Propionibacterium
"Lactobacillus ", "Actinomyces") "Bifidobacterium", "Eggerthella", "Eubacterium",
| tbl$fullname %like% "^Propionibacterium acnes") "Lactobacillus ", "Actinomyces")
& tbl[, peni] == 'R'), & tbl[, peni] == 'R'),
cols = c(ampi, amox, pita, tica)) cols = c(ampi, amox, pipe, pita, tica))
} }
if (info == TRUE) { if (info == TRUE) {
txt_ok() txt_ok()
@ -928,19 +945,19 @@ EUCAST_rules <- function(tbl,
rows = which(tbl$genus %in% c("Bacteroides", "Prevotella", "Porphyromonas", rows = which(tbl$genus %in% c("Bacteroides", "Prevotella", "Porphyromonas",
"Fusobacterium", "Bilophila ", "Mobiluncus") "Fusobacterium", "Bilophila ", "Mobiluncus")
& tbl[, peni] == 'S'), & tbl[, peni] == 'S'),
cols = c(ampi, amox, pita, tica)) cols = c(ampi, amox, pipe, pita, tica))
edit_rsi(to = 'I', edit_rsi(to = 'I',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$genus %in% c("Bacteroides", "Prevotella", "Porphyromonas", rows = which(tbl$genus %in% c("Bacteroides", "Prevotella", "Porphyromonas",
"Fusobacterium", "Bilophila ", "Mobiluncus") "Fusobacterium", "Bilophila ", "Mobiluncus")
& tbl[, peni] == 'I'), & tbl[, peni] == 'I'),
cols = c(ampi, amox, pita, tica)) cols = c(ampi, amox, pipe, pita, tica))
edit_rsi(to = 'R', edit_rsi(to = 'R',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$genus %in% c("Bacteroides", "Prevotella", "Porphyromonas", rows = which(tbl$genus %in% c("Bacteroides", "Prevotella", "Porphyromonas",
"Fusobacterium", "Bilophila ", "Mobiluncus") "Fusobacterium", "Bilophila ", "Mobiluncus")
& tbl[, peni] == 'R'), & tbl[, peni] == 'R'),
cols = c(ampi, amox, pita, tica)) cols = c(ampi, amox, pipe, pita, tica))
} }
if (info == TRUE) { if (info == TRUE) {
txt_ok() txt_ok()
@ -972,8 +989,8 @@ EUCAST_rules <- function(tbl,
if (info == TRUE) { if (info == TRUE) {
txt_ok() txt_ok()
} }
# Campylobacter jejuni ---- # Campylobacter jejuni and coli ----
rule <- 'Campylobacter jejuni' rule <- 'Campylobacter jejuni and coli'
if (info == TRUE) { if (info == TRUE) {
warned <- FALSE warned <- FALSE
changed_results <- 0 changed_results <- 0
@ -982,34 +999,34 @@ EUCAST_rules <- function(tbl,
if (!is.na(eryt)) { if (!is.na(eryt)) {
edit_rsi(to = 'S', edit_rsi(to = 'S',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Campylobacter jejuni" rows = which(tbl$fullname %like% "^Campylobacter (jejuni|coli)"
& tbl[, eryt] == 'S'), & tbl[, eryt] == 'S'),
cols = c(azit, clar)) cols = c(azit, clar))
edit_rsi(to = 'I', edit_rsi(to = 'I',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Campylobacter jejuni" rows = which(tbl$fullname %like% "^Campylobacter (jejuni|coli)"
& tbl[, eryt] == 'I'), & tbl[, eryt] == 'I'),
cols = c(azit, clar)) cols = c(azit, clar))
edit_rsi(to = 'R', edit_rsi(to = 'R',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Campylobacter jejuni" rows = which(tbl$fullname %like% "^Campylobacter (jejuni|coli)"
& tbl[, eryt] == 'R'), & tbl[, eryt] == 'R'),
cols = c(azit, clar)) cols = c(azit, clar))
} }
if (!is.na(tetr)) { if (!is.na(tetr)) {
edit_rsi(to = 'S', edit_rsi(to = 'S',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Campylobacter jejuni" rows = which(tbl$fullname %like% "^Campylobacter (jejuni|coli)"
& tbl[, tetr] == 'S'), & tbl[, tetr] == 'S'),
cols = doxy) cols = doxy)
edit_rsi(to = 'I', edit_rsi(to = 'I',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Campylobacter jejuni" rows = which(tbl$fullname %like% "^Campylobacter (jejuni|coli)"
& tbl[, tetr] == 'I'), & tbl[, tetr] == 'I'),
cols = doxy) cols = doxy)
edit_rsi(to = 'R', edit_rsi(to = 'R',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Campylobacter jejuni" rows = which(tbl$fullname %like% "^Campylobacter (jejuni|coli)"
& tbl[, tetr] == 'R'), & tbl[, tetr] == 'R'),
cols = doxy) cols = doxy)
} }
@ -1023,6 +1040,23 @@ EUCAST_rules <- function(tbl,
changed_results <- 0 changed_results <- 0
cat(rule) cat(rule)
} }
if (!is.na(norf)) {
edit_rsi(to = 'S',
rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Aerococcus (sanguinicola|urinae)"
& tbl[, norf] == 'S'),
cols = fluoroquinolones)
edit_rsi(to = 'I',
rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Aerococcus (sanguinicola|urinae)"
& tbl[, norf] == 'I'),
cols = fluoroquinolones)
edit_rsi(to = 'R',
rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Aerococcus (sanguinicola|urinae)"
& tbl[, norf] == 'R'),
cols = fluoroquinolones)
}
if (!is.na(cipr)) { if (!is.na(cipr)) {
edit_rsi(to = 'S', edit_rsi(to = 'S',
rule = c(rule_group, rule), rule = c(rule_group, rule),
@ -1090,16 +1124,6 @@ EUCAST_rules <- function(tbl,
rows = which(tbl$fullname %like% "^Kingella kingae" rows = which(tbl$fullname %like% "^Kingella kingae"
& tbl[, tetr] == 'S'), & tbl[, tetr] == 'S'),
cols = doxy) cols = doxy)
edit_rsi(to = 'I',
rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Kingella kingae"
& tbl[, tetr] == 'I'),
cols = doxy)
edit_rsi(to = 'R',
rule = c(rule_group, rule),
rows = which(tbl$fullname %like% "^Kingella kingae"
& tbl[, tetr] == 'R'),
cols = doxy)
} }
if (info == TRUE) { if (info == TRUE) {
txt_ok() txt_ok()
@ -1243,9 +1267,9 @@ EUCAST_rules <- function(tbl,
# Burkholderia # Burkholderia
edit_rsi(to = 'R', edit_rsi(to = 'R',
rule = c(rule_group, rule), rule = c(rule_group, rule),
# onder 'Burkholderia cepacia complex' vallen deze species allemaal: PMID 16217180. # the 'Burkholderia cepacia complex' are all these species: (PMID 16217180)
rows = which(tbl$fullname %like% '^Burkholderia (cepacia|multivorans|cenocepacia|stabilis|vietnamiensis|dolosa|ambifaria|anthina|pyrrocinia|ubonensis)'), rows = which(tbl$fullname %like% '^Burkholderia (cepacia|multivorans|cenocepacia|stabilis|vietnamiensis|dolosa|ambifaria|anthina|pyrrocinia|ubonensis)'),
cols = c(aminopenicillins, amcl, tica, pita, czol, cfot, cftr, aztr, erta, cipr, chlo, aminoglycosides, trim, fosf, polymyxins)) cols = c(aminopenicillins, amcl, tica, pipe, pita, czol, cfot, cftr, aztr, erta, cipr, chlo, aminoglycosides, trim, fosf, polymyxins))
# Elizabethkingia # Elizabethkingia
edit_rsi(to = 'R', edit_rsi(to = 'R',
rule = c(rule_group, rule), rule = c(rule_group, rule),
@ -1255,7 +1279,7 @@ EUCAST_rules <- function(tbl,
edit_rsi(to = 'R', edit_rsi(to = 'R',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% '^Ochrobactrum anthropi'), rows = which(tbl$fullname %like% '^Ochrobactrum anthropi'),
cols = c(aminopenicillins, amcl, tica, pita, czol, cfot, cftr, cfta, cfep, aztr, erta)) cols = c(aminopenicillins, amcl, tica, pipe, pita, czol, cfot, cftr, cfta, cfep, aztr, erta))
# Pseudomonas # Pseudomonas
edit_rsi(to = 'R', edit_rsi(to = 'R',
rule = c(rule_group, rule), rule = c(rule_group, rule),
@ -1265,7 +1289,7 @@ EUCAST_rules <- function(tbl,
edit_rsi(to = 'R', edit_rsi(to = 'R',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$fullname %like% '^Stenotrophomonas maltophilia'), rows = which(tbl$fullname %like% '^Stenotrophomonas maltophilia'),
cols = c(aminopenicillins, amcl, tica, pita, czol, cfot, cftr, cfta, aztr, erta, imip, mero, aminoglycosides, trim, fosf, tetr)) cols = c(aminopenicillins, amcl, tica, pipe, pita, czol, cfot, cftr, cfta, aztr, erta, imip, mero, aminoglycosides, trim, fosf, tetr))
if (info == TRUE) { if (info == TRUE) {
txt_ok() txt_ok()
} }
@ -1430,13 +1454,13 @@ EUCAST_rules <- function(tbl,
cat(rule) cat(rule)
} }
# rule 9.3 # rule 9.3
if (!is.na(tica) & !is.na(pita)) { if (!is.na(tica) & !is.na(pipe)) {
edit_rsi(to = 'R', edit_rsi(to = 'R',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl$family == 'Enterobacteriaceae' rows = which(tbl$family == 'Enterobacteriaceae'
& tbl[, tica] == 'R' & tbl[, tica] == 'R'
& tbl[, pita] == 'S'), & tbl[, pipe] == 'S'),
cols = pita) cols = pipe)
} }
if (info == TRUE) { if (info == TRUE) {
txt_ok() txt_ok()
@ -1456,7 +1480,7 @@ EUCAST_rules <- function(tbl,
# rule = c(rule_group, rule), # rule = c(rule_group, rule),
# rows = which(tbl$fullname %like% '^Haemophilus influenza' # rows = which(tbl$fullname %like% '^Haemophilus influenza'
# & tbl[, ampi] == 'R'), # & tbl[, ampi] == 'R'),
# cols = c(ampi, amox, amcl, pita, cfur)) # cols = c(ampi, amox, amcl, pipe, pita, cfur))
# } # }
if (info == TRUE) { if (info == TRUE) {
txt_ok() txt_ok()
@ -1602,6 +1626,21 @@ EUCAST_rules <- function(tbl,
if (info == TRUE) { if (info == TRUE) {
txt_ok() txt_ok()
} }
rule <- 'Non-EUCAST: piperacillin = R where piperacillin/tazobactam = R'
if (info == TRUE) {
warned <- FALSE
changed_results <- 0
cat(rule)
}
if (!is.na(pita)) {
edit_rsi(to = 'R',
rule = c(rule_group, rule),
rows = which(tbl[, pita] == 'R'),
cols = pipe)
}
if (info == TRUE) {
txt_ok()
}
rule <- 'Non-EUCAST: trimethoprim = R where trimethoprim/sulfa = R' rule <- 'Non-EUCAST: trimethoprim = R where trimethoprim/sulfa = R'
if (info == TRUE) { if (info == TRUE) {
warned <- FALSE warned <- FALSE
@ -1623,7 +1662,7 @@ EUCAST_rules <- function(tbl,
changed_results <- 0 changed_results <- 0
cat(rule) cat(rule)
} }
if (!is.na(amcl)) { if (!is.na(ampi)) {
edit_rsi(to = 'S', edit_rsi(to = 'S',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl[, ampi] == 'S'), rows = which(tbl[, ampi] == 'S'),
@ -1632,13 +1671,28 @@ EUCAST_rules <- function(tbl,
if (info == TRUE) { if (info == TRUE) {
txt_ok() txt_ok()
} }
rule <- 'Non-EUCAST: piperacillin/tazobactam = S where piperacillin = S'
if (info == TRUE) {
warned <- FALSE
changed_results <- 0
cat(rule)
}
if (!is.na(pipe)) {
edit_rsi(to = 'S',
rule = c(rule_group, rule),
rows = which(tbl[, pipe] == 'S'),
cols = pita)
}
if (info == TRUE) {
txt_ok()
}
rule <- 'Non-EUCAST: trimethoprim/sulfa = S where trimethoprim = S' rule <- 'Non-EUCAST: trimethoprim/sulfa = S where trimethoprim = S'
if (info == TRUE) { if (info == TRUE) {
warned <- FALSE warned <- FALSE
changed_results <- 0 changed_results <- 0
cat(rule) cat(rule)
} }
if (!is.na(trsu)) { if (!is.na(trim)) {
edit_rsi(to = 'S', edit_rsi(to = 'S',
rule = c(rule_group, rule), rule = c(rule_group, rule),
rows = which(tbl[, trim] == 'S'), rows = which(tbl[, trim] == 'S'),

View File

@ -658,14 +658,27 @@ as_tibble.frequency_tbl <- function(x, validate = TRUE, ..., rownames = NA) {
#' @exportMethod hist.frequency_tbl #' @exportMethod hist.frequency_tbl
#' @export #' @export
#' @importFrom graphics hist #' @importFrom graphics hist
hist.frequency_tbl <- function(x, ...) { hist.frequency_tbl <- function(x, breaks = "Sturges", main = NULL, ...) {
opt <- attr(x, 'opt') opt <- attr(x, 'opt')
if (!class(x$item) %in% c("numeric", "double", "integer", "Date")) {
stop("'x' must be numeric or Date.", call. = FALSE)
}
if (!is.null(opt$vars)) { if (!is.null(opt$vars)) {
title <- opt$vars title <- opt$vars
} else if (!is.null(opt$data)) {
title <- opt$data
} else { } else {
title <- "" title <- "frequency table"
} }
hist(as.vector(x), main = paste("Histogram of", title), xlab = title, ...) if (class(x$item) == "Date") {
x <- as.Date(as.vector(x), origin = "1970-01-01")
} else {
x <- as.vector(x)
}
if (is.null(main)) {
main <- paste("Histogram of", title)
}
hist(x, main = main, xlab = title, ...)
} }
#' @noRd #' @noRd

View File

@ -35,11 +35,12 @@ EUCAST_rules(tbl, col_mo = "mo", info = TRUE,
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",
oxac = "oxac", peni = "peni", pita = "pita", poly = "poly", oxac = "oxac", peni = "peni", pipe = "pipe", pita = "pita",
pris = "pris", qida = "qida", rifa = "rifa", roxi = "roxi", poly = "poly", pris = "pris", qida = "qida", rifa = "rifa",
siso = "siso", teic = "teic", tetr = "tetr", tica = "tica", roxi = "roxi", siso = "siso", teic = "teic", tetr = "tetr",
tige = "tige", tobr = "tobr", trim = "trim", trsu = "trsu", tica = "tica", tige = "tige", tobr = "tobr", trim = "trim",
vanc = "vanc", col_bactid = "bactid", verbose = FALSE) trsu = "trsu", vanc = "vanc", col_bactid = "bactid",
verbose = FALSE)
interpretive_reading(...) interpretive_reading(...)
} }
@ -52,7 +53,7 @@ interpretive_reading(...)
\item{rules}{a character vector that specifies which rules should be applied - one or more of \code{c("breakpoints", "expert", "other", "all")}} \item{rules}{a character vector that specifies which rules should be applied - one or more of \code{c("breakpoints", "expert", "other", "all")}}
\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, see Details} \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, pipe, pita, poly, pris, qida, rifa, roxi, siso, teic, tetr, tica, tige, tobr, trim, trsu, vanc}{column name of an antibiotic, see Details}
\item{col_bactid}{Deprecated. Use \code{col_mo} instead.} \item{col_bactid}{Deprecated. Use \code{col_mo} instead.}
@ -119,6 +120,7 @@ Abbrevations of the column containing antibiotics in the form: \strong{abbreviat
\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}: penicillin (\emph{J01RA01}), \strong{peni}: penicillin (\emph{J01RA01}),
\strong{pipe}: piperacillin (\emph{J01CA12}),
\strong{pita}: piperacillin+tazobactam (\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}),

View File

@ -220,6 +220,7 @@ Abbrevations of the column containing antibiotics in the form: \strong{abbreviat
\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}: penicillin (\emph{J01RA01}), \strong{peni}: penicillin (\emph{J01RA01}),
\strong{pipe}: piperacillin (\emph{J01CA12}),
\strong{pita}: piperacillin+tazobactam (\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}),