#' check_bootstrap_args
#'
#' Check the input arguments of the
#' \link[EWCE]{bootstrap_enrichment_test}.
#'
#' @inheritParams bootstrap_enrichment_test
#' @return Null output.
#'
#' @keywords internal
check_bootstrap_args <- function(sct_data,
hits,
annotLevel,
reps,
controlledCT = NULL,
fix_celltypes = TRUE) {
#### Check an SCT dataset was provided ####
if (unique(is.null(sct_data)) ||
(!is_celltypedataset(ctd = sct_data))) {
stop("Must provide valid CellTypeDataset to sct_data.")
}
#### Check an hits was provided ####
if ((!exists("hits")) || unique(is.null(hits))) {
stop("Must provide a gene list to hits.")
}
#### Check an hits was provided ####
if ((!exists("annotLevel")) ||
(annotLevel < 1) ||
(annotLevel > length(sct_data))) {
stop("Must provide a valid annotLevel <= ", length(sct_data), ".")
}
if ((!exists("reps")) ||
(reps < 1)) {
stop("Must provide a valid reps > 0 .")
}
#### Check if controlling for another celltype ###
if (!is.null(controlledCT)) {
ct_names <- colnames(sct_data[[annotLevel]]$specificity)
if(fix_celltypes){
ct_names <- fix_celltype_names(ct_names)
}
if (!controlledCT %in% ct_names) {
err_msg <- paste0(
"invalid celltype name passed in controlledCT.",
" This argument is optional. Leave empty if you do not",
" wish to control for a celltypes expression."
)
stop(err_msg)
}
}
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.