R/Params-methods.R

## the initialize() method to replace the prototype
## so that set.seed() works as expected
## see https://github.com/Oshlack/splatter/issues/132
setMethod("initialize", "Params", function(.Object, ...) {
    .Object@nGenes <- 10000
    .Object@nCells <- 100
    .Object@seed <- sample(seq_len(1e6), 1)
    .Object
})

#' @rdname getParam
#' @importFrom methods slot
setMethod("getParam", "Params", function(object, name) {
    slot(object, name)
})

#' @rdname setParam
#' @importFrom methods slot<- validObject
setMethod("setParam", "Params", function(object, name, value) {
    checkmate::assertString(name)
    slot(object, name) <- value
    validObject(object)
    return(object)
})

#' @rdname setParamUnchecked
#' @importFrom methods slot<-
setMethod("setParamUnchecked", "Params", function(object, name, value) {
    checkmate::assertString(name)
    slot(object, name) <- value
    return(object)
})

#' @rdname setParams
setMethod("setParams", "Params", function(object, update = NULL, ...) {
    checkmate::assertClass(object, classes = "Params")
    checkmate::assertList(update, null.ok = TRUE)

    update <- c(update, list(...))

    if (length(update) > 0) {
        for (name in names(update)) {
            value <- update[[name]]
            object <- setParam(object, name, value)
        }
    }

    return(object)
})

#' @importFrom methods slotNames
setMethod("show", "Params", function(object) {
    pp <- list("Global:" = c(
        "(Genes)" = "nGenes",
        "(Cells)" = "nCells",
        "[Seed]" = "seed"
    ))

    cat(
        "A", crayon::bold("Params"), "object of class",
        crayon::bold(class(object)), "\n"
    )
    cat(
        "Parameters can be (estimable) or",
        paste0(crayon::blue("[not estimable]"), ","),
        "'Default' or ", crayon::bold(crayon::green("'NOT DEFAULT'")), "\n"
    )
    cat(
        crayon::bgYellow(crayon::black("Secondary")), "parameters are usually",
        "set during simulation\n\n"
    )
    showPP(object, pp)
    cat(length(slotNames(object)) - 3, "additional parameters", "\n\n")
})

#' @rdname expandParams
setMethod("expandParams", "Params", function(object, vectors, n) {
    object <- paramsExpander(object, vectors, n)

    return(object)
})
Oshlack/splatter documentation built on April 1, 2024, 9:37 a.m.