mirror of
https://github.com/msberends/AMR.git
synced 2025-01-26 05:44:35 +01:00
fixes
This commit is contained in:
parent
94e3ea5333
commit
729eff0a9d
18
.github/workflows/check.yaml
vendored
18
.github/workflows/check.yaml
vendored
@ -151,6 +151,24 @@ jobs:
|
|||||||
find . -name 'tinytest.Rout*' -exec cat '{}' \; || true
|
find . -name 'tinytest.Rout*' -exec cat '{}' \; || true
|
||||||
shell: bash
|
shell: bash
|
||||||
|
|
||||||
|
- name: Show dir
|
||||||
|
continue-on-error: true
|
||||||
|
if: always()
|
||||||
|
run: |
|
||||||
|
echo ${GITHUB_WORKSPACE}
|
||||||
|
echo "---"
|
||||||
|
ls ${GITHUB_WORKSPACE}
|
||||||
|
echo "---"
|
||||||
|
ls ../${GITHUB_WORKSPACE}
|
||||||
|
echo "---"
|
||||||
|
ls ../${GITHUB_WORKSPACE}/AMR
|
||||||
|
echo "---"
|
||||||
|
ls ../${GITHUB_WORKSPACE}/AMR.Rcheck
|
||||||
|
echo "---"
|
||||||
|
ls ${GITHUB_WORKSPACE}/AMR
|
||||||
|
echo "---"
|
||||||
|
ls ${GITHUB_WORKSPACE}/AMR.Rcheck
|
||||||
|
|
||||||
- name: Upload artifacts
|
- name: Upload artifacts
|
||||||
if: always()
|
if: always()
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
Package: AMR
|
Package: AMR
|
||||||
Version: 1.8.1.9062
|
Version: 1.8.1.9063
|
||||||
Date: 2022-09-23
|
Date: 2022-09-23
|
||||||
Title: Antimicrobial Resistance Data Analysis
|
Title: Antimicrobial Resistance Data Analysis
|
||||||
Description: Functions to simplify and standardise antimicrobial resistance (AMR)
|
Description: Functions to simplify and standardise antimicrobial resistance (AMR)
|
||||||
|
2
NEWS.md
2
NEWS.md
@ -1,4 +1,4 @@
|
|||||||
# AMR 1.8.1.9062
|
# AMR 1.8.1.9063
|
||||||
|
|
||||||
This version will eventually become v2.0! We're happy to reach a new major milestone soon!
|
This version will eventually become v2.0! We're happy to reach a new major milestone soon!
|
||||||
|
|
||||||
|
@ -563,11 +563,11 @@ ab_select_exec <- function(function_name,
|
|||||||
return(NULL)
|
return(NULL)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is.null(ab_class_args) || function_name %in% c("antifungals", "antimycobacterials")) {
|
if (is.null(ab_class_args) || isTRUE(function_name %in% c("antifungals", "antimycobacterials"))) {
|
||||||
ab_group <- NULL
|
ab_group <- NULL
|
||||||
if (function_name == "antifungals") {
|
if (isTRUE(function_name == "antifungals")) {
|
||||||
abx <- antibiotics$ab[which(antibiotics$group == "Antifungals")]
|
abx <- antibiotics$ab[which(antibiotics$group == "Antifungals")]
|
||||||
} else if (function_name == "antimycobacterials") {
|
} else if (isTRUE(function_name == "antimycobacterials")) {
|
||||||
abx <- antibiotics$ab[which(antibiotics$group == "Antimycobacterials")]
|
abx <- antibiotics$ab[which(antibiotics$group == "Antimycobacterials")]
|
||||||
} else {
|
} else {
|
||||||
# their upper case equivalent are vectors with class <ab>, created in data-raw/_pre_commit_hook.R
|
# their upper case equivalent are vectors with class <ab>, created in data-raw/_pre_commit_hook.R
|
||||||
|
9
R/mo.R
9
R/mo.R
@ -92,10 +92,7 @@
|
|||||||
#' - `"S. aureus - please mind: MRSA"`. The last word will be stripped, after which the function will try to find a match. If it does not, the second last word will be stripped, etc. Again, a warning will be thrown that the result *Staphylococcus aureus* (`B_STPHY_AURS`) needs review.
|
#' - `"S. aureus - please mind: MRSA"`. The last word will be stripped, after which the function will try to find a match. If it does not, the second last word will be stripped, etc. Again, a warning will be thrown that the result *Staphylococcus aureus* (`B_STPHY_AURS`) needs review.
|
||||||
#' - `"Fluoroquinolone-resistant Neisseria gonorrhoeae"`. The first word will be stripped, after which the function will try to find a match. A warning will be thrown that the result *Neisseria gonorrhoeae* (`B_NESSR_GNRR`) needs review.
|
#' - `"Fluoroquinolone-resistant Neisseria gonorrhoeae"`. The first word will be stripped, after which the function will try to find a match. A warning will be thrown that the result *Neisseria gonorrhoeae* (`B_NESSR_GNRR`) needs review.
|
||||||
#'
|
#'
|
||||||
#' There are three helper functions that can be run after using the [as.mo()] function:
|
#' Use [mo_uncertainties()] to get a [data.frame] that prints in a pretty format with all taxonomic names that were guessed. The output contains the matching score for all matches (see *Matching Score for Microorganisms* below).
|
||||||
#' - Use [mo_uncertainties()] to get a [data.frame] that prints in a pretty format with all taxonomic names that were guessed. The output contains the matching score for all matches (see *Matching Score for Microorganisms* below).
|
|
||||||
#' - Use [mo_failures()] to get a [character] [vector] with all values that could not be coerced to a valid value.
|
|
||||||
#' - Use [mo_renamed()] to get a [data.frame] with all values that could be coerced based on old, previously accepted taxonomic names.
|
|
||||||
#'
|
#'
|
||||||
#' ### Microbial Prevalence of Pathogens in Humans
|
#' ### Microbial Prevalence of Pathogens in Humans
|
||||||
#'
|
#'
|
||||||
@ -839,14 +836,14 @@ translate_allow_uncertain <- function(allow_uncertain) {
|
|||||||
allow_uncertain
|
allow_uncertain
|
||||||
}
|
}
|
||||||
|
|
||||||
get_mo_failures_uncertainties_renamed <- function() {
|
get_mo_uncertainties <- function() {
|
||||||
remember <- list(uncertainties = pkg_env$mo_uncertainties)
|
remember <- list(uncertainties = pkg_env$mo_uncertainties)
|
||||||
# empty them, otherwise e.g. mo_shortname("Chlamydophila psittaci") will give 3 notes
|
# empty them, otherwise e.g. mo_shortname("Chlamydophila psittaci") will give 3 notes
|
||||||
pkg_env$mo_uncertainties <- NULL
|
pkg_env$mo_uncertainties <- NULL
|
||||||
remember
|
remember
|
||||||
}
|
}
|
||||||
|
|
||||||
load_mo_failures_uncertainties_renamed <- function(metadata) {
|
load_mo_uncertainties <- function(metadata) {
|
||||||
pkg_env$mo_uncertainties <- metadata$uncertainties
|
pkg_env$mo_uncertainties <- metadata$uncertainties
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -201,7 +201,7 @@ mo_shortname <- function(x, language = get_AMR_locale(), keep_synonyms = getOpti
|
|||||||
|
|
||||||
x.mo <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
x.mo <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
||||||
|
|
||||||
metadata <- get_mo_failures_uncertainties_renamed()
|
metadata <- get_mo_uncertainties()
|
||||||
|
|
||||||
replace_empty <- function(x) {
|
replace_empty <- function(x) {
|
||||||
x[x == ""] <- "spp."
|
x[x == ""] <- "spp."
|
||||||
@ -223,7 +223,7 @@ mo_shortname <- function(x, language = get_AMR_locale(), keep_synonyms = getOpti
|
|||||||
shortnames[shortnames %like% "unknown"] <- paste0("(", trimws(gsub("[^a-zA-Z -]", "", shortnames[shortnames %like% "unknown"], perl = TRUE)), ")")
|
shortnames[shortnames %like% "unknown"] <- paste0("(", trimws(gsub("[^a-zA-Z -]", "", shortnames[shortnames %like% "unknown"], perl = TRUE)), ")")
|
||||||
|
|
||||||
shortnames[is.na(x.mo)] <- NA_character_
|
shortnames[is.na(x.mo)] <- NA_character_
|
||||||
load_mo_failures_uncertainties_renamed(metadata)
|
load_mo_uncertainties(metadata)
|
||||||
translate_into_language(shortnames, language = language, only_unknown = FALSE, only_affect_mo_names = TRUE)
|
translate_into_language(shortnames, language = language, only_unknown = FALSE, only_affect_mo_names = TRUE)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -374,7 +374,7 @@ mo_gramstain <- function(x, language = get_AMR_locale(), keep_synonyms = getOpti
|
|||||||
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
||||||
|
|
||||||
x.mo <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
x.mo <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
||||||
metadata <- get_mo_failures_uncertainties_renamed()
|
metadata <- get_mo_uncertainties()
|
||||||
|
|
||||||
x <- rep(NA_character_, length(x))
|
x <- rep(NA_character_, length(x))
|
||||||
# make all bacteria Gram negative
|
# make all bacteria Gram negative
|
||||||
@ -393,7 +393,7 @@ mo_gramstain <- function(x, language = get_AMR_locale(), keep_synonyms = getOpti
|
|||||||
# and of course our own ID for Gram-positives
|
# and of course our own ID for Gram-positives
|
||||||
| x.mo == "B_GRAMP"] <- "Gram-positive"
|
| x.mo == "B_GRAMP"] <- "Gram-positive"
|
||||||
|
|
||||||
load_mo_failures_uncertainties_renamed(metadata)
|
load_mo_uncertainties(metadata)
|
||||||
translate_into_language(x, language = language, only_unknown = FALSE)
|
translate_into_language(x, language = language, only_unknown = FALSE)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -409,9 +409,9 @@ mo_is_gram_negative <- function(x, language = get_AMR_locale(), keep_synonyms =
|
|||||||
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
||||||
|
|
||||||
x.mo <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
x.mo <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
||||||
metadata <- get_mo_failures_uncertainties_renamed()
|
metadata <- get_mo_uncertainties()
|
||||||
grams <- mo_gramstain(x.mo, language = NULL, keep_synonyms = keep_synonyms)
|
grams <- mo_gramstain(x.mo, language = NULL, keep_synonyms = keep_synonyms)
|
||||||
load_mo_failures_uncertainties_renamed(metadata)
|
load_mo_uncertainties(metadata)
|
||||||
out <- grams == "Gram-negative" & !is.na(grams)
|
out <- grams == "Gram-negative" & !is.na(grams)
|
||||||
out[x.mo %in% c(NA_character_, "UNKNOWN")] <- NA
|
out[x.mo %in% c(NA_character_, "UNKNOWN")] <- NA
|
||||||
out
|
out
|
||||||
@ -429,9 +429,9 @@ mo_is_gram_positive <- function(x, language = get_AMR_locale(), keep_synonyms =
|
|||||||
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
||||||
|
|
||||||
x.mo <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
x.mo <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
||||||
metadata <- get_mo_failures_uncertainties_renamed()
|
metadata <- get_mo_uncertainties()
|
||||||
grams <- mo_gramstain(x.mo, language = NULL, keep_synonyms = keep_synonyms)
|
grams <- mo_gramstain(x.mo, language = NULL, keep_synonyms = keep_synonyms)
|
||||||
load_mo_failures_uncertainties_renamed(metadata)
|
load_mo_uncertainties(metadata)
|
||||||
out <- grams == "Gram-positive" & !is.na(grams)
|
out <- grams == "Gram-positive" & !is.na(grams)
|
||||||
out[x.mo %in% c(NA_character_, "UNKNOWN")] <- NA
|
out[x.mo %in% c(NA_character_, "UNKNOWN")] <- NA
|
||||||
out
|
out
|
||||||
@ -449,12 +449,12 @@ mo_is_yeast <- function(x, language = get_AMR_locale(), keep_synonyms = getOptio
|
|||||||
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
||||||
|
|
||||||
x.mo <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
x.mo <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
||||||
metadata <- get_mo_failures_uncertainties_renamed()
|
metadata <- get_mo_uncertainties()
|
||||||
|
|
||||||
x.kingdom <- mo_kingdom(x.mo, language = NULL, keep_synonyms = keep_synonyms)
|
x.kingdom <- mo_kingdom(x.mo, language = NULL, keep_synonyms = keep_synonyms)
|
||||||
x.class <- mo_class(x.mo, language = NULL, keep_synonyms = keep_synonyms)
|
x.class <- mo_class(x.mo, language = NULL, keep_synonyms = keep_synonyms)
|
||||||
|
|
||||||
load_mo_failures_uncertainties_renamed(metadata)
|
load_mo_uncertainties(metadata)
|
||||||
|
|
||||||
out <- rep(FALSE, length(x))
|
out <- rep(FALSE, length(x))
|
||||||
out[x.kingdom == "Fungi" & x.class == "Saccharomycetes"] <- TRUE
|
out[x.kingdom == "Fungi" & x.class == "Saccharomycetes"] <- TRUE
|
||||||
@ -615,7 +615,7 @@ mo_taxonomy <- function(x, language = get_AMR_locale(), keep_synonyms = getOptio
|
|||||||
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
||||||
|
|
||||||
x <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
x <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
||||||
metadata <- get_mo_failures_uncertainties_renamed()
|
metadata <- get_mo_uncertainties()
|
||||||
|
|
||||||
out <- list(
|
out <- list(
|
||||||
kingdom = mo_kingdom(x, language = language, keep_synonyms = keep_synonyms),
|
kingdom = mo_kingdom(x, language = language, keep_synonyms = keep_synonyms),
|
||||||
@ -628,7 +628,7 @@ mo_taxonomy <- function(x, language = get_AMR_locale(), keep_synonyms = getOptio
|
|||||||
subspecies = mo_subspecies(x, language = language, keep_synonyms = keep_synonyms)
|
subspecies = mo_subspecies(x, language = language, keep_synonyms = keep_synonyms)
|
||||||
)
|
)
|
||||||
|
|
||||||
load_mo_failures_uncertainties_renamed(metadata)
|
load_mo_uncertainties(metadata)
|
||||||
out
|
out
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -644,7 +644,7 @@ mo_synonyms <- function(x, language = get_AMR_locale(), keep_synonyms = getOptio
|
|||||||
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
||||||
|
|
||||||
x.mo <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
x.mo <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
||||||
metadata <- get_mo_failures_uncertainties_renamed()
|
metadata <- get_mo_uncertainties()
|
||||||
|
|
||||||
syns <- lapply(x.mo, function(y) {
|
syns <- lapply(x.mo, function(y) {
|
||||||
gbif <- AMR::microorganisms$gbif[match(y, AMR::microorganisms$mo)]
|
gbif <- AMR::microorganisms$gbif[match(y, AMR::microorganisms$mo)]
|
||||||
@ -664,7 +664,7 @@ mo_synonyms <- function(x, language = get_AMR_locale(), keep_synonyms = getOptio
|
|||||||
result <- unlist(syns)
|
result <- unlist(syns)
|
||||||
}
|
}
|
||||||
|
|
||||||
load_mo_failures_uncertainties_renamed(metadata)
|
load_mo_uncertainties(metadata)
|
||||||
result
|
result
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -680,7 +680,7 @@ mo_info <- function(x, language = get_AMR_locale(), keep_synonyms = getOption("A
|
|||||||
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
||||||
|
|
||||||
x <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
x <- as.mo(x, language = language, keep_synonyms = keep_synonyms, ...)
|
||||||
metadata <- get_mo_failures_uncertainties_renamed()
|
metadata <- get_mo_uncertainties()
|
||||||
|
|
||||||
info <- lapply(x, function(y) {
|
info <- lapply(x, function(y) {
|
||||||
c(
|
c(
|
||||||
@ -701,7 +701,7 @@ mo_info <- function(x, language = get_AMR_locale(), keep_synonyms = getOption("A
|
|||||||
result <- info[[1L]]
|
result <- info[[1L]]
|
||||||
}
|
}
|
||||||
|
|
||||||
load_mo_failures_uncertainties_renamed(metadata)
|
load_mo_uncertainties(metadata)
|
||||||
result
|
result
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -718,7 +718,7 @@ mo_url <- function(x, open = FALSE, language = get_AMR_locale(), keep_synonyms =
|
|||||||
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
meet_criteria(keep_synonyms, allow_class = "logical", has_length = 1)
|
||||||
|
|
||||||
x.mo <- as.mo(x = x, language = language, keep_synonyms = keep_synonyms, ... = ...)
|
x.mo <- as.mo(x = x, language = language, keep_synonyms = keep_synonyms, ... = ...)
|
||||||
metadata <- get_mo_failures_uncertainties_renamed()
|
metadata <- get_mo_uncertainties()
|
||||||
|
|
||||||
x.rank <- AMR::microorganisms$rank[match(x.mo, AMR::microorganisms$mo)]
|
x.rank <- AMR::microorganisms$rank[match(x.mo, AMR::microorganisms$mo)]
|
||||||
x.name <- AMR::microorganisms$fullname[match(x.mo, AMR::microorganisms$mo)]
|
x.name <- AMR::microorganisms$fullname[match(x.mo, AMR::microorganisms$mo)]
|
||||||
@ -739,7 +739,7 @@ mo_url <- function(x, open = FALSE, language = get_AMR_locale(), keep_synonyms =
|
|||||||
utils::browseURL(u[1L])
|
utils::browseURL(u[1L])
|
||||||
}
|
}
|
||||||
|
|
||||||
load_mo_failures_uncertainties_renamed(metadata)
|
load_mo_uncertainties(metadata)
|
||||||
u
|
u
|
||||||
}
|
}
|
||||||
|
|
||||||
|
6
R/rsi.R
6
R/rsi.R
@ -757,7 +757,7 @@ as_rsi_method <- function(method_short,
|
|||||||
|
|
||||||
method <- method_short
|
method <- method_short
|
||||||
|
|
||||||
metadata_mo <- get_mo_failures_uncertainties_renamed()
|
metadata_mo <- get_mo_uncertainties()
|
||||||
|
|
||||||
x_bak <- data.frame(x_mo = paste0(x, mo), stringsAsFactors = FALSE)
|
x_bak <- data.frame(x_mo = paste0(x, mo), stringsAsFactors = FALSE)
|
||||||
df <- unique(data.frame(x, mo, x_mo = paste0(x, mo), stringsAsFactors = FALSE))
|
df <- unique(data.frame(x, mo, x_mo = paste0(x, mo), stringsAsFactors = FALSE))
|
||||||
@ -810,7 +810,7 @@ as_rsi_method <- function(method_short,
|
|||||||
|
|
||||||
if (nrow(trans) == 0) {
|
if (nrow(trans) == 0) {
|
||||||
message_(" OK.", add_fn = list(font_green, font_bold), as_note = FALSE)
|
message_(" OK.", add_fn = list(font_green, font_bold), as_note = FALSE)
|
||||||
load_mo_failures_uncertainties_renamed(metadata_mo)
|
load_mo_uncertainties(metadata_mo)
|
||||||
return(set_clean_class(factor(new_rsi, levels = c("S", "I", "R"), ordered = TRUE),
|
return(set_clean_class(factor(new_rsi, levels = c("S", "I", "R"), ordered = TRUE),
|
||||||
new_class = c("rsi", "ordered", "factor")
|
new_class = c("rsi", "ordered", "factor")
|
||||||
))
|
))
|
||||||
@ -947,7 +947,7 @@ as_rsi_method <- function(method_short,
|
|||||||
message_(" OK.", add_fn = list(font_green, font_bold), as_note = FALSE)
|
message_(" OK.", add_fn = list(font_green, font_bold), as_note = FALSE)
|
||||||
}
|
}
|
||||||
|
|
||||||
load_mo_failures_uncertainties_renamed(metadata_mo)
|
load_mo_uncertainties(metadata_mo)
|
||||||
|
|
||||||
set_clean_class(factor(new_rsi, levels = c("S", "I", "R"), ordered = TRUE),
|
set_clean_class(factor(new_rsi, levels = c("S", "I", "R"), ordered = TRUE),
|
||||||
new_class = c("rsi", "ordered", "factor")
|
new_class = c("rsi", "ordered", "factor")
|
||||||
|
@ -115,12 +115,7 @@ With the default setting (\code{allow_uncertain = TRUE}, level 2), below example
|
|||||||
\item \code{"Fluoroquinolone-resistant Neisseria gonorrhoeae"}. The first word will be stripped, after which the function will try to find a match. A warning will be thrown that the result \emph{Neisseria gonorrhoeae} (\code{B_NESSR_GNRR}) needs review.
|
\item \code{"Fluoroquinolone-resistant Neisseria gonorrhoeae"}. The first word will be stripped, after which the function will try to find a match. A warning will be thrown that the result \emph{Neisseria gonorrhoeae} (\code{B_NESSR_GNRR}) needs review.
|
||||||
}
|
}
|
||||||
|
|
||||||
There are three helper functions that can be run after using the \code{\link[=as.mo]{as.mo()}} function:
|
Use \code{\link[=mo_uncertainties]{mo_uncertainties()}} to get a \link{data.frame} that prints in a pretty format with all taxonomic names that were guessed. The output contains the matching score for all matches (see \emph{Matching Score for Microorganisms} below).
|
||||||
\itemize{
|
|
||||||
\item Use \code{\link[=mo_uncertainties]{mo_uncertainties()}} to get a \link{data.frame} that prints in a pretty format with all taxonomic names that were guessed. The output contains the matching score for all matches (see \emph{Matching Score for Microorganisms} below).
|
|
||||||
\item Use \code{\link[=mo_failures]{mo_failures()}} to get a \link{character} \link{vector} with all values that could not be coerced to a valid value.
|
|
||||||
\item Use \code{\link[=mo_renamed]{mo_renamed()}} to get a \link{data.frame} with all values that could be coerced based on old, previously accepted taxonomic names.
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
\subsection{Microbial Prevalence of Pathogens in Humans}{
|
\subsection{Microbial Prevalence of Pathogens in Humans}{
|
||||||
|
Loading…
Reference in New Issue
Block a user