mirror of
				https://github.com/msberends/AMR.git
				synced 2025-10-23 02:36:24 +02:00 
			
		
		
		
	expert rules 12.0
This commit is contained in:
		| @@ -1,6 +1,6 @@ | ||||
| Package: AMR | ||||
| Version: 1.8.2.9050 | ||||
| Date: 2022-11-13 | ||||
| Version: 1.8.2.9051 | ||||
| Date: 2022-11-14 | ||||
| Title: Antimicrobial Resistance Data Analysis | ||||
| Description: Functions to simplify and standardise antimicrobial resistance (AMR) | ||||
|   data analysis and to work with microbial and antimicrobial properties by | ||||
|   | ||||
							
								
								
									
										4
									
								
								NEWS.md
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								NEWS.md
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | ||||
| # AMR 1.8.2.9050 | ||||
| # AMR 1.8.2.9051 | ||||
|  | ||||
| This version will eventually become v2.0! We're happy to reach a new major milestone soon! | ||||
|  | ||||
| @@ -15,7 +15,7 @@ This version will eventually become v2.0! We're happy to reach a new major miles | ||||
| * Using `units` in `ab_ddd(..., units = "...")` had been deprecated and is now not supported anymore. Use `ab_ddd_units()` instead. | ||||
|  | ||||
| ### New | ||||
| * **EUCAST 2022 and CLSI 2022 guidelines** have been added for `as.rsi()`. EUCAST 2022 is now the new default guideline for all MIC and disks diffusion interpretations. | ||||
| * **EUCAST 2022 and CLSI 2022 guidelines** have been added for `as.rsi()`. EUCAST 2022 (v12.0) is now the new default guideline for all MIC and disks diffusion interpretations, and for `eucast_rules()` to apply EUCAST Expert Rules. | ||||
| * Support for the following languages: Chinese, Greek, Japanese, Polish, Turkish and Ukrainian. We are very grateful for the valuable input by our colleagues from other countries. The `AMR` package is now available in 16 languages. The automatic language determination will give a note at start-up on systems in supported languages. | ||||
| * **All new algorithm for `as.mo()`** (and thus all `mo_*()` functions) while still following our original set-up as described in our recently submitted JSS paper (DOI [10.18637/jss.v104.i03](https://doi.org/10.18637/jss.v104.i03)). | ||||
|   * A new argument `keep_synonyms` allows to *not* correct for updated taxonomy, in favour of the now deleted argument `allow_uncertain` | ||||
|   | ||||
| @@ -30,6 +30,12 @@ | ||||
| # add new version numbers here, and add the rules themselves to "data-raw/eucast_rules.tsv" and rsi_translation | ||||
| # (sourcing "data-raw/_pre_commit_hook.R" will process the TSV file) | ||||
| EUCAST_VERSION_BREAKPOINTS <- list( | ||||
|   "12.0" = list( | ||||
|     version_txt = "v12.0", | ||||
|     year = 2022, | ||||
|     title = "'EUCAST Clinical Breakpoint Tables'", | ||||
|     url = "https://www.eucast.org/clinical_breakpoints/" | ||||
|   ), | ||||
|   "11.0" = list( | ||||
|     version_txt = "v11.0", | ||||
|     year = 2021, | ||||
|   | ||||
| @@ -304,7 +304,7 @@ search_type_in_df <- function(x, type, info = TRUE) { | ||||
|  | ||||
|   found <- found[1] | ||||
|  | ||||
|   if (!is.null(found) && info == TRUE) { | ||||
|   if (!is.null(found) && isTRUE(info)) { | ||||
|     if (message_not_thrown_before("search_in_type", type)) { | ||||
|       msg <- paste0("Using column '", font_bold(found), "' as input for `col_", type, "`.") | ||||
|       if (type %in% c("keyantibiotics", "keyantimicrobials", "specimen")) { | ||||
|   | ||||
							
								
								
									
										12
									
								
								R/ab.R
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								R/ab.R
									
									
									
									
									
								
							| @@ -132,7 +132,7 @@ as.ab <- function(x, flag_multiple_results = TRUE, info = interactive(), ...) { | ||||
|   x_unknown_ATCs <- character(0) | ||||
|  | ||||
|   note_if_more_than_one_found <- function(found, index, from_text) { | ||||
|     if (initial_search == TRUE && isTRUE(length(from_text) > 1)) { | ||||
|     if (isTRUE(initial_search) && isTRUE(length(from_text) > 1)) { | ||||
|       abnames <- ab_name(from_text, tolower = TRUE, initial_search = FALSE) | ||||
|       if (ab_name(found[1L], language = NULL) %like% "(clavulanic acid|avibactam)") { | ||||
|         abnames <- abnames[!abnames %in% c("clavulanic acid", "avibactam")] | ||||
| @@ -175,13 +175,13 @@ as.ab <- function(x, flag_multiple_results = TRUE, info = interactive(), ...) { | ||||
|   x_new[is.na(x)] <- NA | ||||
|   already_known[is.na(x)] <- FALSE | ||||
|  | ||||
|   if (initial_search == TRUE && sum(already_known) < length(x)) { | ||||
|   if (isTRUE(initial_search) && sum(already_known) < length(x)) { | ||||
|     progress <- progress_ticker(n = sum(!already_known), n_min = 25, print = info) # start if n >= 25 | ||||
|     on.exit(close(progress)) | ||||
|   } | ||||
|  | ||||
|   for (i in which(!already_known)) { | ||||
|     if (initial_search == TRUE) { | ||||
|     if (isTRUE(initial_search)) { | ||||
|       progress$tick() | ||||
|     } | ||||
|  | ||||
| @@ -316,7 +316,7 @@ as.ab <- function(x, flag_multiple_results = TRUE, info = interactive(), ...) { | ||||
|  | ||||
|     # INITIAL SEARCH - More uncertain results ---- | ||||
|  | ||||
|     if (initial_search == TRUE && fast_mode == FALSE) { | ||||
|     if (isTRUE(initial_search) && fast_mode == FALSE) { | ||||
|       # only run on first try | ||||
|  | ||||
|       # try by removing all spaces | ||||
| @@ -487,12 +487,12 @@ as.ab <- function(x, flag_multiple_results = TRUE, info = interactive(), ...) { | ||||
|     x_unknown <- c(x_unknown, x_bak[x[i] == x_bak_clean][1]) | ||||
|   } | ||||
|  | ||||
|   if (initial_search == TRUE && sum(already_known) < length(x)) { | ||||
|   if (isTRUE(initial_search) && sum(already_known) < length(x)) { | ||||
|     close(progress) | ||||
|   } | ||||
|  | ||||
|   # save to package env to save time for next time | ||||
|   if (initial_search == TRUE) { | ||||
|   if (isTRUE(initial_search)) { | ||||
|     AMR_env$ab_previously_coerced <- AMR_env$ab_previously_coerced[which(!AMR_env$ab_previously_coerced$x %in% x), , drop = FALSE] | ||||
|     AMR_env$ab_previously_coerced <- unique(rbind(AMR_env$ab_previously_coerced, | ||||
|       data.frame( | ||||
|   | ||||
| @@ -685,7 +685,7 @@ all.ab_selector_any_all <- function(..., na.rm = FALSE) { | ||||
|   # e.g., example_isolates %>% filter(all(carbapenems() == "R")) | ||||
|   # so just return the vector as is, only correcting for na.rm | ||||
|   out <- unclass(c(...)) | ||||
|   if (na.rm == TRUE) { | ||||
|   if (isTRUE(na.rm)) { | ||||
|     out <- out[!is.na(out)] | ||||
|   } | ||||
|   out | ||||
| @@ -699,7 +699,7 @@ any.ab_selector_any_all <- function(..., na.rm = FALSE) { | ||||
|   # e.g., example_isolates %>% filter(any(carbapenems() == "R")) | ||||
|   # so just return the vector as is, only correcting for na.rm | ||||
|   out <- unclass(c(...)) | ||||
|   if (na.rm == TRUE) { | ||||
|   if (isTRUE(na.rm)) { | ||||
|     out <- out[!is.na(out)] | ||||
|   } | ||||
|   out | ||||
|   | ||||
							
								
								
									
										12
									
								
								R/av.R
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								R/av.R
									
									
									
									
									
								
							| @@ -114,7 +114,7 @@ as.av <- function(x, flag_multiple_results = TRUE, info = interactive(), ...) { | ||||
|   x_unknown_ATCs <- character(0) | ||||
|  | ||||
|   note_if_more_than_one_found <- function(found, index, from_text) { | ||||
|     if (initial_search == TRUE && isTRUE(length(from_text) > 1)) { | ||||
|     if (isTRUE(initial_search) && isTRUE(length(from_text) > 1)) { | ||||
|       avnames <- av_name(from_text, tolower = TRUE, initial_search = FALSE) | ||||
|       if (av_name(found[1L], language = NULL) %like% "(clavulanic acid|avibactam)") { | ||||
|         avnames <- avnames[!avnames %in% c("clavulanic acid", "avibactam")] | ||||
| @@ -157,13 +157,13 @@ as.av <- function(x, flag_multiple_results = TRUE, info = interactive(), ...) { | ||||
|   x_new[is.na(x)] <- NA | ||||
|   already_known[is.na(x)] <- FALSE | ||||
|  | ||||
|   if (initial_search == TRUE && sum(already_known) < length(x)) { | ||||
|   if (isTRUE(initial_search) && sum(already_known) < length(x)) { | ||||
|     progress <- progress_ticker(n = sum(!already_known), n_min = 25, print = info) # start if n >= 25 | ||||
|     on.exit(close(progress)) | ||||
|   } | ||||
|  | ||||
|   for (i in which(!already_known)) { | ||||
|     if (initial_search == TRUE) { | ||||
|     if (isTRUE(initial_search)) { | ||||
|       progress$tick() | ||||
|     } | ||||
|  | ||||
| @@ -286,7 +286,7 @@ as.av <- function(x, flag_multiple_results = TRUE, info = interactive(), ...) { | ||||
|  | ||||
|     # INITIAL SEARCH - More uncertain results ---- | ||||
|  | ||||
|     if (initial_search == TRUE && fast_mode == FALSE) { | ||||
|     if (isTRUE(initial_search) && fast_mode == FALSE) { | ||||
|       # only run on first try | ||||
|  | ||||
|       # try by removing all spaces | ||||
| @@ -452,12 +452,12 @@ as.av <- function(x, flag_multiple_results = TRUE, info = interactive(), ...) { | ||||
|     x_unknown <- c(x_unknown, x_bak[x[i] == x_bak_clean][1]) | ||||
|   } | ||||
|  | ||||
|   if (initial_search == TRUE && sum(already_known) < length(x)) { | ||||
|   if (isTRUE(initial_search) && sum(already_known) < length(x)) { | ||||
|     close(progress) | ||||
|   } | ||||
|  | ||||
|   # save to package env to save time for next time | ||||
|   if (initial_search == TRUE) { | ||||
|   if (isTRUE(initial_search)) { | ||||
|     AMR_env$av_previously_coerced <- AMR_env$av_previously_coerced[which(!AMR_env$av_previously_coerced$x %in% x), , drop = FALSE] | ||||
|     AMR_env$av_previously_coerced <- unique(rbind(AMR_env$av_previously_coerced, | ||||
|       data.frame( | ||||
|   | ||||
							
								
								
									
										2
									
								
								R/data.R
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								R/data.R
									
									
									
									
									
								
							| @@ -281,7 +281,7 @@ | ||||
| #' - `original_txt`\cr Original text in the PDF file of EUCAST | ||||
| #' - `eucast_version`\cr Version number of the EUCAST Clinical Breakpoints guideline to which these dosages apply | ||||
| #' @details | ||||
| #' This data set is based on `r format_eucast_version_nr(11.0)`. | ||||
| #' This data set is based on `r format_eucast_version_nr(12.0)` and `r format_eucast_version_nr(11.0)`. | ||||
| #' | ||||
| #' ### Direct download | ||||
| #' Like all data sets in this package, this data set is publicly available for download in the following formats: R, MS Excel, Apache Feather, Apache Parquet, SPSS, SAS, and Stata. Please visit [our website for the download links](https://msberends.github.io/AMR/articles/datasets.html). The actual files are of course available on [our GitHub repository](https://github.com/msberends/AMR/tree/main/data-raw). | ||||
|   | ||||
							
								
								
									
										2
									
								
								R/disk.R
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								R/disk.R
									
									
									
									
									
								
							| @@ -75,7 +75,7 @@ as.disk <- function(x, na.rm = FALSE) { | ||||
|  | ||||
|   if (!is.disk(x)) { | ||||
|     x <- unlist(x) | ||||
|     if (na.rm == TRUE) { | ||||
|     if (isTRUE(na.rm)) { | ||||
|       x <- x[!is.na(x)] | ||||
|     } | ||||
|     x[trimws2(x) == ""] <- NA | ||||
|   | ||||
| @@ -165,7 +165,7 @@ eucast_rules <- function(x, | ||||
|                          info = interactive(), | ||||
|                          rules = getOption("AMR_eucastrules", default = c("breakpoints", "expert")), | ||||
|                          verbose = FALSE, | ||||
|                          version_breakpoints = 11.0, | ||||
|                          version_breakpoints = 12.0, | ||||
|                          version_expertrules = 3.3, | ||||
|                          ampc_cephalosporin_resistance = NA, | ||||
|                          only_rsi_columns = FALSE, | ||||
| @@ -182,13 +182,13 @@ eucast_rules <- function(x, | ||||
|   meet_criteria(only_rsi_columns, allow_class = "logical", has_length = 1) | ||||
|   meet_criteria(custom_rules, allow_class = "custom_eucast_rules", allow_NULL = TRUE) | ||||
|  | ||||
|   if ("custom" %in% rules & is.null(custom_rules)) { | ||||
|   if ("custom" %in% rules && is.null(custom_rules)) { | ||||
|     warning_("in `eucast_rules()`: no custom rules were set with the `custom_rules` argument", | ||||
|       immediate = TRUE | ||||
|     ) | ||||
|     rules <- rules[rules != "custom"] | ||||
|     if (length(rules) == 0) { | ||||
|       if (info == TRUE) { | ||||
|       if (isTRUE(info)) { | ||||
|         message_("No other rules were set, returning original data", add_fn = font_red, as_note = FALSE) | ||||
|       } | ||||
|       return(x) | ||||
| @@ -204,11 +204,11 @@ eucast_rules <- function(x, | ||||
|   expertrules_info <- EUCAST_VERSION_EXPERT_RULES[[which(as.double(names(EUCAST_VERSION_EXPERT_RULES)) == version_expertrules)]] | ||||
|  | ||||
|   # support old setting (until AMR v1.3.0) | ||||
|   if (missing(rules) & !is.null(getOption("AMR.eucast_rules", default = NULL))) { | ||||
|   if (missing(rules) && !is.null(getOption("AMR.eucast_rules", default = NULL))) { | ||||
|     rules <- getOption("AMR.eucast_rules") | ||||
|   } | ||||
|  | ||||
|   if (interactive() & verbose == TRUE & info == TRUE) { | ||||
|   if (interactive() && isTRUE(verbose) && isTRUE(info)) { | ||||
|     txt <- paste0( | ||||
|       "WARNING: In Verbose mode, the eucast_rules() function does not apply rules to the data, but instead returns a data set in logbook form with extensive info about which rows and columns would be effected and in which way.", | ||||
|       "\n\nThis may overwrite your existing data if you use e.g.:", | ||||
| @@ -247,9 +247,9 @@ eucast_rules <- function(x, | ||||
|         cat(font_subtle(" (no changes)\n")) | ||||
|       } else { | ||||
|         # opening | ||||
|         if (n_added > 0 & n_changed == 0) { | ||||
|         if (n_added > 0 && n_changed == 0) { | ||||
|           cat(font_green(" (")) | ||||
|         } else if (n_added == 0 & n_changed > 0) { | ||||
|         } else if (n_added == 0 && n_changed > 0) { | ||||
|           cat(font_blue(" (")) | ||||
|         } else { | ||||
|           cat(font_grey(" (")) | ||||
| @@ -263,7 +263,7 @@ eucast_rules <- function(x, | ||||
|           } | ||||
|         } | ||||
|         # separator | ||||
|         if (n_added > 0 & n_changed > 0) { | ||||
|         if (n_added > 0 && n_changed > 0) { | ||||
|           cat(font_grey(", ")) | ||||
|         } | ||||
|         # changes | ||||
| @@ -275,9 +275,9 @@ eucast_rules <- function(x, | ||||
|           } | ||||
|         } | ||||
|         # closing | ||||
|         if (n_added > 0 & n_changed == 0) { | ||||
|         if (n_added > 0 && n_changed == 0) { | ||||
|           cat(font_green(")\n")) | ||||
|         } else if (n_added == 0 & n_changed > 0) { | ||||
|         } else if (n_added == 0 && n_changed > 0) { | ||||
|           cat(font_blue(")\n")) | ||||
|         } else { | ||||
|           cat(font_grey(")\n")) | ||||
| @@ -314,16 +314,16 @@ eucast_rules <- function(x, | ||||
|     ... | ||||
|   ) | ||||
|  | ||||
|   if (!"AMP" %in% names(cols_ab) & "AMX" %in% names(cols_ab)) { | ||||
|   if (!"AMP" %in% names(cols_ab) && "AMX" %in% names(cols_ab)) { | ||||
|     # ampicillin column is missing, but amoxicillin is available | ||||
|     if (info == TRUE) { | ||||
|     if (isTRUE(info)) { | ||||
|       message_("Using column '", cols_ab[names(cols_ab) == "AMX"], "' as input for ampicillin since many EUCAST rules depend on it.") | ||||
|     } | ||||
|     cols_ab <- c(cols_ab, c(AMP = unname(cols_ab[names(cols_ab) == "AMX"]))) | ||||
|   } | ||||
|  | ||||
|   # data preparation ---- | ||||
|   if (info == TRUE & NROW(x) > 10000) { | ||||
|   if (isTRUE(info) && NROW(x) > 10000) { | ||||
|     message_("Preparing data...", appendLF = FALSE, as_note = FALSE) | ||||
|   } | ||||
|  | ||||
| @@ -430,7 +430,7 @@ eucast_rules <- function(x, | ||||
|   x <- left_join_microorganisms(x, by = col_mo, suffix = c("_oldcols", "")) | ||||
|   x$gramstain <- mo_gramstain(x[, col_mo, drop = TRUE], language = NULL, info = FALSE) | ||||
|   x$genus_species <- trimws(paste(x$genus, x$species)) | ||||
|   if (info == TRUE & NROW(x) > 10000) { | ||||
|   if (isTRUE(info) && NROW(x) > 10000) { | ||||
|     message_(" OK.", add_fn = list(font_green, font_bold), as_note = FALSE) | ||||
|   } | ||||
|  | ||||
| @@ -448,7 +448,7 @@ eucast_rules <- function(x, | ||||
|  | ||||
|   # Other rules: enzyme inhibitors ------------------------------------------ | ||||
|   if (any(c("all", "other") %in% rules)) { | ||||
|     if (info == TRUE) { | ||||
|     if (isTRUE(info)) { | ||||
|       cat("\n") | ||||
|       cat(word_wrap( | ||||
|         font_bold(paste0( | ||||
| @@ -487,7 +487,7 @@ eucast_rules <- function(x, | ||||
|           ab_enzyme$base_name[i], " ('", font_bold(col_base), "') = R if ", | ||||
|           tolower(ab_enzyme$enzyme_name[i]), " ('", font_bold(col_enzyme), "') = R" | ||||
|         ) | ||||
|         if (info == TRUE) { | ||||
|         if (isTRUE(info)) { | ||||
|           cat(word_wrap(rule_current, | ||||
|             width = getOption("width") - 30, | ||||
|             extra_indent = 6 | ||||
| @@ -514,7 +514,7 @@ eucast_rules <- function(x, | ||||
|         x <- run_changes$output | ||||
|         warn_lacking_rsi_class <- c(warn_lacking_rsi_class, run_changes$rsi_warn) | ||||
|         # Print number of new changes | ||||
|         if (info == TRUE) { | ||||
|         if (isTRUE(info)) { | ||||
|           # print only on last one of rules in this group | ||||
|           txt_ok(n_added = n_added, n_changed = n_changed, warned = warned) | ||||
|           # and reset counters | ||||
| @@ -528,7 +528,7 @@ eucast_rules <- function(x, | ||||
|           tolower(ab_enzyme$base_name[i]), " ('", font_bold(col_base), "') = S" | ||||
|         ) | ||||
|  | ||||
|         if (info == TRUE) { | ||||
|         if (isTRUE(info)) { | ||||
|           cat(word_wrap(rule_current, | ||||
|             width = getOption("width") - 30, | ||||
|             extra_indent = 6 | ||||
| @@ -555,7 +555,7 @@ eucast_rules <- function(x, | ||||
|         x <- run_changes$output | ||||
|         warn_lacking_rsi_class <- c(warn_lacking_rsi_class, run_changes$rsi_warn) | ||||
|         # Print number of new changes | ||||
|         if (info == TRUE) { | ||||
|         if (isTRUE(info)) { | ||||
|           # print only on last one of rules in this group | ||||
|           txt_ok(n_added = n_added, n_changed = n_changed, warned = warned) | ||||
|           # and reset counters | ||||
| @@ -565,14 +565,14 @@ eucast_rules <- function(x, | ||||
|       } | ||||
|     } | ||||
|   } else { | ||||
|     if (info == TRUE) { | ||||
|     if (isTRUE(info)) { | ||||
|       cat("\n") | ||||
|       message_("Skipping inheritance rules defined by this AMR package, such as setting trimethoprim (TMP) = R where trimethoprim/sulfamethoxazole (SXT) = R. Add \"other\" or \"all\" to the `rules` argument to apply those rules.") | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   if (!any(c("all", "custom") %in% rules) & !is.null(custom_rules)) { | ||||
|     if (info == TRUE) { | ||||
|   if (!any(c("all", "custom") %in% rules) && !is.null(custom_rules)) { | ||||
|     if (isTRUE(info)) { | ||||
|       message_("Skipping custom EUCAST rules, since the `rules` argument does not contain \"custom\".") | ||||
|     } | ||||
|     custom_rules <- NULL | ||||
| @@ -626,14 +626,14 @@ eucast_rules <- function(x, | ||||
|     rule_group_previous <- eucast_rules_df[max(1, i - 1), "reference.rule_group", drop = TRUE] | ||||
|     rule_group_current <- eucast_rules_df[i, "reference.rule_group", drop = TRUE] | ||||
|     # don't apply rules if user doesn't want to apply them | ||||
|     if (rule_group_current %like% "breakpoint" & !any(c("all", "breakpoints") %in% rules)) { | ||||
|     if (rule_group_current %like% "breakpoint" && !any(c("all", "breakpoints") %in% rules)) { | ||||
|       next | ||||
|     } | ||||
|     if (rule_group_current %like% "expert" & !any(c("all", "expert") %in% rules)) { | ||||
|     if (rule_group_current %like% "expert" && !any(c("all", "expert") %in% rules)) { | ||||
|       next | ||||
|     } | ||||
|  | ||||
|     if (isFALSE(info) | isFALSE(verbose)) { | ||||
|     if (isFALSE(info) || isFALSE(verbose)) { | ||||
|       rule_text <- "" | ||||
|     } else { | ||||
|       if (is.na(eucast_rules_df[i, "and_these_antibiotics", drop = TRUE])) { | ||||
| @@ -657,9 +657,9 @@ eucast_rules <- function(x, | ||||
|       rule_next <- "" | ||||
|     } | ||||
|  | ||||
|     if (info == TRUE) { | ||||
|     if (isTRUE(info)) { | ||||
|       # Print EUCAST intro ------------------------------------------------------ | ||||
|       if (rule_group_current %unlike% "other" & eucast_notification_shown == FALSE) { | ||||
|       if (rule_group_current %unlike% "other" && eucast_notification_shown == FALSE) { | ||||
|         cat( | ||||
|           paste0( | ||||
|             "\n", font_grey(strrep("-", 0.95 * options()$width)), "\n", | ||||
| @@ -781,7 +781,7 @@ eucast_rules <- function(x, | ||||
|       ) | ||||
|     } else { | ||||
|       source_antibiotics <- get_ab_from_namespace(source_antibiotics, cols_ab) | ||||
|       if (length(source_value) == 1 & length(source_antibiotics) > 1) { | ||||
|       if (length(source_value) == 1 && length(source_antibiotics) > 1) { | ||||
|         source_value <- rep(source_value, length(source_antibiotics)) | ||||
|       } | ||||
|       if (length(source_antibiotics) == 0) { | ||||
| @@ -838,7 +838,7 @@ eucast_rules <- function(x, | ||||
|     x <- run_changes$output | ||||
|     warn_lacking_rsi_class <- c(warn_lacking_rsi_class, run_changes$rsi_warn) | ||||
|     # Print number of new changes --------------------------------------------- | ||||
|     if (info == TRUE & rule_next != rule_current) { | ||||
|     if (isTRUE(info) && rule_next != rule_current) { | ||||
|       # print only on last one of rules in this group | ||||
|       txt_ok(n_added = n_added, n_changed = n_changed, warned = warned) | ||||
|       # and reset counters | ||||
| @@ -849,7 +849,7 @@ eucast_rules <- function(x, | ||||
|  | ||||
|   # Apply custom rules ---- | ||||
|   if (!is.null(custom_rules)) { | ||||
|     if (info == TRUE) { | ||||
|     if (isTRUE(info)) { | ||||
|       cat("\n") | ||||
|       cat(font_bold("Custom EUCAST rules, set by user"), "\n") | ||||
|     } | ||||
| @@ -868,7 +868,7 @@ eucast_rules <- function(x, | ||||
|         format_custom_query_rule(rule$query, colours = FALSE), ": ", | ||||
|         get_antibiotic_names(cols) | ||||
|       ) | ||||
|       if (info == TRUE) { | ||||
|       if (isTRUE(info)) { | ||||
|         # print rule | ||||
|         cat(italicise_taxonomy(word_wrap(format_custom_query_rule(rule$query, colours = FALSE), | ||||
|           width = getOption("width") - 30, | ||||
| @@ -904,7 +904,7 @@ eucast_rules <- function(x, | ||||
|       x <- run_changes$output | ||||
|       warn_lacking_rsi_class <- c(warn_lacking_rsi_class, run_changes$rsi_warn) | ||||
|       # Print number of new changes --------------------------------------------- | ||||
|       if (info == TRUE & rule_next != rule_current) { | ||||
|       if (isTRUE(info) && rule_next != rule_current) { | ||||
|         # print only on last one of rules in this group | ||||
|         txt_ok(n_added = n_added, n_changed = n_changed, warned = warned) | ||||
|         # and reset counters | ||||
| @@ -915,7 +915,7 @@ eucast_rules <- function(x, | ||||
|   } | ||||
|  | ||||
|   # Print overview ---------------------------------------------------------- | ||||
|   if (info == TRUE | verbose == TRUE) { | ||||
|   if (isTRUE(info) || isTRUE(verbose)) { | ||||
|     verbose_info <- x.bak %pm>% | ||||
|       pm_mutate(row = pm_row_number()) %pm>% | ||||
|       pm_select(`.rowid`, row) %pm>% | ||||
| @@ -929,8 +929,8 @@ eucast_rules <- function(x, | ||||
|     rownames(verbose_info) <- NULL | ||||
|   } | ||||
|  | ||||
|   if (info == TRUE) { | ||||
|     if (verbose == TRUE) { | ||||
|   if (isTRUE(info)) { | ||||
|     if (isTRUE(verbose)) { | ||||
|       wouldve <- "would have " | ||||
|     } else { | ||||
|       wouldve <- "" | ||||
| @@ -1010,9 +1010,9 @@ eucast_rules <- function(x, | ||||
|  | ||||
|     cat(paste0(font_grey(strrep("-", 0.95 * options()$width)), "\n")) | ||||
|  | ||||
|     if (verbose == FALSE & total_n_added + total_n_changed > 0) { | ||||
|     if (isFALSE(verbose) && total_n_added + total_n_changed > 0) { | ||||
|       cat("\n", word_wrap("Use ", font_bold("eucast_rules(..., verbose = TRUE)"), " (on your original data) to get a data.frame with all specified edits instead."), "\n\n", sep = "") | ||||
|     } else if (verbose == TRUE) { | ||||
|     } else if (isTRUE(verbose)) { | ||||
|       cat("\n", word_wrap("Used 'Verbose mode' (", font_bold("verbose = TRUE"), "), which returns a data.frame with all specified edits.\nUse ", font_bold("verbose = FALSE"), " to apply the rules on your data."), "\n\n", sep = "") | ||||
|     } | ||||
|   } | ||||
| @@ -1034,7 +1034,7 @@ eucast_rules <- function(x, | ||||
|   } | ||||
|  | ||||
|   # Return data set --------------------------------------------------------- | ||||
|   if (verbose == TRUE) { | ||||
|   if (isTRUE(verbose)) { | ||||
|     as_original_data_class(verbose_info, old_attributes$class) | ||||
|   } else { | ||||
|     # x was analysed with only unique rows, so join everything together again | ||||
| @@ -1072,16 +1072,16 @@ edit_rsi <- function(x, | ||||
|   ) | ||||
|  | ||||
|   txt_error <- function() { | ||||
|     if (info == TRUE) cat("", font_red_bg(" ERROR "), "\n\n") | ||||
|     if (isTRUE(info)) cat("", font_red_bg(" ERROR "), "\n\n") | ||||
|   } | ||||
|   txt_warning <- function() { | ||||
|     if (warned == FALSE) { | ||||
|       if (info == TRUE) cat(" ", font_orange_bg(" WARNING "), sep = "") | ||||
|       if (isTRUE(info)) cat(" ", font_orange_bg(" WARNING "), sep = "") | ||||
|     } | ||||
|     warned <<- TRUE | ||||
|   } | ||||
|  | ||||
|   if (length(rows) > 0 & length(cols) > 0) { | ||||
|   if (length(rows) > 0 && length(cols) > 0) { | ||||
|     new_edits <- x | ||||
|     if (any(!vapply(FUN.VALUE = logical(1), x[, cols, drop = FALSE], is.rsi), na.rm = TRUE)) { | ||||
|       track_changes$rsi_warn <- cols[!vapply(FUN.VALUE = logical(1), x[, cols, drop = FALSE], is.rsi)] | ||||
| @@ -1127,7 +1127,7 @@ edit_rsi <- function(x, | ||||
|     ) | ||||
|  | ||||
|     track_changes$output <- new_edits | ||||
|     if ((info == TRUE | verbose == TRUE) && !isTRUE(all.equal(x, track_changes$output))) { | ||||
|     if ((isTRUE(info) || isTRUE(verbose)) && !isTRUE(all.equal(x, track_changes$output))) { | ||||
|       get_original_rows <- function(rowids) { | ||||
|         as.integer(rownames(original_data[which(original_data$.rowid %in% rowids), , drop = FALSE])) | ||||
|       } | ||||
| @@ -1173,7 +1173,7 @@ edit_rsi <- function(x, | ||||
|  | ||||
| #' @rdname eucast_rules | ||||
| #' @export | ||||
| eucast_dosage <- function(ab, administration = "iv", version_breakpoints = 11.0) { | ||||
| eucast_dosage <- function(ab, administration = "iv", version_breakpoints = 12.0) { | ||||
|   meet_criteria(ab, allow_class = c("character", "numeric", "integer", "factor")) | ||||
|   meet_criteria(administration, allow_class = "character", is_in = dosage$administration[!is.na(dosage$administration)], has_length = 1) | ||||
|   meet_criteria(version_breakpoints, allow_class = c("numeric", "integer"), has_length = 1, is_in = as.double(names(EUCAST_VERSION_BREAKPOINTS))) | ||||
|   | ||||
| @@ -243,7 +243,7 @@ first_isolate <- function(x = NULL, | ||||
|   if (method == "phenotype-based" && !any_col_contains_rsi) { | ||||
|     method <- "episode-based" | ||||
|   } | ||||
|   if (info == TRUE && message_not_thrown_before("first_isolate", "method")) { | ||||
|   if (isTRUE(info) && message_not_thrown_before("first_isolate", "method")) { | ||||
|     message_(paste0( | ||||
|       "Determining first isolates ", | ||||
|       ifelse(method %in% c("episode-based", "phenotype-based"), | ||||
| @@ -353,7 +353,7 @@ first_isolate <- function(x = NULL, | ||||
|     testcodes_exclude <- NULL | ||||
|   } | ||||
|   # remove testcodes | ||||
|   if (!is.null(testcodes_exclude) && info == TRUE && message_not_thrown_before("first_isolate", "excludingtestcodes")) { | ||||
|   if (!is.null(testcodes_exclude) && isTRUE(info) && message_not_thrown_before("first_isolate", "excludingtestcodes")) { | ||||
|     message_("Excluding test codes: ", vector_and(testcodes_exclude, quotes = TRUE), | ||||
|       add_fn = font_black, | ||||
|       as_note = FALSE | ||||
| @@ -367,7 +367,7 @@ first_isolate <- function(x = NULL, | ||||
|   # filter on specimen group and keyantibiotics when they are filled in | ||||
|   if (!is.null(specimen_group)) { | ||||
|     check_columns_existance(col_specimen, x) | ||||
|     if (info == TRUE && message_not_thrown_before("first_isolate", "excludingspecimen")) { | ||||
|     if (isTRUE(info) && message_not_thrown_before("first_isolate", "excludingspecimen")) { | ||||
|       message_("Excluding other than specimen group '", specimen_group, "'", | ||||
|         add_fn = font_black, | ||||
|         as_note = FALSE | ||||
| @@ -411,7 +411,7 @@ first_isolate <- function(x = NULL, | ||||
|  | ||||
|   # speed up - return immediately if obvious | ||||
|   if (abs(row.start) == Inf || abs(row.end) == Inf) { | ||||
|     if (info == TRUE) { | ||||
|     if (isTRUE(info)) { | ||||
|       message_("=> Found ", font_bold("no isolates"), | ||||
|         add_fn = font_black, | ||||
|         as_note = FALSE | ||||
| @@ -420,7 +420,7 @@ first_isolate <- function(x = NULL, | ||||
|     return(rep(FALSE, nrow(x))) | ||||
|   } | ||||
|   if (row.start == row.end) { | ||||
|     if (info == TRUE) { | ||||
|     if (isTRUE(info)) { | ||||
|       message_("=> Found ", font_bold("1 first isolate"), ", as the data only contained 1 row", | ||||
|         add_fn = font_black, | ||||
|         as_note = FALSE | ||||
| @@ -429,7 +429,7 @@ first_isolate <- function(x = NULL, | ||||
|     return(TRUE) | ||||
|   } | ||||
|   if (length(c(row.start:row.end)) == pm_n_distinct(x[c(row.start:row.end), col_mo, drop = TRUE])) { | ||||
|     if (info == TRUE) { | ||||
|     if (isTRUE(info)) { | ||||
|       message_("=> Found ", font_bold(paste(length(c(row.start:row.end)), "first isolates")), | ||||
|         ", as all isolates were different microbial species", | ||||
|         add_fn = font_black, | ||||
| @@ -447,7 +447,7 @@ first_isolate <- function(x = NULL, | ||||
|  | ||||
|   # Analysis of first isolate ---- | ||||
|   if (!is.null(col_keyantimicrobials)) { | ||||
|     if (info == TRUE && message_not_thrown_before("first_isolate", "type")) { | ||||
|     if (isTRUE(info) && message_not_thrown_before("first_isolate", "type")) { | ||||
|       if (type == "keyantimicrobials") { | ||||
|         message_("Basing inclusion on key antimicrobials, ", | ||||
|           ifelse(ignore_I == FALSE, "not ", ""), | ||||
| @@ -533,7 +533,7 @@ first_isolate <- function(x = NULL, | ||||
|   decimal.mark <- getOption("OutDec") | ||||
|   big.mark <- ifelse(decimal.mark != ",", ",", ".") | ||||
|  | ||||
|   if (info == TRUE) { | ||||
|   if (isTRUE(info)) { | ||||
|     # print group name if used in dplyr::group_by() | ||||
|     cur_group <- import_fn("cur_group", "dplyr", error_on_fail = FALSE) | ||||
|     if (!is.null(cur_group)) { | ||||
| @@ -558,7 +558,7 @@ first_isolate <- function(x = NULL, | ||||
|   } | ||||
|  | ||||
|   # handle empty microorganisms | ||||
|   if (any(x$newvar_mo == "UNKNOWN", na.rm = TRUE) && info == TRUE) { | ||||
|   if (any(x$newvar_mo == "UNKNOWN", na.rm = TRUE) && isTRUE(info)) { | ||||
|     message_( | ||||
|       ifelse(include_unknown == TRUE, "Included ", "Excluded "), | ||||
|       format(sum(x$newvar_mo == "UNKNOWN", na.rm = TRUE), | ||||
| @@ -570,7 +570,7 @@ first_isolate <- function(x = NULL, | ||||
|   x[which(x$newvar_mo == "UNKNOWN"), "newvar_first_isolate"] <- include_unknown | ||||
|  | ||||
|   # exclude all NAs | ||||
|   if (anyNA(x$newvar_mo) && info == TRUE) { | ||||
|   if (anyNA(x$newvar_mo) && isTRUE(info)) { | ||||
|     message_( | ||||
|       "Excluded ", format(sum(is.na(x$newvar_mo), na.rm = TRUE), | ||||
|         decimal.mark = decimal.mark, big.mark = big.mark | ||||
| @@ -594,7 +594,7 @@ first_isolate <- function(x = NULL, | ||||
|   x <- x[order(x$newvar_row_index), , drop = FALSE] | ||||
|   rownames(x) <- NULL | ||||
|  | ||||
|   if (info == TRUE) { | ||||
|   if (isTRUE(info)) { | ||||
|     n_found <- sum(x$newvar_first_isolate, na.rm = TRUE) | ||||
|     p_found_total <- percentage(n_found / nrow(x[which(!is.na(x$newvar_mo)), , drop = FALSE]), digits = 1) | ||||
|     p_found_scope <- percentage(n_found / scope.size, digits = 1) | ||||
|   | ||||
| @@ -77,7 +77,7 @@ guess_ab_col <- function(x = NULL, search_string = NULL, verbose = FALSE, only_r | ||||
|   ab_result <- unname(all_found[names(all_found) == search_string.ab]) | ||||
|  | ||||
|   if (length(ab_result) == 0) { | ||||
|     if (verbose == TRUE) { | ||||
|     if (isTRUE(verbose)) { | ||||
|       message_("No column found as input for ", search_string, | ||||
|         " (", ab_name(search_string, language = NULL, tolower = TRUE), ").", | ||||
|         add_fn = font_black, | ||||
| @@ -86,7 +86,7 @@ guess_ab_col <- function(x = NULL, search_string = NULL, verbose = FALSE, only_r | ||||
|     } | ||||
|     return(NULL) | ||||
|   } else { | ||||
|     if (verbose == TRUE) { | ||||
|     if (isTRUE(verbose)) { | ||||
|       message_( | ||||
|         "Using column '", font_bold(ab_result), "' as input for ", search_string, | ||||
|         " (", ab_name(search_string, language = NULL, tolower = TRUE), ")." | ||||
| @@ -147,7 +147,7 @@ get_column_abx <- function(x, | ||||
|   meet_criteria(only_rsi_columns, allow_class = "logical", has_length = 1) | ||||
|   meet_criteria(sort, allow_class = "logical", has_length = 1) | ||||
|  | ||||
|   if (info == TRUE) { | ||||
|   if (isTRUE(info)) { | ||||
|     message_("Auto-guessing columns suitable for analysis", appendLF = FALSE, as_note = FALSE) | ||||
|   } | ||||
|  | ||||
| @@ -159,14 +159,14 @@ get_column_abx <- function(x, | ||||
|  | ||||
|   if (NROW(x) > 10000) { | ||||
|     # only test maximum of 10,000 values per column | ||||
|     if (info == TRUE) { | ||||
|     if (isTRUE(info)) { | ||||
|       message_(" (using only ", font_bold("the first 10,000 rows"), ")...", | ||||
|         appendLF = FALSE, | ||||
|         as_note = FALSE | ||||
|       ) | ||||
|     } | ||||
|     x <- x[1:10000, , drop = FALSE] | ||||
|   } else if (info == TRUE) { | ||||
|   } else if (isTRUE(info)) { | ||||
|     message_("...", appendLF = FALSE, as_note = FALSE) | ||||
|   } | ||||
|  | ||||
| @@ -210,7 +210,7 @@ get_column_abx <- function(x, | ||||
|   if (length(dots) > 0) { | ||||
|     newnames <- suppressWarnings(as.ab(names(dots), info = FALSE)) | ||||
|     if (anyNA(newnames)) { | ||||
|       if (info == TRUE) { | ||||
|       if (isTRUE(info)) { | ||||
|         message_(" WARNING", add_fn = list(font_yellow, font_bold), as_note = FALSE) | ||||
|       } | ||||
|       warning_("Invalid antibiotic reference(s): ", vector_and(names(dots)[is.na(newnames)], quotes = FALSE), | ||||
| @@ -221,7 +221,7 @@ get_column_abx <- function(x, | ||||
|     } | ||||
|     unexisting_cols <- which(!vapply(FUN.VALUE = logical(1), dots, function(col) all(col %in% x_columns))) | ||||
|     if (length(unexisting_cols) > 0) { | ||||
|       if (info == TRUE) { | ||||
|       if (isTRUE(info)) { | ||||
|         message_(" ERROR", add_fn = list(font_red, font_bold), as_note = FALSE) | ||||
|       } | ||||
|       stop_("Column(s) not found: ", vector_and(unlist(dots[[unexisting_cols]]), quotes = FALSE), | ||||
| @@ -240,7 +240,7 @@ get_column_abx <- function(x, | ||||
|   } | ||||
|  | ||||
|   if (length(out) == 0) { | ||||
|     if (info == TRUE && all_okay == TRUE) { | ||||
|     if (isTRUE(info) && all_okay == TRUE) { | ||||
|       message_("No columns found.") | ||||
|     } | ||||
|     AMR_env$get_column_abx.call <- unique_call_id(entire_session = FALSE, match_fn = fn) | ||||
| @@ -259,14 +259,14 @@ get_column_abx <- function(x, | ||||
|     all_okay <- FALSE | ||||
|   } | ||||
|  | ||||
|   if (info == TRUE) { | ||||
|   if (isTRUE(info)) { | ||||
|     if (all_okay == TRUE) { | ||||
|       message_(" OK.", add_fn = list(font_green, font_bold), as_note = FALSE) | ||||
|     } else { | ||||
|       message_(" WARNING.", add_fn = list(font_yellow, font_bold), as_note = FALSE) | ||||
|     } | ||||
|     for (i in seq_len(length(out))) { | ||||
|       if (verbose == TRUE && !names(out[i]) %in% names(duplicates)) { | ||||
|       if (isTRUE(verbose) && !names(out[i]) %in% names(duplicates)) { | ||||
|         message_( | ||||
|           "Using column '", font_bold(out[i]), "' as input for ", names(out)[i], | ||||
|           " (", ab_name(names(out)[i], tolower = TRUE, language = NULL), ")." | ||||
| @@ -304,7 +304,7 @@ get_column_abx <- function(x, | ||||
|   } | ||||
|   if (!is.null(soft_dependencies)) { | ||||
|     soft_dependencies <- unique(soft_dependencies) | ||||
|     if (info == TRUE && !all(soft_dependencies %in% names(out))) { | ||||
|     if (isTRUE(info) && !all(soft_dependencies %in% names(out))) { | ||||
|       # missing a soft dependency may lower the reliability | ||||
|       missing <- soft_dependencies[!soft_dependencies %in% names(out)] | ||||
|       missing_msg <- vector_and(paste0( | ||||
|   | ||||
| @@ -52,7 +52,7 @@ kurtosis.default <- function(x, na.rm = FALSE, excess = FALSE) { | ||||
|   meet_criteria(na.rm, allow_class = "logical", has_length = 1) | ||||
|   meet_criteria(excess, allow_class = "logical", has_length = 1) | ||||
|   x <- as.vector(x) | ||||
|   if (na.rm == TRUE) { | ||||
|   if (isTRUE(na.rm)) { | ||||
|     x <- x[!is.na(x)] | ||||
|   } | ||||
|   n <- length(x) | ||||
|   | ||||
							
								
								
									
										2
									
								
								R/mic.R
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								R/mic.R
									
									
									
									
									
								
							| @@ -176,7 +176,7 @@ as.mic <- function(x, na.rm = FALSE) { | ||||
|     } else { | ||||
|       x <- as.character(unlist(x)) | ||||
|     } | ||||
|     if (na.rm == TRUE) { | ||||
|     if (isTRUE(na.rm)) { | ||||
|       x <- x[!is.na(x)] | ||||
|     } | ||||
|     x[trimws2(x) == ""] <- NA | ||||
|   | ||||
| @@ -197,7 +197,7 @@ resistance_predict <- function(x, | ||||
|   if (model %in% c("binomial", "binom", "logit")) { | ||||
|     model <- "binomial" | ||||
|     model_lm <- with(df, glm(df_matrix ~ year, family = binomial)) | ||||
|     if (info == TRUE) { | ||||
|     if (isTRUE(info)) { | ||||
|       cat("\nLogistic regression model (logit) with binomial distribution") | ||||
|       cat("\n------------------------------------------------------------\n") | ||||
|       print(summary(model_lm)) | ||||
| @@ -209,7 +209,7 @@ resistance_predict <- function(x, | ||||
|   } else if (model %in% c("loglin", "poisson")) { | ||||
|     model <- "poisson" | ||||
|     model_lm <- with(df, glm(R ~ year, family = poisson)) | ||||
|     if (info == TRUE) { | ||||
|     if (isTRUE(info)) { | ||||
|       cat("\nLog-linear regression model (loglin) with poisson distribution") | ||||
|       cat("\n--------------------------------------------------------------\n") | ||||
|       print(summary(model_lm)) | ||||
| @@ -221,7 +221,7 @@ resistance_predict <- function(x, | ||||
|   } else if (model %in% c("lin", "linear")) { | ||||
|     model <- "linear" | ||||
|     model_lm <- with(df, lm((R / (R + S)) ~ year)) | ||||
|     if (info == TRUE) { | ||||
|     if (isTRUE(info)) { | ||||
|       cat("\nLinear regression model") | ||||
|       cat("\n-----------------------\n") | ||||
|       print(summary(model_lm)) | ||||
|   | ||||
							
								
								
									
										23
									
								
								R/rsi.R
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								R/rsi.R
									
									
									
									
									
								
							| @@ -853,7 +853,7 @@ as_rsi_method <- function(method_short, | ||||
|     is_intrinsic_r <- paste(mo[i], ab_param) %in% AMR_env$intrinsic_resistant | ||||
|     any_is_intrinsic_resistant <- any_is_intrinsic_resistant | is_intrinsic_r | ||||
|  | ||||
|     if (isTRUE(add_intrinsic_resistance) & is_intrinsic_r) { | ||||
|     if (isTRUE(add_intrinsic_resistance) && isTRUE(is_intrinsic_r)) { | ||||
|       if (guideline_coerced %unlike% "EUCAST") { | ||||
|         if (message_not_thrown_before("as.rsi", "intrinsic")) { | ||||
|           warning_("in `as.rsi()`: using 'add_intrinsic_resistance' is only useful when using EUCAST guidelines, since the rules for intrinsic resistance are based on EUCAST.") | ||||
| @@ -985,17 +985,16 @@ as_rsi_method <- function(method_short, | ||||
|         data.frame( | ||||
|           datetime = Sys.time(), | ||||
|           index = i, | ||||
|           ab_input = ab.bak[1], | ||||
|           ab_considered = ab[1], | ||||
|           mo_input = mo.bak[1], | ||||
|           mo_considered = mo[1], | ||||
|           ab_userinput = ab.bak[1], | ||||
|           ab_actual = ab[1], | ||||
|           mo_userinput = mo.bak[1], | ||||
|           mo_actual = mo[1], | ||||
|           guideline = guideline_coerced, | ||||
|           ref_table = get_record[, "ref_tbl", drop = TRUE], | ||||
|           method = method, | ||||
|           breakpoint_S = get_record[, "breakpoint_S", drop = TRUE], | ||||
|           breakpoint_R = get_record[, "breakpoint_R", drop = TRUE], | ||||
|           input = as.double(x[i]), | ||||
|           interpretation = new_rsi[i], | ||||
|           outcome = new_rsi[i], | ||||
|           breakpoint_S_R = paste0(get_record[, "breakpoint_S", drop = TRUE], "-", get_record[, "breakpoint_R", drop = TRUE]), | ||||
|           stringsAsFactors = FALSE | ||||
|         ) | ||||
|       ) | ||||
| @@ -1045,11 +1044,11 @@ rsi_interpretation_history <- function(clean = FALSE) { | ||||
|   out <- out.bak | ||||
|   if (NROW(out) == 0) { | ||||
|     message_("No results to return. Run `as.rsi()` on MIC values or disk diffusion zones first to see a 'logbook' data set here.") | ||||
|     return(NULL) | ||||
|     return(invisible(NULL)) | ||||
|   } | ||||
|   out$ab_considered <- as.ab(out$ab_considered) | ||||
|   out$mo_considered <- as.mo(out$mo_considered) | ||||
|   out$interpretation <- as.rsi(out$interpretation) | ||||
|   out$ab_actual <- as.ab(out$ab_actual) | ||||
|   out$mo_actual <- as.mo(out$mo_actual) | ||||
|   out$outcome <- as.rsi(out$outcome) | ||||
|   # keep stored for next use | ||||
|   if (isTRUE(clean)) { | ||||
|     AMR_env$rsi_interpretation_history <- AMR_env$rsi_interpretation_history[0, , drop = FALSE] | ||||
|   | ||||
| @@ -50,7 +50,7 @@ skewness <- function(x, na.rm = FALSE) { | ||||
| skewness.default <- function(x, na.rm = FALSE) { | ||||
|   meet_criteria(na.rm, allow_class = "logical", has_length = 1) | ||||
|   x <- as.vector(x) | ||||
|   if (na.rm == TRUE) { | ||||
|   if (isTRUE(na.rm)) { | ||||
|     x <- x[!is.na(x)] | ||||
|   } | ||||
|   n <- length(x) | ||||
|   | ||||
							
								
								
									
										
											BIN
										
									
								
								R/sysdata.rda
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								R/sysdata.rda
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								data-raw/Dosages_v_12.0_Breakpoint_Tables.pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								data-raw/Dosages_v_12.0_Breakpoint_Tables.pdf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								data-raw/Dosages_v_12.0_Breakpoint_Tables.xlsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								data-raw/Dosages_v_12.0_Breakpoint_Tables.xlsx
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -42,7 +42,7 @@ old_globalenv <- ls(envir = globalenv()) | ||||
| # See 'data-raw/eucast_rules.tsv' for the EUCAST reference file | ||||
| EUCAST_RULES_DF <- utils::read.delim( | ||||
|   file = "data-raw/eucast_rules.tsv", | ||||
|   skip = 10, | ||||
|   skip = 9, | ||||
|   sep = "\t", | ||||
|   stringsAsFactors = FALSE, | ||||
|   header = TRUE, | ||||
|   | ||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -1 +1 @@ | ||||
| e000567383fb9289741ed2360d10f72f | ||||
| 9a9fad0100acf4738f3f66b25ed3d8ef | ||||
|   | ||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -1,4 +1,171 @@ | ||||
| "ab"	"name"	"type"	"dose"	"dose_times"	"administration"	"notes"	"original_txt"	"eucast_version" | ||||
| "AMK"	"Amikacin"	"standard_dosage"	"25-30 mg/kg"	1	"iv"	""	"25-30 mg/kg x 1 iv"	12 | ||||
| "AMX"	"Amoxicillin"	"high_dosage"	"2 g"	6	"iv"	""	"2 g x 6 iv"	12 | ||||
| "AMX"	"Amoxicillin"	"standard_dosage"	"1 g"	3	"iv"	""	"1 g x 3-4 iv"	12 | ||||
| "AMX"	"Amoxicillin"	"high_dosage"	"0.75-1 g"	3	"oral"	""	"0.75-1 g x 3 oral"	12 | ||||
| "AMX"	"Amoxicillin"	"standard_dosage"	"0.5 g"	3	"oral"	""	"0.5 g x 3 oral"	12 | ||||
| "AMX"	"Amoxicillin"	"uncomplicated_uti"	"0.5 g"	3	"oral"	""	"0.5 g x 3 oral"	12 | ||||
| "AMC"	"Amoxicillin/clavulanic acid"	"high_dosage"	"2 g + 0.2 g"	3	"iv"	""	"(2 g amoxicillin + 0.2 g clavulanic acid) x 3 iv"	12 | ||||
| "AMC"	"Amoxicillin/clavulanic acid"	"standard_dosage"	"1 g + 0.2 g"	3	"iv"	""	"(1 g amoxicillin + 0.2 g clavulanic acid) x 3-4 iv"	12 | ||||
| "AMC"	"Amoxicillin/clavulanic acid"	"high_dosage"	"0.875 g + 0.125 g"	3	"oral"	""	"(0.875 g amoxicillin + 0.125 g clavulanic acid) x 3 oral"	12 | ||||
| "AMC"	"Amoxicillin/clavulanic acid"	"standard_dosage"	"0.5 g + 0.125 g"	3	"oral"	""	"(0.5 g amoxicillin + 0.125 g clavulanic acid) x 3 oral"	12 | ||||
| "AMC"	"Amoxicillin/clavulanic acid"	"uncomplicated_uti"	"0.5 g + 0.125 g"	3	"oral"	""	"(0.5 g amoxicillin + 0.125 g clavulanic acid) x 3 oral"	12 | ||||
| "AMP"	"Ampicillin"	"high_dosage"	"2 g"	4	"iv"	""	"2 g x 4 iv"	12 | ||||
| "AMP"	"Ampicillin"	"standard_dosage"	"2 g"	3	"iv"	""	"2 g x 3 iv"	12 | ||||
| "SAM"	"Ampicillin/sulbactam"	"high_dosage"	"2 g + 1 g"	4	"iv"	""	"(2 g ampicillin + 1 g sulbactam) x 4 iv"	12 | ||||
| "SAM"	"Ampicillin/sulbactam"	"standard_dosage"	"2 g + 1 g"	3	"iv"	""	"(2 g ampicillin + 1 g sulbactam) x 3 iv"	12 | ||||
| "AZM"	"Azithromycin"	"standard_dosage"	"0.5 g"	1	"iv"	""	"0.5 g x 1 iv"	12 | ||||
| "AZM"	"Azithromycin"	"standard_dosage"	"0.5 g"	1	"oral"	""	"0.5 g x 1 oral"	12 | ||||
| "ATM"	"Aztreonam"	"high_dosage"	"2 g"	4	"iv"	""	"2 g x 4 iv"	12 | ||||
| "ATM"	"Aztreonam"	"standard_dosage"	"1 g"	3	"iv"	""	"1 g x 3 iv"	12 | ||||
| "PEN"	"Benzylpenicillin"	"high_dosage"	"1.2 g"	4	"iv"	""	"1.2 g (2 MU) x 4-6 iv"	12 | ||||
| "PEN"	"Benzylpenicillin"	"standard_dosage"	"0.6 g"	4	"iv"	""	"0.6 g (1 MU) x 4 iv"	12 | ||||
| "CEC"	"Cefaclor"	"high_dosage"	"1 g"	3	"oral"	""	"1 g x 3 oral"	12 | ||||
| "CEC"	"Cefaclor"	"standard_dosage"	"0.25-0.5 g"	3	"oral"	""	"0.25-0.5 g x 3 oral"	12 | ||||
| "CFR"	"Cefadroxil"	"standard_dosage"	"0.5-1 g"	2	"oral"	""	"0.5-1 g x 2 oral"	12 | ||||
| "CFR"	"Cefadroxil"	"uncomplicated_uti"	"0.5-1 g"	2	"oral"	""	"0.5-1 g x 2 oral"	12 | ||||
| "LEX"	"Cefalexin"	"standard_dosage"	"0.25-1 g"	2	"oral"	""	"0.25-1 g x 2-3 oral"	12 | ||||
| "LEX"	"Cefalexin"	"uncomplicated_uti"	"0.25-1 g"	2	"oral"	""	"0.25-1 g x 2-3 oral"	12 | ||||
| "CZO"	"Cefazolin"	"high_dosage"	"2 g"	3	"iv"	""	"2 g x 3 iv"	12 | ||||
| "CZO"	"Cefazolin"	"standard_dosage"	"1 g"	3	"iv"	""	"1 g x 3 iv"	12 | ||||
| "FEP"	"Cefepime"	"high_dosage"	"2 g"	3	"iv"	""	"2 g x 3 iv"	12 | ||||
| "FEP"	"Cefepime"	"standard_dosage"	"2 g"	2	"iv"	""	"2 g x 2 iv"	12 | ||||
| "FDC"	"Cefiderocol"	"standard_dosage"	"2 g"	3	"iv"	"over 3 hours"	"2 g x 3 iv over 3 hours"	12 | ||||
| "CFM"	"Cefixime"	"standard_dosage"	"0.2-0.4 g"	2	"oral"	""	"0.2-0.4 g x 2 oral"	12 | ||||
| "CFM"	"Cefixime"	"uncomplicated_uti"	"0.2-0.4 g"	2	"oral"	""	"0.2-0.4 g x 2 oral"	12 | ||||
| "CTX"	"Cefotaxime"	"high_dosage"	"2 g"	3	"iv"	""	"2 g x 3 iv"	12 | ||||
| "CTX"	"Cefotaxime"	"standard_dosage"	"1 g"	3	"iv"	""	"1 g x 3 iv"	12 | ||||
| "CPD"	"Cefpodoxime"	"standard_dosage"	"0.1-0.2 g"	2	"oral"	""	"0.1-0.2 g x 2 oral"	12 | ||||
| "CPD"	"Cefpodoxime"	"uncomplicated_uti"	"0.1-0.2 g"	2	"oral"	""	"0.1-0.2 g x 2 oral"	12 | ||||
| "CPT"	"Ceftaroline"	"high_dosage"	"0.6 g"	3	"iv"	"over 2 hours"	"0.6 g x 3 iv over 2 hours"	12 | ||||
| "CPT"	"Ceftaroline"	"standard_dosage"	"0.6 g"	2	"iv"	"over 1 hour"	"0.6 g x 2 iv over 1 hour"	12 | ||||
| "CAZ"	"Ceftazidime"	"high_dosage"	"1 g"	6	"iv"	""	"1 g x 6 iv"	12 | ||||
| "CAZ"	"Ceftazidime"	"standard_dosage"	"1 g"	3	"iv"	""	"1 g x 3 iv"	12 | ||||
| "CZA"	"Ceftazidime/avibactam"	"standard_dosage"	"2 g + 0.5 g"	3	"iv"	"over 2 hours"	"(2 g ceftazidime + 0.5 g avibactam) x 3 iv over 2 hours"	12 | ||||
| "CTB"	"Ceftibuten"	"standard_dosage"	"0.4 g"	1	"oral"	""	"0.4 g x 1 oral"	12 | ||||
| "BPR"	"Ceftobiprole"	"standard_dosage"	"0.5 g"	3	"iv"	"over 2 hours"	"0.5 g x 3 iv over 2 hours"	12 | ||||
| "CZT"	"Ceftolozane/tazobactam"	"standard_dosage"	"1 g + 0.5 g"	3	"iv"	"over 1 hour"	"(1 g ceftolozane + 0.5 g tazobactam) x 3 iv over 1 hour"	12 | ||||
| "CZT"	"Ceftolozane/tazobactam"	"standard_dosage"	"2 g + 1 g"	3	"iv"	"over 1 hour"	"(2 g ceftolozane + 1 g tazobactam) x 3 iv over 1 hour"	12 | ||||
| "CRO"	"Ceftriaxone"	"high_dosage"	"4 g"	1	"iv"	""	"4 g x 1 iv"	12 | ||||
| "CRO"	"Ceftriaxone"	"standard_dosage"	"2 g"	1	"iv"	""	"2 g x 1 iv"	12 | ||||
| "CXM"	"Cefuroxime"	"high_dosage"	"1.5 g"	3	"iv"	""	"1.5 g x 3 iv"	12 | ||||
| "CXM"	"Cefuroxime"	"standard_dosage"	"0.75 g"	3	"iv"	""	"0.75 g x 3 iv"	12 | ||||
| "CXM"	"Cefuroxime"	"high_dosage"	"0.5 g"	2	"oral"	""	"0.5 g x 2 oral"	12 | ||||
| "CXM"	"Cefuroxime"	"standard_dosage"	"0.25 g"	2	"oral"	""	"0.25 g x 2 oral"	12 | ||||
| "CXM"	"Cefuroxime"	"uncomplicated_uti"	"0.25 g"	2	"oral"	""	"0.25 g x 2 oral"	12 | ||||
| "CHL"	"Chloramphenicol"	"high_dosage"	"2 g"	4	"iv"	""	"2 g x 4 iv"	12 | ||||
| "CHL"	"Chloramphenicol"	"standard_dosage"	"1 g"	4	"iv"	""	"1 g x 4 iv"	12 | ||||
| "CHL"	"Chloramphenicol"	"high_dosage"	"2 g"	4	"oral"	""	"2 g x 4 oral"	12 | ||||
| "CHL"	"Chloramphenicol"	"standard_dosage"	"1 g"	4	"oral"	""	"1 g x 4 oral"	12 | ||||
| "CIP"	"Ciprofloxacin"	"high_dosage"	"0.4 g"	3	"iv"	""	"0.4 g x 3 iv"	12 | ||||
| "CIP"	"Ciprofloxacin"	"standard_dosage"	"0.4 g"	2	"iv"	""	"0.4 g x 2 iv"	12 | ||||
| "CIP"	"Ciprofloxacin"	"high_dosage"	"0.75 g"	2	"oral"	""	"0.75 g x 2 oral"	12 | ||||
| "CIP"	"Ciprofloxacin"	"standard_dosage"	"0.5 g"	2	"oral"	""	"0.5 g x 2 oral"	12 | ||||
| "CLR"	"Clarithromycin"	"high_dosage"	"0.5 g"	2	"oral"	""	"0.5 g x 2 oral"	12 | ||||
| "CLR"	"Clarithromycin"	"standard_dosage"	"0.25 g"	2	"oral"	""	"0.25 g x 2 oral"	12 | ||||
| "CLI"	"Clindamycin"	"high_dosage"	"0.9 g"	3	"iv"	""	"0.9 g x 3 iv"	12 | ||||
| "CLI"	"Clindamycin"	"standard_dosage"	"0.6 g"	3	"iv"	""	"0.6 g x 3 iv"	12 | ||||
| "CLI"	"Clindamycin"	"high_dosage"	"0.3 g"	4	"oral"	""	"0.3 g x 4 oral"	12 | ||||
| "CLI"	"Clindamycin"	"standard_dosage"	"0.3 g"	2	"oral"	""	"0.3 g x 2 oral"	12 | ||||
| "CLO"	"Cloxacillin"	"high_dosage"	"2 g"	6	"iv"	""	"2 g x 6 iv"	12 | ||||
| "CLO"	"Cloxacillin"	"standard_dosage"	"1 g"	4	"iv"	""	"1 g x 4 iv"	12 | ||||
| "CLO"	"Cloxacillin"	"high_dosage"	"1 g"	4	"oral"	""	"1 g x 4 oral"	12 | ||||
| "CLO"	"Cloxacillin"	"standard_dosage"	"0.5 g"	4	"oral"	""	"0.5 g x 4 oral"	12 | ||||
| "COL"	"Colistin"	"standard_dosage"	"4.5 MU"	2	"iv"	"loading dose of 9 MU"	"4.5 MU x 2 iv with a loading dose of 9 MU"	12 | ||||
| "DAL"	"Dalbavancin"	"standard_dosage"	"1 g"	1	"iv"	"over 30 minutes on day 8"	"1 g x 1 iv over 30 minutes on day 1  If needed, 0.5 g x 1 iv over 30 minutes on day 8"	12 | ||||
| "DAP"	"Daptomycin"	"standard_dosage"	"4 mg/kg"	1	"iv"	""	"4 mg/kg x 1 iv"	12 | ||||
| "DAP"	"Daptomycin"	"standard_dosage"	"6 mg/kg"	1	"iv"	""	"6 mg/kg x 1 iv"	12 | ||||
| "DFX"	"Delafloxacin"	"standard_dosage"	"0.3 g"	2	"iv"	""	"0.3 g x 2 iv"	12 | ||||
| "DFX"	"Delafloxacin"	"standard_dosage"	"0.45 g"	2	"oral"	""	"0.45 g x 2 oral"	12 | ||||
| "DIC"	"Dicloxacillin"	"high_dosage"	"2 g"	6	"iv"	""	"2 g x 6 iv"	12 | ||||
| "DIC"	"Dicloxacillin"	"standard_dosage"	"1 g"	4	"iv"	""	"1 g x 4 iv"	12 | ||||
| "DIC"	"Dicloxacillin"	"high_dosage"	"2 g"	4	"oral"	""	"2 g x 4 oral"	12 | ||||
| "DIC"	"Dicloxacillin"	"standard_dosage"	"0.5-1 g"	4	"oral"	""	"0.5-1 g x 4 oral"	12 | ||||
| "DOR"	"Doripenem"	"high_dosage"	"1 g"	3	"iv"	"over 1 hour"	"1 g x 3 iv over 1 hour"	12 | ||||
| "DOR"	"Doripenem"	"standard_dosage"	"0.5 g"	3	"iv"	"over 1 hour"	"0.5 g x 3 iv over 1 hour"	12 | ||||
| "DOX"	"Doxycycline"	"high_dosage"	"0.2 g"	1	"oral"	""	"0.2 g x 1 oral"	12 | ||||
| "DOX"	"Doxycycline"	"standard_dosage"	"0.1 g"	1	"oral"	""	"0.1 g x 1 oral"	12 | ||||
| "ERV"	"Eravacycline"	"standard_dosage"	"1 mg/kg"	2	"iv"	""	"1 mg/kg x 2 iv"	12 | ||||
| "ETP"	"Ertapenem"	"standard_dosage"	"1 g"	1	"iv"	"over 30 minutes"	"1 g x 1 iv over 30 minutes"	12 | ||||
| "ERY"	"Erythromycin"	"high_dosage"	"1 g"	4	"iv"	""	"1 g x 4 iv"	12 | ||||
| "ERY"	"Erythromycin"	"standard_dosage"	"0.5 g"	2	"iv"	""	"0.5 g x 2-4 iv"	12 | ||||
| "ERY"	"Erythromycin"	"high_dosage"	"1 g"	4	"oral"	""	"1 g x 4 oral"	12 | ||||
| "ERY"	"Erythromycin"	"standard_dosage"	"0.5 g"	2	"oral"	""	"0.5 g x 2-4 oral"	12 | ||||
| "FDX"	"Fidaxomicin"	"standard_dosage"	"0.2 g"	2	"oral"	""	"0.2 g x 2 oral"	12 | ||||
| "FLC"	"Flucloxacillin"	"high_dosage"	"2 g"	6	"iv"	""	"2 g x 6 iv"	12 | ||||
| "FLC"	"Flucloxacillin"	"standard_dosage"	"2 g"	4	"iv"	""	"2 g x 4 iv (or 1 g x 6 iv)"	12 | ||||
| "FLC"	"Flucloxacillin"	"high_dosage"	"1 g"	4	"oral"	""	"1 g x 4 oral"	12 | ||||
| "FLC"	"Flucloxacillin"	"standard_dosage"	"1 g"	3	"oral"	""	"1 g x 3 oral"	12 | ||||
| "FOS"	"Fosfomycin"	"high_dosage"	"8 g"	3	"iv"	""	"8 g x 3 iv"	12 | ||||
| "FOS"	"Fosfomycin"	"standard_dosage"	"4 g"	3	"iv"	""	"4 g x 3 iv"	12 | ||||
| "FUS"	"Fusidic acid"	"high_dosage"	"0.5 g"	3	"iv"	""	"0.5 g x 3 iv"	12 | ||||
| "FUS"	"Fusidic acid"	"standard_dosage"	"0.5 g"	2	"iv"	""	"0.5 g x 2 iv"	12 | ||||
| "FUS"	"Fusidic acid"	"high_dosage"	"0.5 g"	3	"oral"	""	"0.5 g x 3 oral"	12 | ||||
| "FUS"	"Fusidic acid"	"standard_dosage"	"0.5 g"	2	"oral"	""	"0.5 g x 2 oral"	12 | ||||
| "GEN"	"Gentamicin"	"standard_dosage"	"6-7 mg/kg"	1	"iv"	""	"6-7 mg/kg x 1 iv"	12 | ||||
| "IPM"	"Imipenem"	"high_dosage"	"1 g"	4	"iv"	"over 30 minutes"	"1 g x 4 iv over 30 minutes"	12 | ||||
| "IPM"	"Imipenem"	"standard_dosage"	"0.5 g"	4	"iv"	"over 30 minutes"	"0.5 g x 4 iv over 30 minutes"	12 | ||||
| "IMR"	"Imipenem/relebactam"	"standard_dosage"	"0.5 g + 0.25 g"	4	"iv"	"over 30 minutes"	"(0.5 g imipenem + 0.25 g relebactam) x 4 iv over 30 minutes"	12 | ||||
| "IMR"	"Imipenem/relebactam"	"standard_dosage"	"0.5 g + 0.25 g"	4	"iv"	"over 30 minutes"	"(0.5 g imipenem + 0.25 g relebactam) x 4 iv over 30 minutes"	12 | ||||
| "LMU"	"Lefamulin"	"standard_dosage"	"0.15 g"	2	"iv"	"or 0.6 g x 2 oral"	"0.15 g x 2 iv or 0.6 g x 2 oral"	12 | ||||
| "LMU"	"Lefamulin"	"standard_dosage"	"0.6 g"	2	"oral"	""	"0.6 g x 2 oral"	12 | ||||
| "LVX"	"Levofloxacin"	"high_dosage"	"0.5 g"	2	"iv"	""	"0.5 g x 2 iv"	12 | ||||
| "LVX"	"Levofloxacin"	"standard_dosage"	"0.5 g"	1	"iv"	""	"0.5 g x 1 iv"	12 | ||||
| "LVX"	"Levofloxacin"	"high_dosage"	"0.5 g"	2	"oral"	""	"0.5 g x 2 oral"	12 | ||||
| "LVX"	"Levofloxacin"	"standard_dosage"	"0.5 g"	1	"oral"	""	"0.5 g x 1 oral"	12 | ||||
| "LNZ"	"Linezolid"	"standard_dosage"	"0.6 g"	2	"iv"	""	"0.6 g x 2 iv"	12 | ||||
| "LNZ"	"Linezolid"	"standard_dosage"	"0.6 g"	2	"oral"	""	"0.6 g x 2 oral"	12 | ||||
| "MEM"	"Meropenem"	"high_dosage"	"2 g"	3	"iv"	"over 3 hours"	"2 g x 3 iv over 3 hours"	12 | ||||
| "MEM"	"Meropenem"	"standard_dosage"	"1 g"	3	"iv"	"over 30 minutes"	"1 g x 3 iv over 30 minutes"	12 | ||||
| "MEV"	"Meropenem/vaborbactam"	"standard_dosage"	"2 g + 2 g"	3	"iv"	"over 3 hours"	"(2 g meropenem + 2 g vaborbactam) x 3 iv over 3 hours"	12 | ||||
| "MTR"	"Metronidazole"	"high_dosage"	"0.5 g"	3	"iv"	""	"0.5 g x 3 iv"	12 | ||||
| "MTR"	"Metronidazole"	"standard_dosage"	"0.4 g"	3	"iv"	""	"0.4 g x 3 iv"	12 | ||||
| "MTR"	"Metronidazole"	"high_dosage"	"0.5 g"	3	"oral"	""	"0.5 g x 3 oral"	12 | ||||
| "MTR"	"Metronidazole"	"standard_dosage"	"0.4 g"	3	"oral"	""	"0.4 g x 3 oral"	12 | ||||
| "MNO"	"Minocycline"	"standard_dosage"	"0.1 g"	2	"oral"	""	"0.1 g x 2 oral"	12 | ||||
| "MFX"	"Moxifloxacin"	"standard_dosage"	"0.4 g"	1	"iv"	""	"0.4 g x 1 iv"	12 | ||||
| "MFX"	"Moxifloxacin"	"standard_dosage"	"0.4 g"	1	"oral"	""	"0.4 g x 1 oral"	12 | ||||
| "OFX"	"Ofloxacin"	"high_dosage"	"0.4 g"	2	"iv"	""	"0.4 g x 2 iv"	12 | ||||
| "OFX"	"Ofloxacin"	"standard_dosage"	"0.2 g"	2	"iv"	""	"0.2 g x 2 iv"	12 | ||||
| "OFX"	"Ofloxacin"	"high_dosage"	"0.4 g"	2	"oral"	""	"0.4 g x 2 oral"	12 | ||||
| "OFX"	"Ofloxacin"	"standard_dosage"	"0.2 g"	2	"oral"	""	"0.2 g x 2 oral"	12 | ||||
| "ORI"	"Oritavancin"	"standard_dosage"	"1.2 g"	1	"iv"	""	"1.2 g x 1 (single dose) iv over 3 hours"	12 | ||||
| "OXA"	"Oxacillin"	"high_dosage"	"1 g"	6	"iv"	""	"1 g x 6 iv"	12 | ||||
| "OXA"	"Oxacillin"	"standard_dosage"	"1 g"	4	"iv"	""	"1 g x 4 iv"	12 | ||||
| "PHN"	"Phenoxymethylpenicillin"	"standard_dosage"	"0.5-2 g"	3	"oral"	""	"0.5-2 g x 3-4 oral"	12 | ||||
| "PIP"	"Piperacillin"	"high_dosage"	"4 g"	4	"iv"	""	"4 g x 4 iv by extended 3-hour infusion"	12 | ||||
| "PIP"	"Piperacillin"	"standard_dosage"	"4 g"	4	"iv"	""	"4 g x 4 iv"	12 | ||||
| "TZP"	"Piperacillin/tazobactam"	"high_dosage"	"4 g + 0.5 g"	4	"iv"	""	"(4 g piperacillin + 0.5 g tazobactam) x 4 iv by extended 3-hour infusion"	12 | ||||
| "TZP"	"Piperacillin/tazobactam"	"standard_dosage"	"4 g + 0.5 g"	4	"iv"	""	"(4 g piperacillin + 0.5 g tazobactam) x 4 iv 30-minute infusion or x 3 iv by extended 4-hour infusion"	12 | ||||
| "QDA"	"Quinupristin/dalfopristin"	"high_dosage"	"7.5 mg/kg"	3	"iv"	""	"7.5 mg/kg x 3 iv"	12 | ||||
| "QDA"	"Quinupristin/dalfopristin"	"standard_dosage"	"7.5 mg/kg"	2	"iv"	""	"7.5 mg/kg x 2 iv"	12 | ||||
| "RIF"	"Rifampicin"	"standard_dosage"	"0.6 g"	1	"iv"	""	"0.6 g x 1 iv"	12 | ||||
| "RIF"	"Rifampicin"	"standard_dosage"	"0.6 g"	1	"oral"	""	"0.6 g x 1 oral"	12 | ||||
| "RXT"	"Roxithromycin"	"standard_dosage"	"0.15 g"	2	"oral"	""	"0.15 g x 2 oral"	12 | ||||
| "SPT"	"Spectinomycin"	"standard_dosage"	"2 g"	1	"im"	""	"2 g x 1 im"	12 | ||||
| "TZD"	"Tedizolid"	"standard_dosage"	"0.2 g"	1	"iv"	""	"0.2 g x 1 iv"	12 | ||||
| "TZD"	"Tedizolid"	"standard_dosage"	"0.2 g"	1	"oral"	""	"0.2 g x 1 oral"	12 | ||||
| "TEC"	"Teicoplanin"	"high_dosage"	"0.8 g"	1	"iv"	""	"0.8 g x 1 iv"	12 | ||||
| "TEC"	"Teicoplanin"	"standard_dosage"	"0.4 g"	1	"iv"	""	"0.4 g x 1 iv"	12 | ||||
| "TLV"	"Telavancin"	"standard_dosage"	"10 mg/kg"	1	"iv"	"over 1 hour"	"10 mg/kg x 1 iv over 1 hour"	12 | ||||
| "TLT"	"Telithromycin"	"standard_dosage"	"0.8 g"	1	"oral"	""	"0.8 g x 1 oral"	12 | ||||
| "TEM"	"Temocillin"	"high_dosage"	"2 g"	3	"iv"	""	"2 g x 3 iv"	12 | ||||
| "TEM"	"Temocillin"	"standard_dosage"	"2 g"	2	"iv"	""	"2 g x 2 iv"	12 | ||||
| "TCY"	"Tetracycline"	"high_dosage"	"0.5 g"	4	"oral"	""	"0.5 g x 4 oral"	12 | ||||
| "TCY"	"Tetracycline"	"standard_dosage"	"0.25 g"	4	"oral"	""	"0.25 g x 4 oral"	12 | ||||
| "TIC"	"Ticarcillin"	"high_dosage"	"3 g"	6	"iv"	""	"3 g x 6 iv"	12 | ||||
| "TIC"	"Ticarcillin"	"standard_dosage"	"3 g"	4	"iv"	""	"3 g x 4 iv"	12 | ||||
| "TCC"	"Ticarcillin/clavulanic acid"	"high_dosage"	"3 g + 0.1 g"	6	"iv"	""	"(3 g ticarcillin + 0.1 g clavulanic acid) x 6 iv"	12 | ||||
| "TCC"	"Ticarcillin/clavulanic acid"	"standard_dosage"	"3 g + 0.1-0.2 g"	4	"iv"	""	"(3 g ticarcillin + 0.1-0.2 g clavulanic acid) x 4 iv"	12 | ||||
| "TGC"	"Tigecycline"	"standard_dosage"	"0.1 g"			"loading dose followed by 50 mg x 2 iv"	"0.1 g loading dose followed by 50 mg x 2 iv"	12 | ||||
| "TOB"	"Tobramycin"	"standard_dosage"	"6-7 mg/kg"	1	"iv"	""	"6-7 mg/kg x 1 iv"	12 | ||||
| "SXT"	"Trimethoprim/sulfamethoxazole"	"high_dosage"	"0.24 g + 1.2 g"	2	"oral"	""	"(0.24 g trimethoprim + 1.2 g sulfamethoxazole) x 2 oral"	12 | ||||
| "SXT"	"Trimethoprim/sulfamethoxazole"	"high_dosage"	"0.24 g + 1.2 g"	2	"oral"	""	"(0.24 g trimethoprim + 1.2 g sulfamethoxazole) x 2 oral or (0.24 g trimethoprim + 1.2 g sulfamethoxazole) x 2 iv"	12 | ||||
| "SXT"	"Trimethoprim/sulfamethoxazole"	"standard_dosage"	"0.16 g + 0.8 g"	2	"oral"	""	"(0.16 g trimethoprim + 0.8 g sulfamethoxazole) x 2 oral"	12 | ||||
| "SXT"	"Trimethoprim/sulfamethoxazole"	"standard_dosage"	"0.16 g + 0.8 g"	2	"oral"	""	"(0.16 g trimethoprim + 0.8 g sulfamethoxazole) x 2 oral or (0.16 g trimethoprim + 0.8 g sulfamethoxazole) x 2 iv"	12 | ||||
| "SXT"	"Trimethoprim/sulfamethoxazole"	"uncomplicated_uti"	"0.16 g + 0.8 g"	2	"oral"	""	"(0.16 g trimethoprim + 0.8 g sulfamethoxazole) x 2 oral"	12 | ||||
| "SXT"	"Trimethoprim/sulfamethoxazole"	"uncomplicated_uti"	"0.16 g + 0.8 g"	2	"oral"	""	"(0.16 g trimethoprim + 0.8 g sulfamethoxazole) x 2 oral"	12 | ||||
| "VAN"	"Vancomycin"	"standard_dosage"	"1 g"	2	"iv"	""	"1 g x 2 iv or 2 g x 1 by continuous infusion"	12 | ||||
| "AMK"	"Amikacin"	"standard_dosage"	"25-30 mg/kg"	1	"iv"	""	"25-30 mg/kg x 1 iv"	11 | ||||
| "AMX"	"Amoxicillin"	"high_dosage"	"2 g"	6	"iv"	""	"2 g x 6 iv"	11 | ||||
| "AMX"	"Amoxicillin"	"standard_dosage"	"1 g"	3	"iv"	""	"1 g x 3-4 iv"	11 | ||||
|   | ||||
										
											Binary file not shown.
										
									
								
							| @@ -1,12 +1,11 @@ | ||||
| # ------------------------------------------------------------------------------------------------------------------------------- | ||||
| # For editing this EUCAST reference file, these values can all be used for targeting antibiotics: | ||||
| # 'betalactams', 'aminoglycosides', 'aminopenicillins', 'carbapenems', 'cephalosporins', 'cephalosporins_1st', 'cephalosporins_2nd', 'cephalosporins_3rd', 'cephalosporins_except_CAZ', | ||||
| # 'fluoroquinolones', 'glycopeptides', 'glycopeptides_except_lipo', 'lincosamides', 'lipoglycopeptides', 'macrolides', 'oxazolidinones', 'polymyxins', 'streptogramins', 'tetracyclines', 'tetracyclines_except_TGC', 'ureidopenicillins', | ||||
| # and all separate EARS-Net letter codes like 'AMC'. They can be separated by comma: 'AMC, fluoroquinolones'. | ||||
| # aminoglycosides, aminopenicillins, antifungals, antimycobacterials, betalactams, carbapenems, cephalosporins, cephalosporins_1st, cephalosporins_2nd, cephalosporins_3rd, cephalosporins_4th, cephalosporins_5th, cephalosporins_except_CAZ, fluoroquinolones, glycopeptides, glycopeptides_except_lipo, lincosamides, lipoglycopeptides, macrolides, oxazolidinones, penicillins, polymyxins, quinolones, streptogramins, tetracyclines, tetracyclines_except_TGC, trimethoprims, ureidopenicillins | ||||
| # and all separate EARS-Net letter codes such as AMC. They can be separated by comma: 'AMC, fluoroquinolones'. | ||||
| # The 'if_mo_property' column can be any column name from the AMR::microorganisms data set, or "genus_species" or "gramstain". | ||||
| # The like.is.one_of column must be 'like' or 'is' or 'one_of' ('like' will read the 'this_value' column as regular expression) | ||||
| # The EUCAST guideline contains references to the 'Burkholderia cepacia complex'. All species in this group are noted on the 'B.cepacia' sheet of the EUCAST Clinical Breakpoint v.10.0 Excel file of 2020 (v_10.0_Breakpoint_Tables.xlsx). | ||||
| # >>>>> IF YOU WANT TO IMPORT THIS FILE INTO YOUR OWN SOFTWARE, HAVE THE FIRST 10 LINES SKIPPED <<<<< | ||||
| # The EUCAST guideline contains references to the 'Burkholderia cepacia complex'. All species in this group are noted on the 'B.cepacia' sheet of the EUCAST Clinical Breakpoint v.10.0 Excel file of 2020 and later | ||||
| # >>>>> IF YOU WANT TO IMPORT THIS FILE INTO YOUR OWN SOFTWARE, HAVE THE FIRST 9 LINES SKIPPED <<<<< | ||||
| # -------------------------------------------------------------------------------------------------------------------------------			 | ||||
| if_mo_property	like.is.one_of	this_value	and_these_antibiotics	have_these_values	then_change_these_antibiotics	to_value	reference.rule	reference.rule_group	reference.version	note | ||||
| order	is	Enterobacterales	AMP	S	AMX	S	Enterobacterales (Order)	Breakpoints	10	 | ||||
| @@ -176,12 +175,12 @@ genus_species	is	Moraxella catarrhalis	ERY	S	AZM, CLR, RXT	S	Moraxella catarrhal | ||||
| genus_species	is	Moraxella catarrhalis	ERY	I	AZM, CLR, RXT	I	Moraxella catarrhalis	Breakpoints	11	 | ||||
| genus_species	is	Moraxella catarrhalis	ERY	R	AZM, CLR, RXT	R	Moraxella catarrhalis	Breakpoints	11	 | ||||
| genus_species	is	Moraxella catarrhalis	TCY	S	DOX, MNO	S	Moraxella catarrhalis	Breakpoints	11	 | ||||
| genus	one_of	Actinomyces, Bifidobacterium, Clostridium, Cutibacterium, Eggerthella, Eubacterium, Lactobacillus, Propionibacterium	PEN	S	AMP, AMX, PIP, TZP, TIC	S	Anaerobic Gram-positives	Breakpoints	11	 | ||||
| genus	one_of	Actinomyces, Bifidobacterium, Clostridium, Cutibacterium, Eggerthella, Eubacterium, Lactobacillus, Propionibacterium	PEN	I	AMP, AMX, PIP, TZP, TIC	I	Anaerobic Gram-positives	Breakpoints	11	 | ||||
| genus	one_of	Actinomyces, Bifidobacterium, Clostridium, Cutibacterium, Eggerthella, Eubacterium, Lactobacillus, Propionibacterium	PEN	R	AMP, AMX, PIP, TZP, TIC	R	Anaerobic Gram-positives	Breakpoints	11	 | ||||
| genus	one_of	Bacteroides, Bilophila , Fusobacterium, Mobiluncus, Porphyromonas, Prevotella	PEN	S	AMP, AMX, PIP, TZP, TIC	S	Anaerobic Gram-negatives	Breakpoints	11	 | ||||
| genus	one_of	Bacteroides, Bilophila , Fusobacterium, Mobiluncus, Porphyromonas, Prevotella	PEN	I	AMP, AMX, PIP, TZP, TIC	I	Anaerobic Gram-negatives	Breakpoints	11	 | ||||
| genus	one_of	Bacteroides, Bilophila , Fusobacterium, Mobiluncus, Porphyromonas, Prevotella	PEN	R	AMP, AMX, PIP, TZP, TIC	R	Anaerobic Gram-negatives	Breakpoints	11	 | ||||
| genus	one_of	Actinomyces, Bifidobacterium, Clostridium, Cutibacterium, Eggerthella, Eubacterium, Lactobacillus, Propionibacterium	PEN	S	AMP, AMX, PIP, TIC	S	Anaerobic Gram-positives	Breakpoints	11	 | ||||
| genus	one_of	Actinomyces, Bifidobacterium, Clostridium, Cutibacterium, Eggerthella, Eubacterium, Lactobacillus, Propionibacterium	PEN	I	AMP, AMX, PIP, TIC	I	Anaerobic Gram-positives	Breakpoints	11	 | ||||
| genus	one_of	Actinomyces, Bifidobacterium, Clostridium, Cutibacterium, Eggerthella, Eubacterium, Lactobacillus, Propionibacterium	PEN	R	AMP, AMX, PIP, TIC	R	Anaerobic Gram-positives	Breakpoints	11	 | ||||
| genus	one_of	Bacteroides, Bilophila , Fusobacterium, Mobiluncus, Porphyromonas, Prevotella	PEN	S	AMP, AMX, PIP, TIC	S	Anaerobic Gram-negatives	Breakpoints	11	 | ||||
| genus	one_of	Bacteroides, Bilophila , Fusobacterium, Mobiluncus, Porphyromonas, Prevotella	PEN	I	AMP, AMX, PIP, TIC	I	Anaerobic Gram-negatives	Breakpoints	11	 | ||||
| genus	one_of	Bacteroides, Bilophila , Fusobacterium, Mobiluncus, Porphyromonas, Prevotella	PEN	R	AMP, AMX, PIP, TIC	R	Anaerobic Gram-negatives	Breakpoints	11	 | ||||
| genus_species	is	Pasteurella multocida	PEN	S	AMP, AMX	S	Pasteurella multocida	Breakpoints	11	 | ||||
| genus_species	is	Pasteurella multocida	PEN	I	AMP, AMX	I	Pasteurella multocida	Breakpoints	11	 | ||||
| genus_species	is	Pasteurella multocida	PEN	R	AMP, AMX	R	Pasteurella multocida	Breakpoints	11	 | ||||
| @@ -224,6 +223,133 @@ genus_species	is	Burkholderia pseudomallei	TCY	R	DOX	R	Burkholderia pseudomallei | ||||
| genus	is	Bacillus	NOR	S	fluoroquinolones	S	Bacillus	Breakpoints	11	added in 11 | ||||
| genus	is	Bacillus	NOR	I	fluoroquinolones	I	Bacillus	Breakpoints	11	added in 11 | ||||
| genus	is	Bacillus	NOR	R	fluoroquinolones	R	Bacillus	Breakpoints	11	added in 11 | ||||
| order	is	Enterobacterales	AMP	S	AMX	S	Enterobacterales (Order)	Breakpoints	12	 | ||||
| order	is	Enterobacterales	AMP	I	AMX	I	Enterobacterales (Order)	Breakpoints	12	 | ||||
| order	is	Enterobacterales	AMP	R	AMX	R	Enterobacterales (Order)	Breakpoints	12	 | ||||
| genus	is	Staphylococcus	PEN, FOX	S	AMP, AMX, PIP, TIC	S	Staphylococcus	Breakpoints	12	 | ||||
| genus	is	Staphylococcus	PEN, FOX	R, S	OXA, FLC	S	Staphylococcus	Breakpoints	12	 | ||||
| genus	is	Staphylococcus	FOX	R	betalactams	R	Staphylococcus	Breakpoints	12	 | ||||
| genus_species	is	Staphylococcus saprophyticus	AMP	S	AMX, AMC, PIP, TZP	S	Staphylococcus	Breakpoints	12	 | ||||
| genus	is	Staphylococcus	FOX	S	carbapenems, cephalosporins_except_CAZ	S	Staphylococcus	Breakpoints	12	 | ||||
| genus	is	Staphylococcus	FOX	I	carbapenems, cephalosporins_except_CAZ	I	Staphylococcus	Breakpoints	12	 | ||||
| genus	is	Staphylococcus	FOX	R	carbapenems, cephalosporins_except_CAZ	R	Staphylococcus	Breakpoints	12	 | ||||
| genus	is	Staphylococcus	NOR	S	MFX	S	Staphylococcus	Breakpoints	12	 | ||||
| genus	is	Staphylococcus	NOR	S	CIP, LVX	I	Staphylococcus	Breakpoints	12	 | ||||
| genus	is	Staphylococcus	NOR	R	MFX, CIP, LVX	R	Staphylococcus	Breakpoints	12	 | ||||
| genus	is	Staphylococcus	ERY	S	AZM, CLR, RXT	S	Staphylococcus	Breakpoints	12	 | ||||
| genus	is	Staphylococcus	ERY	R	AZM, CLR, RXT	R	Staphylococcus	Breakpoints	12	 | ||||
| genus	is	Staphylococcus	TCY	S	DOX, MNO	S	Staphylococcus	Breakpoints	12	 | ||||
| genus	is	Staphylococcus	TCY	R	DOX, MNO	R	Staphylococcus	Breakpoints	12	 | ||||
| genus	is	Enterococcus	AMP	S	AMX, AMC, PIP, TZP	S	Enterococcus	Breakpoints	12	 | ||||
| genus	is	Enterococcus	AMP	I	AMX, AMC, PIP, TZP	I	Enterococcus	Breakpoints	12	 | ||||
| genus	is	Enterococcus	AMP	R	AMX, AMC, PIP, TZP	R	Enterococcus	Breakpoints	12	 | ||||
| genus	is	Enterococcus	NOR	S	CIP, LVX	S	Enterococcus	Breakpoints	12	 | ||||
| genus	is	Enterococcus	NOR	I	CIP, LVX	I	Enterococcus	Breakpoints	12	 | ||||
| genus	is	Enterococcus	NOR	R	CIP, LVX	R	Enterococcus	Breakpoints	12	 | ||||
| genus_species	one_of	Streptococcus group A, Streptococcus group B, Streptococcus group C, Streptococcus group G	PEN	S	aminopenicillins, ureidopenicillins, cephalosporins_except_CAZ, carbapenems, FLC, AMC	S	Streptococcus groups A, B, C, G	Breakpoints	12	 | ||||
| genus_species	like	Streptococcus group A, Streptococcus group B, Streptococcus group C, Streptococcus group G	PEN	I	aminopenicillins, ureidopenicillins, cephalosporins_except_CAZ, carbapenems, FLC, AMC	I	Streptococcus groups A, B, C, G	Breakpoints	12	 | ||||
| genus_species	like	Streptococcus group A, Streptococcus group B, Streptococcus group C, Streptococcus group G	PEN	R	aminopenicillins, ureidopenicillins, cephalosporins_except_CAZ, carbapenems, FLC, AMC	R	Streptococcus groups A, B, C, G	Breakpoints	12	 | ||||
| genus_species	like	Streptococcus group A, Streptococcus group B, Streptococcus group C, Streptococcus group G	NOR	S	MFX	S	Streptococcus groups A, B, C, G	Breakpoints	12	 | ||||
| genus_species	like	Streptococcus group A, Streptococcus group B, Streptococcus group C, Streptococcus group G	NOR	S	LVX	I	Streptococcus groups A, B, C, G	Breakpoints	12	 | ||||
| genus_species	like	Streptococcus group A, Streptococcus group B, Streptococcus group C, Streptococcus group G	NOR	R	MFX, LVX	R	Streptococcus groups A, B, C, G	Breakpoints	12	 | ||||
| genus_species	like	Streptococcus group A, Streptococcus group B, Streptococcus group C, Streptococcus group G	ERY	S	AZM, CLR, RXT	S	Streptococcus groups A, B, C, G	Breakpoints	12	 | ||||
| genus_species	like	Streptococcus group A, Streptococcus group B, Streptococcus group C, Streptococcus group G	ERY	I	AZM, CLR, RXT	I	Streptococcus groups A, B, C, G	Breakpoints	12	 | ||||
| genus_species	like	Streptococcus group A, Streptococcus group B, Streptococcus group C, Streptococcus group G	ERY	R	AZM, CLR, RXT	R	Streptococcus groups A, B, C, G	Breakpoints	12	 | ||||
| genus_species	like	Streptococcus group A, Streptococcus group B, Streptococcus group C, Streptococcus group G	TCY	S	DOX, MNO	S	Streptococcus groups A, B, C, G	Breakpoints	12	 | ||||
| genus_species	like	Streptococcus group A, Streptococcus group B, Streptococcus group C, Streptococcus group G	TCY	R	DOX, MNO	R	Streptococcus groups A, B, C, G	Breakpoints	12	 | ||||
| genus_species	is	Streptococcus pneumoniae	PEN	S	AMP, AMX, AMC, PIP, TZP	S	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	is	Streptococcus pneumoniae	AMP	S	AMX, AMC, PIP, TZP	S	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	is	Streptococcus pneumoniae	AMP	I	AMX, AMC, PIP, TZP	I	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	is	Streptococcus pneumoniae	AMP	R	AMX, AMC, PIP, TZP	R	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	is	Streptococcus pneumoniae	NOR	S	MFX	S	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	is	Streptococcus pneumoniae	NOR	S	LVX	I	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	is	Streptococcus pneumoniae	NOR	R	MFX, LVX	R	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	is	Streptococcus pneumoniae	ERY	S	AZM, CLR, RXT	S	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	is	Streptococcus pneumoniae	ERY	I	AZM, CLR, RXT	I	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	is	Streptococcus pneumoniae	ERY	R	AZM, CLR, RXT	R	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	is	Streptococcus pneumoniae	TCY	S	DOX, MNO	S	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	is	Streptococcus pneumoniae	TCY	R	DOX, MNO	R	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	like	^Streptococcus (anginosus|australis|bovis|constellatus|cristatus|equinus|gallolyticus|gordonii|infantarius|infantis|intermedius|mitis|mutans|oligofermentans|oralis|parasanguinis|peroris|pseudopneumoniae|salivarius|sanguinis|sinensis|sobrinus|thermophilus|vestibularis|viridans)$	PEN	S	AMP, AMX, AMC, PIP, TZP	S	Viridans group streptococci	Breakpoints	12	 | ||||
| genus_species	like	^Streptococcus (anginosus|australis|bovis|constellatus|cristatus|equinus|gallolyticus|gordonii|infantarius|infantis|intermedius|mitis|mutans|oligofermentans|oralis|parasanguinis|peroris|pseudopneumoniae|salivarius|sanguinis|sinensis|sobrinus|thermophilus|vestibularis|viridans)$	AMP	S	AMX, AMC, PIP, TZP	S	Viridans group streptococci	Breakpoints	12	 | ||||
| genus_species	like	^Streptococcus (anginosus|australis|bovis|constellatus|cristatus|equinus|gallolyticus|gordonii|infantarius|infantis|intermedius|mitis|mutans|oligofermentans|oralis|parasanguinis|peroris|pseudopneumoniae|salivarius|sanguinis|sinensis|sobrinus|thermophilus|vestibularis|viridans)$	AMP	I	AMX, AMC, PIP, TZP	I	Viridans group streptococci	Breakpoints	12	 | ||||
| genus_species	like	^Streptococcus (anginosus|australis|bovis|constellatus|cristatus|equinus|gallolyticus|gordonii|infantarius|infantis|intermedius|mitis|mutans|oligofermentans|oralis|parasanguinis|peroris|pseudopneumoniae|salivarius|sanguinis|sinensis|sobrinus|thermophilus|vestibularis|viridans)$	AMP	R	AMX, AMC, PIP, TZP	R	Viridans group streptococci	Breakpoints	12	 | ||||
| genus_species	is	Haemophilus influenzae	AMP	S	AMX, PIP	S	Haemophilus influenzae	Breakpoints	12	 | ||||
| genus_species	is	Haemophilus influenzae	AMP	I	AMX, PIP	I	Haemophilus influenzae	Breakpoints	12	 | ||||
| genus_species	is	Haemophilus influenzae	AMP	R	AMX, PIP	R	Haemophilus influenzae	Breakpoints	12	 | ||||
| genus_species	is	Haemophilus influenzae	PEN	S	AMP, AMX, AMC, PIP, TZP	S	Haemophilus influenzae	Breakpoints	12	 | ||||
| genus_species	is	Haemophilus influenzae	AMC	S	TZP	S	Haemophilus influenzae	Breakpoints	12	 | ||||
| genus_species	is	Haemophilus influenzae	AMC	I	TZP	I	Haemophilus influenzae	Breakpoints	12	 | ||||
| genus_species	is	Haemophilus influenzae	AMC	R	TZP	R	Haemophilus influenzae	Breakpoints	12	 | ||||
| genus_species	is	Haemophilus influenzae	NAL	S	CIP, LVX, MFX, OFX	S	Haemophilus influenzae	Breakpoints	12	 | ||||
| genus_species	is	Haemophilus influenzae	TCY	S	DOX, MNO	S	Haemophilus influenzae	Breakpoints	12	 | ||||
| genus_species	is	Haemophilus influenzae	TCY	R	DOX, MNO	R	Haemophilus influenzae	Breakpoints	12	 | ||||
| genus_species	is	Moraxella catarrhalis	NOR	S	CIP, LVX, MFX, OFX	S	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	is	Moraxella catarrhalis	NOR	R	CIP, LVX, MFX, OFX	R	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	is	Moraxella catarrhalis	AMC	S	TZP	S	Moraxella catarrhalis	Breakpoints	12	 | ||||
| genus_species	is	Moraxella catarrhalis	AMC	I	TZP	I	Moraxella catarrhalis	Breakpoints	12	 | ||||
| genus_species	is	Moraxella catarrhalis	AMC	R	TZP	R	Moraxella catarrhalis	Breakpoints	12	 | ||||
| genus_species	is	Moraxella catarrhalis	NAL	S	CIP, LVX, MFX, OFX	S	Moraxella catarrhalis	Breakpoints	12	 | ||||
| genus_species	is	Moraxella catarrhalis	ERY	S	AZM, CLR, RXT	S	Moraxella catarrhalis	Breakpoints	12	 | ||||
| genus_species	is	Moraxella catarrhalis	ERY	I	AZM, CLR, RXT	I	Moraxella catarrhalis	Breakpoints	12	 | ||||
| genus_species	is	Moraxella catarrhalis	ERY	R	AZM, CLR, RXT	R	Moraxella catarrhalis	Breakpoints	12	 | ||||
| genus_species	is	Moraxella catarrhalis	TCY	S	DOX, MNO	S	Moraxella catarrhalis	Breakpoints	12	 | ||||
| genus_species	is	Moraxella catarrhalis	TCY	R	DOX, MNO	R	Moraxella catarrhalis	Breakpoints	12	 | ||||
| genus_species	is	Pasteurella multocida	PEN	S	AMP, AMX	S	Pasteurella multocida	Breakpoints	12	 | ||||
| genus_species	is	Pasteurella multocida	PEN	I	AMP, AMX	I	Pasteurella multocida	Breakpoints	12	 | ||||
| genus_species	is	Pasteurella multocida	PEN	R	AMP, AMX	R	Pasteurella multocida	Breakpoints	12	 | ||||
| genus_species	is	Pasteurella multocida	NOR	S	CIP, LVX	S	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	is	Pasteurella multocida	NOR	R	CIP, LVX	R	Streptococcus pneumoniae	Breakpoints	12	 | ||||
| genus_species	is	Campylobacter coli	ERY	S	AZM, CLR	S	Campylobacter coli	Breakpoints	12	 | ||||
| genus_species	is	Campylobacter coli	ERY	I	AZM, CLR	I	Campylobacter coli	Breakpoints	12	 | ||||
| genus_species	is	Campylobacter coli	ERY	R	AZM, CLR	R	Campylobacter coli	Breakpoints	12	 | ||||
| genus_species	is	Campylobacter coli	TCY	S	DOX	S	Campylobacter coli	Breakpoints	12	 | ||||
| genus_species	is	Campylobacter coli	TCY	I	DOX	I	Campylobacter coli	Breakpoints	12	 | ||||
| genus_species	is	Campylobacter coli	TCY	R	DOX	R	Campylobacter coli	Breakpoints	12	 | ||||
| genus_species	is	Campylobacter jejuni	ERY	S	AZM, CLR	S	Campylobacter jejuni	Breakpoints	12	 | ||||
| genus_species	is	Campylobacter jejuni	ERY	I	AZM, CLR	I	Campylobacter jejuni	Breakpoints	12	 | ||||
| genus_species	is	Campylobacter jejuni	ERY	R	AZM, CLR	R	Campylobacter jejuni	Breakpoints	12	 | ||||
| genus_species	is	Campylobacter jejuni	TCY	S	DOX	S	Campylobacter jejuni	Breakpoints	12	 | ||||
| genus_species	is	Campylobacter jejuni	TCY	I	DOX	I	Campylobacter jejuni	Breakpoints	12	 | ||||
| genus_species	is	Campylobacter jejuni	TCY	R	DOX	R	Campylobacter jejuni	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus sanguinicola	AMP	S	AMX	S	Aerococcus sanguinicola	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus sanguinicola	AMP	I	AMX	I	Aerococcus sanguinicola	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus sanguinicola	AMP	R	AMX	R	Aerococcus sanguinicola	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus sanguinicola	NOR	S	fluoroquinolones	S	Aerococcus sanguinicola	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus sanguinicola	NOR	I	fluoroquinolones	I	Aerococcus sanguinicola	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus sanguinicola	NOR	R	fluoroquinolones	R	Aerococcus sanguinicola	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus sanguinicola	CIP	S	LVX	S	Aerococcus sanguinicola	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus sanguinicola	CIP	I	LVX	I	Aerococcus sanguinicola	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus sanguinicola	CIP	R	LVX	R	Aerococcus urinae	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus urinae	AMP	S	AMX	S	Aerococcus sanguinicola	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus urinae	AMP	I	AMX	I	Aerococcus sanguinicola	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus urinae	AMP	R	AMX	R	Aerococcus sanguinicola	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus urinae	NOR	S	fluoroquinolones	S	Aerococcus urinae	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus urinae	NOR	I	fluoroquinolones	I	Aerococcus urinae	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus urinae	NOR	R	fluoroquinolones	R	Aerococcus urinae	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus urinae	CIP	S	LVX	S	Aerococcus urinae	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus urinae	CIP	I	LVX	I	Aerococcus urinae	Breakpoints	12	 | ||||
| genus_species	is	Aerococcus urinae	CIP	R	LVX	R	Aerococcus urinae	Breakpoints	12	 | ||||
| genus_species	is	Kingella kingae	PEN	S	AMP, AMX	S	Kingella kingae	Breakpoints	12	 | ||||
| genus_species	is	Kingella kingae	PEN	I	AMP, AMX	I	Kingella kingae	Breakpoints	12	 | ||||
| genus_species	is	Kingella kingae	PEN	R	AMP, AMX	R	Kingella kingae	Breakpoints	12	 | ||||
| genus_species	is	Kingella kingae	ERY	S	AZM, CLR	S	Kingella kingae	Breakpoints	12	 | ||||
| genus_species	is	Kingella kingae	ERY	I	AZM, CLR	I	Kingella kingae	Breakpoints	12	 | ||||
| genus_species	is	Kingella kingae	ERY	R	AZM, CLR	R	Kingella kingae	Breakpoints	12	 | ||||
| genus_species	is	Kingella kingae	TCY	S	DOX	S	Kingella kingae	Breakpoints	12	 | ||||
| genus_species	is	Kingella kingae	TCY	R	DOX	R	Kingella kingae	Breakpoints	12	 | ||||
| genus	is	Vibrio	PEF	S	CIP, LVX	S	Vibrio spp.	Breakpoints	12	 | ||||
| genus	is	Vibrio	PEF	I	CIP, LVX	I	Vibrio spp.	Breakpoints	12	 | ||||
| genus	is	Vibrio	PEF	R	CIP, LVX	R	Vibrio spp.	Breakpoints	12	 | ||||
| genus	is	Vibrio	ERY	S	AZM	S	Vibrio spp.	Breakpoints	12	 | ||||
| genus	is	Vibrio	ERY	I	AZM	I	Vibrio spp.	Breakpoints	12	 | ||||
| genus	is	Vibrio	ERY	R	AZM	R	Vibrio spp.	Breakpoints	12	 | ||||
| genus	is	Vibrio	TCY	S	DOX	S	Vibrio spp.	Breakpoints	12	 | ||||
| genus	is	Vibrio	TCY	I	DOX	I	Vibrio spp.	Breakpoints	12	 | ||||
| genus	is	Vibrio	TCY	R	DOX	R	Vibrio spp.	Breakpoints	12	 | ||||
| genus	is	Bacillus	NOR	S	CIP, LVX	S	Bacillus	Breakpoints	12	 | ||||
| genus	is	Bacillus	NOR	R	CIP, LVX	R	Bacillus	Breakpoints	12	 | ||||
| genus_species	is	Burkholderia pseudomallei	TCY	S	DOX	I	Burkholderia pseudomallei	Breakpoints	12	 | ||||
| genus_species	is	Burkholderia pseudomallei	TCY	R	DOX	R	Burkholderia pseudomallei	Breakpoints	12	 | ||||
| order	is	Enterobacterales			PEN, glycopeptides_except_lipo, FUS, macrolides, LIN, streptogramins, RIF, DAP, LNZ	R	Table 01: Intrinsic resistance in Enterobacterales (at the time: Enterobacteriaceae)	Expert Rules	3.1	 | ||||
| fullname	like	^Citrobacter (koseri|amalonaticus|sedlakii|farmeri|rodentium)			aminopenicillins, TIC	R	Table 01: Intrinsic resistance in Enterobacterales (at the time: Enterobacteriaceae)	Expert Rules	3.1	 | ||||
| fullname	like	^Citrobacter (freundii|braakii|murliniae|werkmanii|youngae)			aminopenicillins, AMC, CZO, FOX	R	Table 01: Intrinsic resistance in Enterobacterales (at the time: Enterobacteriaceae)	Expert Rules	3.1	 | ||||
| @@ -373,7 +499,9 @@ genus	is	Salmonella			cephalosporins_2nd	R	Expert Rules on Salmonella	Expert Rul | ||||
| genus	is	Salmonella			aminoglycosides	R	Expert Rules on Salmonella	Expert Rules	3.2	 | ||||
| genus	is	Salmonella	PEF	R	CIP	R	Expert Rules on Salmonella	Expert Rules	3.2	 | ||||
| genus_species	is	Staphylococcus aureus	FOX1	R	betalactams	R	Expert Rules on Staphylococcus	Expert Rules	3.2	 | ||||
| genus_species	is	Staphylococcus aureus	FOX	R	betalactams	R	Expert Rules on Staphylococcus	Expert Rules	3.2	 | ||||
| genus_species	is	Staphylococcus aureus	FOX1	S	betalactams	S	Expert Rules on Staphylococcus	Expert Rules	3.2	 | ||||
| genus_species	is	Staphylococcus aureus	FOX	S	betalactams	S	Expert Rules on Staphylococcus	Expert Rules	3.2	 | ||||
| genus_species	one_of	Staphylococcus aureus, Staphylococcus lugdunensis	PEN	R	AMP, AMX, AZL, BAM, CRB, CRN, EPC, HET, MEC, MEZ, MTM, PIP, PME, PVM, SBC, TAL, TEM, TIC	R	Expert Rules on Staphylococcus	Expert Rules	3.2	all penicillins without beta-lactamse inhibitor | ||||
| genus	is	Staphylococcus	ERY, CLI	S	macrolides, lincosamides	S	Expert Rules on Staphylococcus	Expert Rules	3.2	 | ||||
| genus	is	Staphylococcus	NOR	S	CIP, LVX, MFX, OFX	S	Expert Rules on Staphylococcus	Expert Rules	3.2	 | ||||
| @@ -491,7 +619,9 @@ genus	is	Salmonella			cephalosporins_2nd	R	Expert Rules on Salmonella	Expert Rul | ||||
| genus	is	Salmonella			aminoglycosides	R	Expert Rules on Salmonella	Expert Rules	3.3	 | ||||
| genus	is	Salmonella	PEF	R	CIP	R	Expert Rules on Salmonella	Expert Rules	3.3	 | ||||
| genus_species	is	Staphylococcus aureus	FOX1	R	betalactams	R	Expert Rules on Staphylococcus	Expert Rules	3.3	 | ||||
| genus_species	is	Staphylococcus aureus	FOX	R	betalactams	R	Expert Rules on Staphylococcus	Expert Rules	3.3	 | ||||
| genus_species	is	Staphylococcus aureus	FOX1	S	betalactams	S	Expert Rules on Staphylococcus	Expert Rules	3.3	 | ||||
| genus_species	is	Staphylococcus aureus	FOX	S	betalactams	S	Expert Rules on Staphylococcus	Expert Rules	3.3	 | ||||
| genus_species	one_of	Staphylococcus aureus, Staphylococcus lugdunensis	PEN	R	AMP, AMX, AZL, BAM, CRB, CRN, EPC, HET, MEC, MEZ, MTM, PIP, PME, PVM, SBC, TAL, TEM, TIC	R	Expert Rules on Staphylococcus	Expert Rules	3.3	all penicillins without beta-lactamse inhibitor | ||||
| genus	is	Staphylococcus	ERY, CLI	S	macrolides, lincosamides	S	Expert Rules on Staphylococcus	Expert Rules	3.3	 | ||||
| genus	is	Staphylococcus	NOR	S	CIP, LVX, MFX, OFX	S	Expert Rules on Staphylococcus	Expert Rules	3.3	 | ||||
|   | ||||
| Can't render this file because it contains an unexpected character in line 6 and column 96. | 
| @@ -33,12 +33,12 @@ library(cleaner) | ||||
|  | ||||
| # URL: | ||||
| # https://www.eucast.org/fileadmin/src/media/PDFs/EUCAST_files/Breakpoint_tables/Dosages_v_11.0_Breakpoint_Tables.pdf | ||||
| # download the PDF file, open in Acrobat Pro and export as Excel workbook | ||||
| breakpoints_version <- 11 | ||||
| # download the PDF file, open in Adobe Acrobat and export as Excel workbook | ||||
| breakpoints_version <- 12 | ||||
|  | ||||
| dosage_source <- read_excel("data-raw/Dosages_v_11.0_Breakpoint_Tables.xlsx", skip = 5, na = "None") %>% | ||||
| dosage_source <- read_excel("data-raw/Dosages_v_12.0_Breakpoint_Tables.xlsx", skip = 4, na = "None") %>% | ||||
|   format_names(snake_case = TRUE, penicillins = "drug") %>% | ||||
|   filter(!tolower(standard_dosage) %in% c("standard dosage_source", "under review")) %>% | ||||
|   filter(!tolower(standard_dosage) %in% c("standard dosage", "standard dosage_source", "under review")) %>% | ||||
|   filter(!is.na(standard_dosage)) %>% | ||||
|   # keep only one drug in the table | ||||
|   arrange(desc(drug)) %>% | ||||
| @@ -125,7 +125,7 @@ get_dosage_lst <- function(col_data) { | ||||
| standard <- get_dosage_lst(dosage_source$standard_dosage) | ||||
| high <- get_dosage_lst(dosage_source$high_dosage) | ||||
| uti <- get_dosage_lst(dosage_source$uncomplicated_uti) | ||||
| dosage <- bind_rows( | ||||
| dosage_new <- bind_rows( | ||||
|   # standard dose | ||||
|   data.frame( | ||||
|     ab = dosage_source$ab, | ||||
| @@ -171,6 +171,9 @@ dosage <- bind_rows( | ||||
|   arrange(name, administration, type) %>% | ||||
|   filter(!is.na(dose), dose != ".") %>% | ||||
|   as.data.frame(stringsAsFactors = FALSE) | ||||
| rownames(dosage) <- NULL | ||||
| rownames(dosage_new) <- NULL | ||||
|  | ||||
| dosage <- bind_rows(dosage_new, AMR::dosage) %>%  | ||||
|   dataset_UTF8_to_ASCII() | ||||
|  | ||||
| usethis::use_data(dosage, internal = FALSE, overwrite = TRUE, version = 2) | ||||
|   | ||||
							
								
								
									
										
											BIN
										
									
								
								data/dosage.rda
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								data/dosage.rda
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -5,7 +5,7 @@ | ||||
| \alias{dosage} | ||||
| \title{Data Set with Treatment Dosages as Defined by EUCAST} | ||||
| \format{ | ||||
| A \link[tibble:tibble]{tibble} with 169 observations and 9 variables: | ||||
| A \link[tibble:tibble]{tibble} with 336 observations and 9 variables: | ||||
| \itemize{ | ||||
| \item \code{ab}\cr Antibiotic ID as used in this package (such as \code{AMC}), using the official EARS-Net (European Antimicrobial Resistance Surveillance Network) codes where available | ||||
| \item \code{name}\cr Official name of the antimicrobial drug as used by WHONET/EARS-Net or the WHO | ||||
| @@ -25,7 +25,7 @@ dosage | ||||
| EUCAST breakpoints used in this package are based on the dosages in this data set. They can be retrieved with \code{\link[=eucast_dosage]{eucast_dosage()}}. | ||||
| } | ||||
| \details{ | ||||
| This data set is based on \href{https://www.eucast.org/clinical_breakpoints/}{'EUCAST Clinical Breakpoint Tables' v11.0} (2021). | ||||
| This data set is based on \href{https://www.eucast.org/clinical_breakpoints/}{'EUCAST Clinical Breakpoint Tables' v12.0} (2022) and \href{https://www.eucast.org/clinical_breakpoints/}{'EUCAST Clinical Breakpoint Tables' v11.0} (2021). | ||||
| \subsection{Direct download}{ | ||||
|  | ||||
| Like all data sets in this package, this data set is publicly available for download in the following formats: R, MS Excel, Apache Feather, Apache Parquet, SPSS, SAS, and Stata. Please visit \href{https://msberends.github.io/AMR/articles/datasets.html}{our website for the download links}. The actual files are of course available on \href{https://github.com/msberends/AMR/tree/main/data-raw}{our GitHub repository}. | ||||
|   | ||||
| @@ -25,7 +25,7 @@ eucast_rules( | ||||
|   info = interactive(), | ||||
|   rules = getOption("AMR_eucastrules", default = c("breakpoints", "expert")), | ||||
|   verbose = FALSE, | ||||
|   version_breakpoints = 11, | ||||
|   version_breakpoints = 12, | ||||
|   version_expertrules = 3.3, | ||||
|   ampc_cephalosporin_resistance = NA, | ||||
|   only_rsi_columns = FALSE, | ||||
| @@ -33,7 +33,7 @@ eucast_rules( | ||||
|   ... | ||||
| ) | ||||
|  | ||||
| eucast_dosage(ab, administration = "iv", version_breakpoints = 11) | ||||
| eucast_dosage(ab, administration = "iv", version_breakpoints = 12) | ||||
| } | ||||
| \arguments{ | ||||
| \item{x}{a data set with antibiotic columns, such as \code{amox}, \code{AMX} and \code{AMC}} | ||||
| @@ -46,7 +46,7 @@ eucast_dosage(ab, administration = "iv", version_breakpoints = 11) | ||||
|  | ||||
| \item{verbose}{a \link{logical} to turn Verbose mode on and off (default is off). In Verbose mode, the function does not apply rules to the data, but instead returns a data set in logbook form with extensive info about which rows and columns would be effected and in which way. Using Verbose mode takes a lot more time.} | ||||
|  | ||||
| \item{version_breakpoints}{the version number to use for the EUCAST Clinical Breakpoints guideline. Can be either "11.0" or "10.0".} | ||||
| \item{version_breakpoints}{the version number to use for the EUCAST Clinical Breakpoints guideline. Can be either "12.0", "11.0" or "10.0".} | ||||
|  | ||||
| \item{version_expertrules}{the version number to use for the EUCAST Expert Rules and Intrinsic Resistance guideline. Can be either "3.3", "3.2" or "3.1".} | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user