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

First CRAN submission edits

This commit is contained in:
dr. M.S. (Matthijs) Berends 2018-02-22 20:48:48 +01:00
parent 77194527b5
commit d8da8daf9a
No known key found for this signature in database
GPG Key ID: 904E4D816D2F58BA
20 changed files with 162 additions and 94 deletions

View File

@ -1,7 +1,7 @@
Package: AMR Package: AMR
Version: 0.1.0 Version: 0.1.1
Date: 2018-02-20 Date: 2018-02-22
Title: Antimicrobial Resistance (AMR) Analysis Title: Antimicrobial Resistance Analysis
Authors@R: c( Authors@R: c(
person( person(
given = c("Matthijs", "S."), given = c("Matthijs", "S."),
@ -20,7 +20,8 @@ Authors@R: c(
role = "ctb")) role = "ctb"))
Description: Functions to simplify the analysis of Antimicrobial Resistance (AMR) Description: Functions to simplify the analysis of Antimicrobial Resistance (AMR)
of microbial isolates, by using new S3 classes and applying EUCAST expert rules of microbial isolates, by using new S3 classes and applying EUCAST expert rules
on antibiograms. on antibiograms according to Leclercq (2013)
<doi:10.1111/j.1469-0691.2011.03703.x>.
Depends: R (>= 3.0) Depends: R (>= 3.0)
Imports: dplyr (>= 0.7.0), reshape2 (>= 1.4.0), xml2, rvest Imports: dplyr (>= 0.7.0), reshape2 (>= 1.4.0), xml2, rvest
URL: https://github.com/msberends/AMR URL: https://github.com/msberends/AMR

View File

@ -21,7 +21,6 @@ export(interpretive_reading)
export(is.mic) export(is.mic)
export(is.rsi) export(is.rsi)
export(key_antibiotics) export(key_antibiotics)
export(key_antibiotics_equal)
export(left_join_bactlist) export(left_join_bactlist)
export(mo_property) export(mo_property)
export(right_join_bactlist) export(right_join_bactlist)

View File

@ -28,6 +28,7 @@
#' @rdname EUCAST #' @rdname EUCAST
#' @export #' @export
#' @importFrom dplyr %>% left_join select #' @importFrom dplyr %>% left_join select
#' @return table with edited variables of antibiotics.
#' @source #' @source
#' EUCAST Expert Rules Version 2.0: \cr #' EUCAST Expert Rules Version 2.0: \cr
#' Leclercq et al. \strong{EUCAST expert rules in antimicrobial susceptibility testing.} \emph{Clin Microbiol Infect.} 2013;19(2):141-60. \cr #' Leclercq et al. \strong{EUCAST expert rules in antimicrobial susceptibility testing.} \emph{Clin Microbiol Infect.} 2013;19(2):141-60. \cr
@ -37,7 +38,7 @@
#' \url{http://www.eucast.org/expert_rules_and_intrinsic_resistance} #' \url{http://www.eucast.org/expert_rules_and_intrinsic_resistance}
#' @examples #' @examples
#' \dontrun{ #' \dontrun{
#' tbl <- interpretive_reading(tbl) #' tbl <- EUCAST_rules(tbl)
#' } #' }
EUCAST_rules <- function(tbl, EUCAST_rules <- function(tbl,
col_bactcode = 'bacteriecode', col_bactcode = 'bacteriecode',

10
R/atc.R
View File

@ -18,7 +18,7 @@
#' Properties of an ATC code #' Properties of an ATC code
#' #'
#' Gets data from the WHO to determine properties of an ATC of e.g. an antibiotic. #' Gets data from the WHO to determine properties of an ATC of e.g. an antibiotic. \strong{This function requires an internet connection.}
#' @param atc_code a character or character vector with ATC code(s) of antibiotic(s) #' @param atc_code a character or character vector with ATC code(s) of antibiotic(s)
#' @param property property of an ATC code. Valid values are \code{"ATC code"}, \code{"Name"}, \code{"DDD"}, \code{"U"} (\code{"unit"}), \code{"Adm.R"} en \code{"Note"}. #' @param property property of an ATC code. Valid values are \code{"ATC code"}, \code{"Name"}, \code{"DDD"}, \code{"U"} (\code{"unit"}), \code{"Adm.R"} en \code{"Note"}.
#' @param administration type of administration, see \emph{Details} #' @param administration type of administration, see \emph{Details}
@ -54,6 +54,11 @@
#' @importFrom xml2 read_html #' @importFrom xml2 read_html
#' @importFrom rvest html_nodes html_table #' @importFrom rvest html_nodes html_table
#' @source \url{https://www.whocc.no/atc_ddd_alterations__cumulative/ddd_alterations/abbrevations/} #' @source \url{https://www.whocc.no/atc_ddd_alterations__cumulative/ddd_alterations/abbrevations/}
#' @examples
#' \donttest{
#' atc_property("J01CA04", "DDD", "O") # oral DDD of amoxicillin
#' atc_property("J01CA04", "DDD", "P") # parenteral DDD of amoxicillin
#' }
atc_property <- function(atc_code, atc_property <- function(atc_code,
property, property,
administration = 'O', administration = 'O',
@ -128,6 +133,7 @@ atc_property <- function(atc_code,
#' @param textbetween text to put between multiple returned texts #' @param textbetween text to put between multiple returned texts
#' @param tolower return output as lower case with function \code{\link{tolower}}. #' @param tolower return output as lower case with function \code{\link{tolower}}.
#' @keywords ab antibiotics #' @keywords ab antibiotics
#' @source \code{\link{ablist}}
#' @export #' @export
#' @importFrom dplyr %>% filter select slice #' @importFrom dplyr %>% filter select slice
#' @examples #' @examples
@ -148,8 +154,6 @@ atc_property <- function(atc_code,
#' #'
#' abname("J01CR02", from = "atc", to = "umcg") #' abname("J01CR02", from = "atc", to = "umcg")
#' # "AMCL" #' # "AMCL"
#'
#' @source \code{\link{ablist}}
abname <- function(abcode, from = 'umcg', to = 'official', textbetween = ' + ', tolower = FALSE) { abname <- function(abcode, from = 'umcg', to = 'official', textbetween = ' + ', tolower = FALSE) {
ablist <- AMR::ablist ablist <- AMR::ablist

View File

@ -26,8 +26,16 @@
#' @importFrom dplyr %>% #' @importFrom dplyr %>%
#' @examples #' @examples
#' rsi_data <- as.rsi(c(rep("S", 474), rep("I", 36), rep("R", 370))) #' rsi_data <- as.rsi(c(rep("S", 474), rep("I", 36), rep("R", 370)))
#'
#' rsi_data <- as.rsi(c(rep("S", 474), rep("I", 36), rep("R", 370), "A", "B", "C")) #' rsi_data <- as.rsi(c(rep("S", 474), rep("I", 36), rep("R", 370), "A", "B", "C"))
#' is.rsi(rsi_data)
#' plot(rsi_data)
#'
#' \donttest{
#' library(dplyr)
#' tbl %>%
#' mutate_at(vars(ends_with("_rsi")), as.rsi)
#' sapply(mic_data, is.rsi)
#' }
as.rsi <- function(x) { as.rsi <- function(x) {
if (is.rsi(x)) { if (is.rsi(x)) {
x x
@ -157,6 +165,17 @@ plot.rsi <- function(x, ...) {
#' @return New class \code{mic} #' @return New class \code{mic}
#' @export #' @export
#' @importFrom dplyr %>% #' @importFrom dplyr %>%
#' @examples
#' mic_data <- as.mic(c(">=32", "1.0", "1", "1.00", 8, "<=0.128", "8", "16", "16"))
#' is.mic(mic_data)
#' plot(mic_data)
#'
#' \donttest{
#' library(dplyr)
#' tbl %>%
#' mutate_at(vars(ends_with("_mic")), as.mic)
#' sapply(mic_data, is.mic)
#' }
as.mic <- function(x, na.rm = FALSE) { as.mic <- function(x, na.rm = FALSE) {
if (is.mic(x)) { if (is.mic(x)) {
x x

View File

@ -46,6 +46,7 @@
#' @examples #' @examples
#' \dontrun{ #' \dontrun{
#' #'
#' # set key antibiotics to a new variable
#' tbl$keyab <- key_antibiotics(tbl) #' tbl$keyab <- key_antibiotics(tbl)
#' #'
#' tbl$first_isolate <- #' tbl$first_isolate <-
@ -355,7 +356,13 @@ first_isolate <- function(tbl,
#' @param amcl,amox,cfot,cfta,cftr,cfur,cipr,clar,clin,clox,doxy,gent,line,mero,peni,pita,rifa,teic,trsu,vanc column names of antibiotics. #' @param amcl,amox,cfot,cfta,cftr,cfur,cipr,clar,clin,clox,doxy,gent,line,mero,peni,pita,rifa,teic,trsu,vanc column names of antibiotics.
#' @export #' @export
#' @importFrom dplyr %>% mutate if_else #' @importFrom dplyr %>% mutate if_else
#' @return Character of length 1.
#' @seealso \code{\link{mo_property}} \code{\link{ablist}} #' @seealso \code{\link{mo_property}} \code{\link{ablist}}
#' @examples
#' \donttest{
#' #' # set key antibiotics to a new variable
#' tbl$keyab <- key_antibiotics(tbl)
#' }
key_antibiotics <- function(tbl, key_antibiotics <- function(tbl,
col_bactcode = 'bacteriecode', col_bactcode = 'bacteriecode',
info = TRUE, info = TRUE,
@ -439,15 +446,17 @@ key_antibiotics <- function(tbl,
} }
#' Compare key antibiotics # Compare key antibiotics
#' #
#' Check whether two text values with key antibiotics match. Supports vectors. # Check whether two text values with key antibiotics match. Supports vectors.
#' @param x,y tekst (or multiple text vectors) with antimicrobial interpretations # @param x,y tekst (or multiple text vectors) with antimicrobial interpretations
#' @param ignore_I ignore \code{"I"} as antimicrobial interpretation of key antibiotics (with \code{FALSE}, changes in antibiograms from S to I and I to R will be interpreted as difference) # @param ignore_I ignore \code{"I"} as antimicrobial interpretation of key antibiotics (with \code{FALSE}, changes in antibiograms from S to I and I to R will be interpreted as difference)
#' @param info print progress # @param info print progress
#' @return logical # @return logical
#' @export # @export
#' @seealso \code{\link{key_antibiotics}} # @seealso \code{\link{key_antibiotics}}
# only internal use
key_antibiotics_equal <- function(x, y, ignore_I = TRUE, info = FALSE) { key_antibiotics_equal <- function(x, y, ignore_I = TRUE, info = FALSE) {
if (length(x) != length(y)) { if (length(x) != length(y)) {
stop('Length of `x` and `y` must be equal.') stop('Length of `x` and `y` must be equal.')

View File

@ -1,4 +1,4 @@
#' Join van tabel en \code{bactlist} #' Join a table with \code{bactlist}
#' #'
#' Join the list of microorganisms \code{\link{bactlist}} easily to an existing table. #' Join the list of microorganisms \code{\link{bactlist}} easily to an existing table.
#' @rdname join #' @rdname join
@ -9,6 +9,17 @@
#' @param ... other parameters to pass trhough to \code{dplyr::\link[dplyr]{join}}. #' @param ... other parameters to pass trhough to \code{dplyr::\link[dplyr]{join}}.
#' @details As opposed to the \code{\link[dplyr]{join}} functions of \code{dplyr}, at default existing columns will get a suffix \code{"2"} and the newly joined columns will not get a suffix. See \code{\link[dplyr]{join}} for more information. #' @details As opposed to the \code{\link[dplyr]{join}} functions of \code{dplyr}, at default existing columns will get a suffix \code{"2"} and the newly joined columns will not get a suffix. See \code{\link[dplyr]{join}} for more information.
#' @export #' @export
#' @examples
#' df <- data.frame(date = seq(from = as.Date("2018-01-01"),
#' to = as.Date("2018-01-07"),
#' by = 1),
#' bacteria_id = c("STAAUR", "STAAUR", "STAAUR", "STAAUR",
#' "ESCCOL", "ESCCOL", "ESCCOL"),
#' stringsAsFactors = FALSE)
#'
#' colnames(df)
#' df2 <- left_join_bactlist(df, "bacteria_id")
#' colnames(df2)
inner_join_bactlist <- function(x, by = 'bactid', ...) { inner_join_bactlist <- function(x, by = 'bactid', ...) {
# no name set to `by` parameter # no name set to `by` parameter
if (is.null(names(by))) { if (is.null(names(by))) {

View File

@ -167,7 +167,7 @@ rsi_df <- function(tbl,
#' Resistance of isolates #' Resistance of isolates
#' #'
#' This function can be used in \code{\link[dplyr]{summarise}}, see \emph{Examples}. CaBerekent het percentage S, SI, I, IR of R van een lijst isolaten. #' This function can be used in \code{dplyr}s \code{\link[dplyr]{summarise}}, see \emph{Examples}. Calculate the percentage S, SI, I, IR or R of a vector of isolates.
#' @param ab1,ab2 list with interpretations of an antibiotic #' @param ab1,ab2 list with interpretations of an antibiotic
#' @inheritParams rsi_df #' @inheritParams rsi_df
#' @details This function uses the \code{\link{rsi_df}} function internally. #' @details This function uses the \code{\link{rsi_df}} function internally.
@ -177,20 +177,19 @@ rsi_df <- function(tbl,
#' @examples #' @examples
#' \dontrun{ #' \dontrun{
#' tbl %>% #' tbl %>%
#' group_by(year, hospital) %>%
#' summarise(
#' isolates = n(),
#' cipro = rsi(cipr, percent = TRUE),
#' amoxi = rsi(amox, percent = TRUE)
#' )
#'
#' tbl %>%
#' group_by(hospital) %>% #' group_by(hospital) %>%
#' summarise(cipr = rsi(cipr)) #' summarise(cipr = rsi(cipr))
#' #'
#' rsi(isolates$amox) #' tbl %>%
#' group_by(year, hospital) %>%
#' summarise(
#' isolates = n(),
#' cipro = rsi(cipr %>% as.rsi(), percent = TRUE),
#' amoxi = rsi(amox %>% as.rsi(), percent = TRUE))
#' #'
#' rsi(isolates$amcl, interpretation = "S") #' rsi(as.rsi(isolates$amox))
#'
#' rsi(as.rsi(isolates$amcl), interpretation = "S")
#' } #' }
rsi <- function(ab1, ab2 = NA, interpretation = 'IR', minimum = 30, percent = FALSE, info = FALSE, warning = FALSE) { rsi <- function(ab1, ab2 = NA, interpretation = 'IR', minimum = 30, percent = FALSE, info = FALSE, warning = FALSE) {
functietekst <- as.character(match.call()) functietekst <- as.character(match.call())
@ -258,6 +257,7 @@ rsi <- function(ab1, ab2 = NA, interpretation = 'IR', minimum = 30, percent = FA
#' rsi_predict(tbl[which(first_isolate == TRUE & genus == "Haemophilus"),], "amcl") #' rsi_predict(tbl[which(first_isolate == TRUE & genus == "Haemophilus"),], "amcl")
#' #'
#' # or with dplyr so you can actually read it: #' # or with dplyr so you can actually read it:
#' library(dplyr)
#' tbl %>% #' tbl %>%
#' filter(first_isolate == TRUE, #' filter(first_isolate == TRUE,
#' genus == "Haemophilus") %>% #' genus == "Haemophilus") %>%

View File

@ -12,6 +12,26 @@ AMR can also be predicted for the forthcoming years with the `rsi_predict` funct
It also contains functions to translate antibiotic codes from the lab (like `"AMOX"`) or the [WHO](https://www.whocc.no/atc_ddd_index/?code=J01CA04&showdescription=no) (like `"J01CA04"`) to trivial names (like `"amoxicillin"`) and vice versa. It also contains functions to translate antibiotic codes from the lab (like `"AMOX"`) or the [WHO](https://www.whocc.no/atc_ddd_index/?code=J01CA04&showdescription=no) (like `"J01CA04"`) to trivial names (like `"amoxicillin"`) and vice versa.
## How to get it?
[![CRAN_Badge](http://www.r-pkg.org/badges/version/AMR)](http://cran.r-project.org/package=AMR)
This package is available on CRAN (latest stable version) and also here on GitHub (latest development version).
#### Latest stable version from CRAN (recommended)
RStudio:
- Click on `Tools` and then `Install Packages..`
- Type in `AMR` and press <kbd>Install</kbd>
Other:
```r
install.packages("AMR")
```
#### Latest development version from GitHub
```r
devtools::install_github("msberends/AMR")
```
## How to use it? ## How to use it?
```r ```r
# Call it with: # Call it with:
@ -95,28 +115,6 @@ abname(...)
abname("J01CR02", from = "atc", to = "umcg") # "AMCL" abname("J01CR02", from = "atc", to = "umcg") # "AMCL"
``` ```
## How to get it?
This package is only available here on GitHub, but respects the [CRAN Repository Policy](https://cran.r-project.org/web/packages/policies.html).
*Installation commands:*
```r
library(devtools)
install_github("msberends/AMR")
```
*Working behind a proxy? Then use:*
```r
library(httr)
library(devtools)
set_config(use_proxy("yourproxydomain.com",
8080,
"username",
"password",
"any")) # change "any" to "basic" or "digest" if needed
install_github("msberends/AMR")
reset_config()
```
## Authors ## Authors
- [Berends MS](https://github.com/msberends)<sup>1,2</sup>, PhD Student - [Berends MS](https://github.com/msberends)<sup>1,2</sup>, PhD Student

View File

@ -44,11 +44,14 @@ interpretive_reading(...)
\item{...}{parameters that are passed on to \code{EUCAST_rules}} \item{...}{parameters that are passed on to \code{EUCAST_rules}}
} }
\value{
table with edited variables of antibiotics.
}
\description{ \description{
Apply expert rules (like intrinsic resistance), as defined by the European Committee on Antimicrobial Susceptibility Testing (EUCAST, \url{http://eucast.org}), see \emph{Source}. Apply expert rules (like intrinsic resistance), as defined by the European Committee on Antimicrobial Susceptibility Testing (EUCAST, \url{http://eucast.org}), see \emph{Source}.
} }
\examples{ \examples{
\dontrun{ \dontrun{
tbl <- interpretive_reading(tbl) tbl <- EUCAST_rules(tbl)
} }
} }

View File

@ -40,7 +40,6 @@ abname("AMCL", to = "atc")
abname("J01CR02", from = "atc", to = "umcg") abname("J01CR02", from = "atc", to = "umcg")
# "AMCL" # "AMCL"
} }
\keyword{ab} \keyword{ab}
\keyword{antibiotics} \keyword{antibiotics}

View File

@ -20,3 +20,15 @@ New class \code{mic}
\description{ \description{
This transforms a vector to a new class\code{mic}, which is an ordered factor valid MIC values as levels. Invalid MIC values will be translated as \code{NA} with a warning. This transforms a vector to a new class\code{mic}, which is an ordered factor valid MIC values as levels. Invalid MIC values will be translated as \code{NA} with a warning.
} }
\examples{
mic_data <- as.mic(c(">=32", "1.0", "1", "1.00", 8, "<=0.128", "8", "16", "16"))
is.mic(mic_data)
plot(mic_data)
\donttest{
library(dplyr)
tbl \%>\%
mutate_at(vars(ends_with("_mic")), as.mic)
sapply(mic_data, is.mic)
}
}

View File

@ -20,6 +20,14 @@ This transforms a vector to a new class \code{rsi}, which is an ordered factor w
} }
\examples{ \examples{
rsi_data <- as.rsi(c(rep("S", 474), rep("I", 36), rep("R", 370))) rsi_data <- as.rsi(c(rep("S", 474), rep("I", 36), rep("R", 370)))
rsi_data <- as.rsi(c(rep("S", 474), rep("I", 36), rep("R", 370), "A", "B", "C")) rsi_data <- as.rsi(c(rep("S", 474), rep("I", 36), rep("R", 370), "A", "B", "C"))
is.rsi(rsi_data)
plot(rsi_data)
\donttest{
library(dplyr)
tbl \%>\%
mutate_at(vars(ends_with("_rsi")), as.rsi)
sapply(mic_data, is.rsi)
}
} }

View File

@ -20,7 +20,7 @@ atc_property(atc_code, property, administration = "O",
\item{url}{url of website of the WHO. The sign \code{\%s} can be used as a placeholder for ATC codes.} \item{url}{url of website of the WHO. The sign \code{\%s} can be used as a placeholder for ATC codes.}
} }
\description{ \description{
Gets data from the WHO to determine properties of an ATC of e.g. an antibiotic. Gets data from the WHO to determine properties of an ATC of e.g. an antibiotic. \strong{This function requires an internet connection.}
} }
\details{ \details{
Abbreviations for the property \code{"Adm.R"} (parameter \code{administration}): Abbreviations for the property \code{"Adm.R"} (parameter \code{administration}):
@ -49,3 +49,9 @@ Abbreviations for the property \code{"U"} (unit):
\item{\code{"ml"}}{ = milliliter (e.g. eyedrops)} \item{\code{"ml"}}{ = milliliter (e.g. eyedrops)}
} }
} }
\examples{
\donttest{
atc_property("J01CA04", "DDD", "O") # oral DDD of amoxicillin
atc_property("J01CA04", "DDD", "P") # parenteral DDD of amoxicillin
}
}

View File

@ -57,6 +57,7 @@ To conduct an analysis of antimicrobial resistance, you should only include the
\examples{ \examples{
\dontrun{ \dontrun{
# set key antibiotics to a new variable
tbl$keyab <- key_antibiotics(tbl) tbl$keyab <- key_antibiotics(tbl)
tbl$first_isolate <- tbl$first_isolate <-

View File

@ -9,7 +9,7 @@
\alias{full_join_bactlist} \alias{full_join_bactlist}
\alias{semi_join_bactlist} \alias{semi_join_bactlist}
\alias{anti_join_bactlist} \alias{anti_join_bactlist}
\title{Join van tabel en \code{bactlist}} \title{Join a table with \code{bactlist}}
\usage{ \usage{
inner_join_bactlist(x, by = "bactid", ...) inner_join_bactlist(x, by = "bactid", ...)
@ -36,3 +36,15 @@ Join the list of microorganisms \code{\link{bactlist}} easily to an existing tab
\details{ \details{
As opposed to the \code{\link[dplyr]{join}} functions of \code{dplyr}, at default existing columns will get a suffix \code{"2"} and the newly joined columns will not get a suffix. See \code{\link[dplyr]{join}} for more information. As opposed to the \code{\link[dplyr]{join}} functions of \code{dplyr}, at default existing columns will get a suffix \code{"2"} and the newly joined columns will not get a suffix. See \code{\link[dplyr]{join}} for more information.
} }
\examples{
df <- data.frame(date = seq(from = as.Date("2018-01-01"),
to = as.Date("2018-01-07"),
by = 1),
bacteria_id = c("STAAUR", "STAAUR", "STAAUR", "STAAUR",
"ESCCOL", "ESCCOL", "ESCCOL"),
stringsAsFactors = FALSE)
colnames(df)
df2 <- left_join_bactlist(df, "bacteria_id")
colnames(df2)
}

View File

@ -20,9 +20,18 @@ key_antibiotics(tbl, col_bactcode = "bacteriecode", info = TRUE,
\item{amcl, amox, cfot, cfta, cftr, cfur, cipr, clar, clin, clox, doxy, gent, line, mero, peni, pita, rifa, teic, trsu, vanc}{column names of antibiotics.} \item{amcl, amox, cfot, cfta, cftr, cfur, cipr, clar, clin, clox, doxy, gent, line, mero, peni, pita, rifa, teic, trsu, vanc}{column names of antibiotics.}
} }
\value{
Character of length 1.
}
\description{ \description{
Key antibiotics based on bacteria ID Key antibiotics based on bacteria ID
} }
\examples{
\donttest{
#' # set key antibiotics to a new variable
tbl$keyab <- key_antibiotics(tbl)
}
}
\seealso{ \seealso{
\code{\link{mo_property}} \code{\link{ablist}} \code{\link{mo_property}} \code{\link{ablist}}
} }

View File

@ -1,24 +0,0 @@
% Generated by roxygen2: do not edit by hand
% Please edit documentation in R/first_isolates.R
\name{key_antibiotics_equal}
\alias{key_antibiotics_equal}
\title{Compare key antibiotics}
\usage{
key_antibiotics_equal(x, y, ignore_I = TRUE, info = FALSE)
}
\arguments{
\item{x, y}{tekst (or multiple text vectors) with antimicrobial interpretations}
\item{ignore_I}{ignore \code{"I"} as antimicrobial interpretation of key antibiotics (with \code{FALSE}, changes in antibiograms from S to I and I to R will be interpreted as difference)}
\item{info}{print progress}
}
\value{
logical
}
\description{
Check whether two text values with key antibiotics match. Supports vectors.
}
\seealso{
\code{\link{key_antibiotics}}
}

View File

@ -24,28 +24,27 @@ rsi(ab1, ab2 = NA, interpretation = "IR", minimum = 30, percent = FALSE,
Double or, when \code{percent = TRUE}, a character. Double or, when \code{percent = TRUE}, a character.
} }
\description{ \description{
This function can be used in \code{\link[dplyr]{summarise}}, see \emph{Examples}. CaBerekent het percentage S, SI, I, IR of R van een lijst isolaten. This function can be used in \code{dplyr}s \code{\link[dplyr]{summarise}}, see \emph{Examples}. Calculate the percentage S, SI, I, IR or R of a vector of isolates.
} }
\details{ \details{
This function uses the \code{\link{rsi_df}} function internally. This function uses the \code{\link{rsi_df}} function internally.
} }
\examples{ \examples{
\dontrun{ \dontrun{
tbl \%>\%
group_by(year, hospital) \%>\%
summarise(
isolates = n(),
cipro = rsi(cipr, percent = TRUE),
amoxi = rsi(amox, percent = TRUE)
)
tbl \%>\% tbl \%>\%
group_by(hospital) \%>\% group_by(hospital) \%>\%
summarise(cipr = rsi(cipr)) summarise(cipr = rsi(cipr))
rsi(isolates$amox) tbl \%>\%
group_by(year, hospital) \%>\%
summarise(
isolates = n(),
cipro = rsi(cipr \%>\% as.rsi(), percent = TRUE),
amoxi = rsi(amox \%>\% as.rsi(), percent = TRUE))
rsi(isolates$amcl, interpretation = "S") rsi(as.rsi(isolates$amox))
rsi(as.rsi(isolates$amcl), interpretation = "S")
} }
} }
\keyword{antibiotics} \keyword{antibiotics}

View File

@ -40,6 +40,7 @@ Create a prediction model to predict antimicrobial resistance for the next years
rsi_predict(tbl[which(first_isolate == TRUE & genus == "Haemophilus"),], "amcl") rsi_predict(tbl[which(first_isolate == TRUE & genus == "Haemophilus"),], "amcl")
# or with dplyr so you can actually read it: # or with dplyr so you can actually read it:
library(dplyr)
tbl \%>\% tbl \%>\%
filter(first_isolate == TRUE, filter(first_isolate == TRUE,
genus == "Haemophilus") \%>\% genus == "Haemophilus") \%>\%