1
0
mirror of https://github.com/msberends/AMR.git synced 2025-01-13 23:31:38 +01:00

rsi for freq

This commit is contained in:
dr. M.S. (Matthijs) Berends 2018-08-01 22:37:28 +02:00
parent d8f70a74de
commit edd2dd09dc
8 changed files with 30 additions and 44 deletions

View File

@ -1,6 +1,6 @@
Package: AMR Package: AMR
Version: 0.2.0.9018 Version: 0.2.0.9019
Date: 2018-07-30 Date: 2018-08-01
Title: Antimicrobial Resistance Analysis Title: Antimicrobial Resistance Analysis
Authors@R: c( Authors@R: c(
person( person(

View File

@ -17,6 +17,7 @@
* Functions `clipboard_import` and `clipboard_export` as helper functions to quickly copy and paste from/to software like Excel and SPSS. These functions use the `clipr` package, but are a little altered to also support headless Linux servers (so you can use it in RStudio Server) * Functions `clipboard_import` and `clipboard_export` as helper functions to quickly copy and paste from/to software like Excel and SPSS. These functions use the `clipr` package, but are a little altered to also support headless Linux servers (so you can use it in RStudio Server)
* New for frequency tables (function `freq`): * New for frequency tables (function `freq`):
* A vignette to explain its usage * A vignette to explain its usage
* Support for `rsi` (antimicrobial resistance) to use as input
* Support for `table` to use as input: `freq(table(x, y))` * Support for `table` to use as input: `freq(table(x, y))`
* Support for existing functions `hist` and `plot` to use a frequency table as input: `hist(freq(df$age))` * Support for existing functions `hist` and `plot` to use a frequency table as input: `hist(freq(df$age))`
* Support for `as.vector`, `as.data.frame`, `as_tibble` and `format` * Support for `as.vector`, `as.data.frame`, `as_tibble` and `format`
@ -30,9 +31,9 @@
* More antibiotics for EUCAST rules * More antibiotics for EUCAST rules
* Updated version of the `septic_patients` data set to better reflect the reality * Updated version of the `septic_patients` data set to better reflect the reality
* Pretty printing for tibbles removed as it is not really the scope of this package * Pretty printing for tibbles removed as it is not really the scope of this package
* Printing of `mic` and `rsi` classes now returns all values - use `freq` to check distributions
* Improved speed of key antibiotics comparison for determining first isolates * Improved speed of key antibiotics comparison for determining first isolates
* Column names for the `key_antibiotics` function are now generic: 6 for broadspectrum ABs, 6 for Gram-positive specific and 6 for Gram-negative specific ABs * Column names for the `key_antibiotics` function are now generic: 6 for broadspectrum ABs, 6 for Gram-positive specific and 6 for Gram-negative specific ABs
* Printing of class `mic` now shows all MIC values
* `%like%` now supports multiple patterns * `%like%` now supports multiple patterns
* Frequency tables are now actual `data.frame`s with altered console printing to make it look like a frequency table. Because of this, the parameter `toConsole` is not longer needed. * Frequency tables are now actual `data.frame`s with altered console printing to make it look like a frequency table. Because of this, the parameter `toConsole` is not longer needed.
* Fix for `freq` where the class of an item would be lost * Fix for `freq` where the class of an item would be lost
@ -52,7 +53,7 @@
* Other small fixes * Other small fixes
#### Other #### Other
* Unit testing for all Linux and macOS release of R 3.1 and higher: https://travis-ci.org/msberends/AMR * Unit testing for all Linux and macOS releases of R 3.1 and higher: https://travis-ci.org/msberends/AMR
# 0.2.0 (latest stable version) # 0.2.0 (latest stable version)
**Published on CRAN: 2018-05-03** **Published on CRAN: 2018-05-03**

View File

@ -36,6 +36,7 @@
#' #'
#' plot(rsi_data) # for percentages #' plot(rsi_data) # for percentages
#' barplot(rsi_data) # for frequencies #' barplot(rsi_data) # for frequencies
#' freq(rsi_data) # frequency table with informative header
as.rsi <- function(x) { as.rsi <- function(x) {
if (is.rsi(x)) { if (is.rsi(x)) {
x x
@ -92,39 +93,17 @@ is.rsi <- function(x) {
#' @importFrom dplyr %>% #' @importFrom dplyr %>%
#' @noRd #' @noRd
print.rsi <- function(x, ...) { print.rsi <- function(x, ...) {
n_total <- x %>% length()
x <- x[!is.na(x)]
n <- x %>% length()
S <- x[x == 'S'] %>% length()
I <- x[x == 'I'] %>% length()
R <- x[x == 'R'] %>% length()
IR <- x[x %in% c('I', 'R')] %>% length()
cat("Class 'rsi'\n") cat("Class 'rsi'\n")
cat(n, " results (missing: ", n_total - n, ' = ', percent((n_total - n) / n_total, force_zero = TRUE), ')\n', sep = "") print(as.character(x), quote = FALSE)
if (n > 0) {
cat('\n')
cat('Sum of S: ', S, ' (', percent(S / n, force_zero = TRUE), ')\n', sep = "")
cat('Sum of IR: ', IR, ' (', percent(IR / n, force_zero = TRUE), ')\n', sep = "")
cat('- Sum of R: ', R, ' (', percent(R / n, force_zero = TRUE), ')\n', sep = "")
cat('- Sum of I: ', I, ' (', percent(I / n, force_zero = TRUE), ')\n', sep = "")
}
} }
#' @exportMethod summary.rsi #' @exportMethod summary.rsi
#' @export #' @export
#' @importFrom dplyr %>%
#' @noRd #' @noRd
summary.rsi <- function(object, ...) { summary.rsi <- function(object, ...) {
x <- object x <- object
n_total <- x %>% length() lst <- c('rsi', sum(is.na(x)), sum(x == "S"), sum(x %in% c("I", "R")), sum(x == "R"), sum(x == "I"))
x <- x[!is.na(x)] names(lst) <- c("Mode", "<NA>", "Sum S", "Sum IR", "-Sum R", "-Sum I")
n <- x %>% length()
S <- x[x == 'S'] %>% length()
I <- x[x == 'I'] %>% length()
R <- x[x == 'R'] %>% length()
IR <- x[x %in% c('I', 'R')] %>% length()
lst <- c('rsi', n_total - n, S, IR, R, I)
names(lst) <- c("Mode", "<NA>", "Sum S", "Sum IR", "Sum R", "Sum I")
lst lst
} }
@ -213,6 +192,7 @@ barplot.rsi <- function(height, ...) {
#' #'
#' plot(mic_data) #' plot(mic_data)
#' barplot(mic_data) #' barplot(mic_data)
#' freq(mic_data)
as.mic <- function(x, na.rm = FALSE) { as.mic <- function(x, na.rm = FALSE) {
if (is.mic(x)) { if (is.mic(x)) {
x x
@ -363,18 +343,8 @@ as.numeric.mic <- function(x, ...) {
#' @importFrom dplyr %>% tibble group_by summarise pull #' @importFrom dplyr %>% tibble group_by summarise pull
#' @noRd #' @noRd
print.mic <- function(x, ...) { print.mic <- function(x, ...) {
n_total <- x %>% length()
x <- x[!is.na(x)]
n <- x %>% length()
cat("Class 'mic'\n") cat("Class 'mic'\n")
cat(n, " results (missing: ", n_total - n, ' = ', percent((n_total - n) / n_total, force_zero = TRUE), ')\n', sep = "") print(as.character(x), quote = FALSE)
if (n > 0) {
cat('\n')
tibble(MIC = x, y = 1) %>%
group_by(MIC) %>%
summarise(n = sum(y)) %>%
base::print.data.frame(row.names = FALSE)
}
} }
#' @exportMethod summary.mic #' @exportMethod summary.mic
@ -406,7 +376,6 @@ plot.mic <- function(x, ...) {
#' @exportMethod barplot.mic #' @exportMethod barplot.mic
#' @export #' @export
#' @importFrom dplyr %>% group_by summarise
#' @importFrom graphics barplot axis #' @importFrom graphics barplot axis
#' @noRd #' @noRd
barplot.mic <- function(height, ...) { barplot.mic <- function(height, ...) {
@ -415,6 +384,7 @@ barplot.mic <- function(height, ...) {
} }
#' @importFrom graphics barplot axis #' @importFrom graphics barplot axis
#' @importFrom dplyr %>% group_by summarise
create_barplot_mic <- function(x, x_name, ...) { create_barplot_mic <- function(x, x_name, ...) {
data <- data.frame(mic = x, cnt = 1) %>% data <- data.frame(mic = x, cnt = 1) %>%
group_by(mic) %>% group_by(mic) %>%

View File

@ -305,7 +305,7 @@ frequency_tbl <- function(x,
header <- header %>% paste0(markdown_line, '\nLength: ', (NAs %>% length() + x %>% length()) %>% format(), header <- header %>% paste0(markdown_line, '\nLength: ', (NAs %>% length() + x %>% length()) %>% format(),
' (of which NA: ', NAs %>% length() %>% format(), ' (of which NA: ', NAs %>% length() %>% format(),
' = ', (NAs %>% length() / (NAs %>% length() + x %>% length())) %>% percent(force_zero = TRUE) %>% sub('NaN', '0', ., fixed = TRUE), ')') ' = ', (NAs %>% length() / (NAs %>% length() + x %>% length())) %>% percent(force_zero = TRUE, round = digits) %>% sub('NaN', '0', ., fixed = TRUE), ')')
header <- header %>% paste0(markdown_line, '\nUnique: ', x %>% n_distinct() %>% format()) header <- header %>% paste0(markdown_line, '\nUnique: ', x %>% n_distinct() %>% format())
if (NROW(x) > 0 & any(class(x) %in% c('double', 'integer', 'numeric', 'raw', 'single'))) { if (NROW(x) > 0 & any(class(x) %in% c('double', 'integer', 'numeric', 'raw', 'single'))) {
@ -326,6 +326,17 @@ frequency_tbl <- function(x,
header <- header %>% paste0(' (unique: ', boxplot.stats(x)$out %>% n_distinct(), ')') header <- header %>% paste0(' (unique: ', boxplot.stats(x)$out %>% n_distinct(), ')')
} }
} }
if (any(class(x) == "rsi")) {
header <- header %>% paste0('\n')
cnt_S <- sum(x == "S")
cnt_I <- sum(x == "I")
cnt_R <- sum(x == "R")
header <- header %>% paste(markdown_line, '\n%IR: ',
((cnt_I + cnt_R) / sum(!is.na(x))) %>% percent(force_zero = TRUE, round = digits))
header <- header %>% paste0(markdown_line, '\nRatio SIR: 1.0 : ',
(cnt_I / cnt_S) %>% format(digits = 1, nsmall = 1), " : ",
(cnt_R / cnt_S) %>% format(digits = 1, nsmall = 1))
}
formatdates <- "%e %B %Y" # = d mmmm yyyy formatdates <- "%e %B %Y" # = d mmmm yyyy
if (any(class(x) == 'hms')) { if (any(class(x) == 'hms')) {

View File

@ -29,6 +29,7 @@ as.mic("<=0.002; S") # will return <=0.002
plot(mic_data) plot(mic_data)
barplot(mic_data) barplot(mic_data)
freq(mic_data)
} }
\seealso{ \seealso{
\code{\link{as.rsi}} \code{\link{as.rsi}}

View File

@ -28,6 +28,7 @@ as.rsi("<= 0.002; S") # will return S
plot(rsi_data) # for percentages plot(rsi_data) # for percentages
barplot(rsi_data) # for frequencies barplot(rsi_data) # for frequencies
freq(rsi_data) # frequency table with informative header
} }
\seealso{ \seealso{
\code{\link{as.mic}} \code{\link{as.mic}}

View File

@ -17,8 +17,8 @@ test_that("rsi works", {
"<NA>" = "0", "<NA>" = "0",
"Sum S" = "1", "Sum S" = "1",
"Sum IR" = "1", "Sum IR" = "1",
"Sum R" = "1", "-Sum R" = "1",
"Sum I" = "0")) "-Sum I" = "0"))
}) })
test_that("mic works", { test_that("mic works", {

View File

@ -19,6 +19,8 @@ test_that("frequency table works", {
expect_output(print(freq(septic_patients$hospital_id))) expect_output(print(freq(septic_patients$hospital_id)))
# table # table
expect_output(print(freq(table(septic_patients$sex, septic_patients$age)))) expect_output(print(freq(table(septic_patients$sex, septic_patients$age))))
# rsi
expect_output(print(freq(septic_patients$amcl)))
library(dplyr) library(dplyr)
expect_output(septic_patients %>% select(1:2) %>% freq() %>% print()) expect_output(septic_patients %>% select(1:2) %>% freq() %>% print())