AMR/man/count.Rd

128 lines
4.9 KiB
Plaintext
Raw Normal View History

2018-08-22 00:02:26 +02:00
% Generated by roxygen2: do not edit by hand
% Please edit documentation in R/count.R
\name{count}
\alias{count}
\alias{count_R}
\alias{count_IR}
\alias{count_I}
\alias{count_SI}
\alias{count_S}
2018-10-12 16:35:18 +02:00
\alias{count_all}
\alias{n_rsi}
2018-08-22 00:02:26 +02:00
\alias{count_df}
\title{Count isolates}
\source{
Wickham H. \strong{Tidy Data.} The Journal of Statistical Software, vol. 59, 2014. \url{http://vita.had.co.nz/papers/tidy-data.html}
}
\usage{
count_R(..., also_single_tested = FALSE)
2018-08-22 00:02:26 +02:00
count_IR(..., also_single_tested = FALSE)
2018-08-22 00:02:26 +02:00
count_I(..., also_single_tested = FALSE)
2018-08-22 00:02:26 +02:00
count_SI(..., also_single_tested = FALSE)
2018-08-22 00:02:26 +02:00
count_S(..., also_single_tested = FALSE)
2018-08-22 00:02:26 +02:00
2018-10-12 16:35:18 +02:00
count_all(...)
n_rsi(...)
2018-08-22 00:02:26 +02:00
count_df(data, translate_ab = getOption("get_antibiotic_names",
2018-10-16 09:59:31 +02:00
"official"), combine_IR = FALSE)
2018-08-22 00:02:26 +02:00
}
\arguments{
2018-10-12 16:35:18 +02:00
\item{...}{one or more vectors (or columns) with antibiotic interpretations. They will be transformed internally with \code{\link{as.rsi}} if needed.}
2018-08-22 00:02:26 +02:00
\item{also_single_tested}{a logical to indicate whether (in combination therapies) also observations should be included where not all antibiotics were tested, but at least one of the tested antibiotics contains a target interpretation (e.g. S in case of \code{portion_S} and R in case of \code{portion_R}). \strong{This would lead to selection bias in almost all cases.}}
2018-08-22 00:02:26 +02:00
\item{data}{a \code{data.frame} containing columns with class \code{rsi} (see \code{\link{as.rsi}})}
\item{translate_ab}{a column name of the \code{\link{antibiotics}} data set to translate the antibiotic abbreviations to, using \code{\link{abname}}. This can be set with \code{\link{getOption}("get_antibiotic_names")}.}
2018-10-16 09:59:31 +02:00
\item{combine_IR}{a logical to indicate whether all values of I and R must be merged into one, so the output only consists of S vs. IR (susceptible vs. non-susceptible)}
2018-08-22 00:02:26 +02:00
}
\value{
Integer
}
\description{
2018-08-23 00:40:36 +02:00
These functions can be used to count resistant/susceptible microbial isolates. All functions support quasiquotation with pipes, can be used in \code{dplyr}s \code{\link[dplyr]{summarise}} and support grouped variables, see \emph{Examples}.
2018-08-22 00:02:26 +02:00
\code{count_R} and \code{count_IR} can be used to count resistant isolates, \code{count_S} and \code{count_SI} can be used to count susceptible isolates.\cr
}
\details{
These functions are meant to count isolates. Use the \code{\link{portion}_*} functions to calculate microbial resistance.
2018-10-12 16:35:18 +02:00
\code{n_rsi} is an alias of \code{count_all}. They can be used to count all available isolates, i.e. where all input antibiotics have an available result (S, I or R). Their use is equal to \code{\link{n_distinct}}. Their function is equal to \code{count_S(...) + count_IR(...)}.
2018-08-22 00:02:26 +02:00
\code{count_df} takes any variable from \code{data} that has an \code{"rsi"} class (created with \code{\link{as.rsi}}) and counts the amounts of R, I and S. The resulting \emph{tidy data} (see Source) \code{data.frame} will have three rows (S/I/R) and a column for each variable with class \code{"rsi"}.
}
\examples{
# septic_patients is a data set available in the AMR package. It is true, genuine data.
?septic_patients
# Count resistant isolates
count_R(septic_patients$amox)
count_IR(septic_patients$amox)
# Or susceptibile isolates
count_S(septic_patients$amox)
count_SI(septic_patients$amox)
2018-10-12 16:35:18 +02:00
# Count all available isolates
count_all(septic_patients$amox)
n_rsi(septic_patients$amox)
2018-08-22 00:02:26 +02:00
# Since n_rsi counts available isolates, you can
# calculate back to count e.g. non-susceptible isolates.
# This results in the same:
count_IR(septic_patients$amox)
portion_IR(septic_patients$amox) * n_rsi(septic_patients$amox)
library(dplyr)
septic_patients \%>\%
group_by(hospital_id) \%>\%
2018-10-12 16:35:18 +02:00
summarise(R = count_R(cipr),
I = count_I(cipr),
S = count_S(cipr),
n1 = count_all(cipr), # the actual total; sum of all three
n2 = n_rsi(cipr), # same - analogous to n_distinct
total = n()) # NOT the amount of tested isolates!
2018-08-22 00:02:26 +02:00
# Count co-resistance between amoxicillin/clav acid and gentamicin,
# so we can see that combination therapy does a lot more than mono therapy.
# Please mind that `portion_S` calculates percentages right away instead.
2018-10-12 16:35:18 +02:00
count_S(septic_patients$amcl) # S = 1057 (67.1\%)
count_all(septic_patients$amcl) # n = 1576
2018-08-22 00:02:26 +02:00
2018-10-12 16:35:18 +02:00
count_S(septic_patients$gent) # S = 1372 (74.0\%)
count_all(septic_patients$gent) # n = 1855
2018-08-22 00:02:26 +02:00
with(septic_patients,
2018-10-12 16:35:18 +02:00
count_S(amcl, gent)) # S = 1396 (92.0\%)
with(septic_patients, # n = 1517
2018-08-22 00:02:26 +02:00
n_rsi(amcl, gent))
# Get portions S/I/R immediately of all rsi columns
septic_patients \%>\%
select(amox, cipr) \%>\%
count_df(translate = FALSE)
# It also supports grouping variables
septic_patients \%>\%
select(hospital_id, amox, cipr) \%>\%
group_by(hospital_id) \%>\%
count_df(translate = FALSE)
}
\seealso{
2018-10-12 16:35:18 +02:00
\code{\link{portion}_*} to calculate microbial resistance and susceptibility.
2018-08-22 00:02:26 +02:00
}
\keyword{antibiotics}
\keyword{isolate}
\keyword{isolates}
\keyword{resistance}
\keyword{rsi}
\keyword{susceptibility}