#' Set options for symmetric resampling
#'
#' @description
#' \code{SymmetricResamplingOptions} is an R6 class that defines parameters for
#' symmetric resampling analyses.
#' @importFrom checkmate asInt assertInt
#' @importFrom cli cli_abort cli_text col_grey
#' @importFrom glue glue
#' @importFrom R6 R6Class
SymmetricResamplingOptions <- R6Class("SymmetricResamplingOptions",
inherit = AbstractResamplingOptions,
private = list(
.probability = NULL
),
active = list(
#' @field probability An integer value indicating the change probability.
probability = function (value) {
if (missing(value)) {
return(private$.probability)
} else {
val_check <- check_int(value, lower = 0, upper = 99)
if (!isTRUE(val_check)) {
cli_abort(c("{.arg probability} must be an integer.",
"x" = val_check))
}
private$.probability <- asInt(value)
}
}
),
public = list(
#' @param replications An integer value indicating the number of resampling
#' replications to perform.
#' @param probability An integer value indicating the change probability.
#' @param cutoff An integer value indicating the cutoff value for
#' frequencies.
#' @param frequency_summary A character vector indicating which method(s) to
#' use to summarize supports. More than one option can be specified. The
#' options are:
#' \itemize{
#' \item \code{absolute}: absolute frequencies, default;
#' \item \code{difference}: frequency differences (i.e., group supported/contradicted);
#' \item \code{slope}: frequency slopes.
#' }
initialize = function (replications = 100, probability = 36, cutoff = 0,
frequency_summary = "absolute") {
a <- as.list(environment(), all = TRUE)
for (n in names(a)) {
self[[n]] <- a[[n]]
}
},
#' @param ... Ignored.
print = function (...) {
cli_text("{col_grey(\"# A TNT symmetric resampling configuration\")}")
options <- c(
"Replications:" = self$replications,
"Removal probability:" = self$probability,
"Cutoff frequency:" = self$cutoff,
"Frequency summary:" = paste(self$frequency_summary, collapse = ", ")
) %>%
data.frame()
names(options) <- NULL
print(options)
},
#' @param ... Ignored.
queue = function (...) {
queue <- CommandQueue$new()
choices <- c(gc = "difference", frequency = "absolute", slope = "slope")
freq_summ <- pmatch(self$frequency_summary, choices) %>%
na.omit() %>%
{names(choices)[.]} %>%
paste(collapse = " ")
if (!"difference" %in% self$frequency_summary) {
freq_summ <- glue("nogc {freq_summ}")
}
sym_args <- glue("sym from 0 replications {self$replications} probability {self$probability} cut {self$cutoff} {freq_summ} [")
sm_queue <- self$search_method$queue()
while(sm_queue$length() > 0) {
cmd <- sm_queue$read_next() %$%
paste(name, arguments, sep = " ", collapse = " ") %>%
glue(";")
sym_args <- c(sym_args, cmd)
}
sym_args <- c(sym_args, "]")
queue$add("resample", sym_args)
return(queue)
}
)
)
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.