relabel_class = function (class, ref, full_set = union(class, ref), return_map = TRUE) {
if(!requireNamespace("clue")) {
stop_wrap("Package 'clue' should be installed.")
}
md = mode(class)
class = as.character(class)
ref = as.character(ref)
full_set = as.character(full_set)
all_class = union(class, ref)
n = length(all_class)
m = matrix(0, nrow = n, ncol = n, dimnames = list(all_class, all_class))
tb = table(class, ref)
m[rownames(tb), colnames(tb)] = tb
imap = clue::solve_LSAP(m, maximum = TRUE)
map = structure(rownames(m)[imap], names = rownames(m))
map = map[unique(class)]
unmapped = setdiff(setdiff(full_set, class), names(map))
if (length(unmapped)) {
map = c(map, structure(unmapped, names = unmapped))
}
df = data.frame(class = class, adjusted = map[class], ref = ref,
stringsAsFactors = FALSE)
attr(map, "df") = df
if (return_map) {
return(map)
}
else {
return(as(df$adjusted, md))
}
}
stop_wrap = function (...) {
x = paste0(...)
x = paste(strwrap(x), collapse = "\n")
stop(x, call. = FALSE)
}
message_wrap = function (...) {
x = paste0(...)
x = paste(strwrap(x), collapse = "\n")
message(x)
}
#' @importFrom utils flush.console install.packages packageDescription
check_pkg = function(pkg, bioc = FALSE) {
if(requireNamespace(pkg, quietly = TRUE)) {
return(NULL)
} else {
if(!interactive()) {
if(bioc) {
stop_wrap(qq("You need to manually install package '@{pkg}' from Bioconductor."))
} else {
stop_wrap(qq("You need to manually install package '@{pkg}' from CRAN."))
}
}
if(bioc) {
answer = readline(qq("Package '@{pkg}' is required but not installed. Do you want to install it from Bioconductor? [y|n] "))
} else {
answer = readline(qq("Package '@{pkg}' is required but not installed. Do you want to install it from CRAN? [y|n] "))
}
if(bioc) {
if(tolower(answer) %in% c("y", "yes")) {
if(!requireNamespace("BiocManager", quietly = TRUE)) {
install.packages("BiocManager")
}
BiocManager::install(pkg)
} else {
stop_wrap(qq("You need to manually install package '@{pkg}' from Bioconductor."))
}
} else {
if(tolower(answer) %in% c("y", "yes")) {
install.packages(pkg)
} else {
stop_wrap(qq("You need to manually install package '@{pkg}' from CRAN."))
}
}
}
}
is_GO_id = function(x) {
grepl("^GO:[0-9]+$", x)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.