R/SplatPopParams-methods.R

Defines functions newSplatPopParams

Documented in newSplatPopParams

#' @rdname newParams
#' @importFrom methods new
#' @export
newSplatPopParams <- function(...) {
    checkDependencies("splatPop")

    params <- new("SplatPopParams")
    params <- setParams(params, ...)

    return(params)
}


#' @importFrom checkmate checkInt checkIntegerish checkNumber checkNumeric
#' checkFlag
setValidity("SplatPopParams", function(object) {
    object <- expandParams(object)
    v <- getParams(object, c(slotNames(object)))

    nConditions <- v$nConditions

    checks <- c(
        eqtl.n = checkNumber(v$eqtl.n, lower = 0),
        eqtl.dist = checkInt(v$eqtl.dist, lower = 1),
        eqtl.maf.min = checkNumber(
            v$eqtl.maf.min,
            lower = 0, upper = 0.5
        ),
        eqtl.maf.max = checkNumber(
            v$eqtl.maf.max,
            lower = 0, upper = 1
        ),
        eqtl.coreg = checkNumber(v$eqtl.coreg, lower = 0, upper = 1),
        eqtl.ES.shape = checkNumber(v$eqtl.ES.shape, lower = 0),
        eqtl.ES.rate = checkNumber(v$eqtl.ES.rate, lower = 0),
        eqtl.group.specific = checkNumber(
            v$eqtl.group.specific,
            lower = 0, upper = 1
        ),
        eqtl.condition.specific = checkNumber(
            v$eqtl.condition.specific,
            lower = 0, upper = 1
        ),
        pop.mean.shape = checkNumber(v$pop.mean.shape, lower = 0),
        pop.mean.rate = checkNumber(v$pop.mean.rate, lower = 0),
        pop.quant.norm = checkFlag(v$pop.quant.norm),
        pop.cv.bins = checkInt(v$pop.cv.bins, lower = 1),
        pop.cv.param = checkDataFrame(v$pop.cv.param),
        similarity.scale = checkNumber(v$similarity.scale, lower = 0),
        batch.size = checkInt(v$batch.size, lower = 1),
        nCells.sample = checkFlag(v$nCells.sample),
        nCells.shape = checkNumber(v$nCells.shape, lower = 0),
        nCells.rate = checkNumber(v$nCells.rate, lower = 0),
        nConditions = checkInt(v$nConditions, lower = 1),
        condition.prob = checkNumeric(
            v$condition.prob,
            lower = 0, upper = 1, len = nConditions
        ),
        cde.prob = checkNumeric(
            v$cde.prob,
            lower = 0, upper = 1, len = nConditions
        ),
        cde.downProb = checkNumeric(
            v$cde.downProb,
            lower = 0, upper = 1, len = nConditions
        ),
        cde.facLoc = checkNumeric(v$cde.facLoc, len = nConditions),
        cde.facScale = checkNumeric(
            v$cde.facScale,
            lower = 0, len = nConditions
        )
    )

    # Check condition.prob sums to 1
    if (sum(round(v$condition.prob, 5)) != 1) {
        checks <- c(checks, "condition.probs must sum to 1")
    }

    if (all(checks == TRUE)) {
        valid <- TRUE
    } else {
        valid <- checks[checks != TRUE]
        valid <- paste(names(valid), valid, sep = ": ")
    }

    return(valid)
})


#' @rdname setParam
setMethod("setParam", "SplatPopParams", function(object, name, value) {
    checkmate::assertString(name)

    # splatPopParam checks
    if (name == "pop.cv.param") {
        if (getParam(object, "pop.cv.bins") != nrow(value)) {
            stop("Need to set pop.cv.bins to length of pop.cv.param")
        }
    }

    if (name == "eqtl.maf.min") {
        if (getParam(object, "eqtl.maf.min") >= getParam(object, "eqtl.maf.max")) {
            stop("Range of acceptable Minor Allele Frequencies is too small...
                 Be sure eqtl.maf.min < eqtl.maf.max.")
        }
    }

    if (name == "nConditions") {
        stop(name, " cannot be set directly, set condition.prob instead")
    }

    if (name == "condition.prob") {
        object <- setParamUnchecked(object, "nConditions", length(value))
    }

    object <- callNextMethod()

    return(object)
})


#' @importFrom methods callNextMethod
setMethod("show", "SplatPopParams", function(object) {
    pp <- list(
        "Population params:" = c(
            "(mean.shape)" = "pop.mean.shape",
            "(mean.rate)" = "pop.mean.rate",
            "[pop.quant.norm]" = "pop.quant.norm",
            "[similarity.scale]" = "similarity.scale",
            "[batch.size]" = "batch.size",
            "[nCells.sample]" = "nCells.sample",
            "[nCells.shape]" = "nCells.shape",
            "[nCells.rate]" = "nCells.rate",
            "[cv.bins]" = "pop.cv.bins",
            "(cv.params)" = "pop.cv.param"
        ),
        "eQTL params:" = c(
            "[eqtl.n]" = "eqtl.n",
            "[eqtl.dist]" = "eqtl.dist",
            "[eqtl.maf.min]" = "eqtl.maf.min",
            "[eqtl.maf.max]" = "eqtl.maf.max",
            "[eqtl.coreg]" = "eqtl.coreg",
            "[eqtl.group.specific]" =
                "eqtl.group.specific",
            "[eqtl.condition.specific]" =
                "eqtl.condition.specific",
            "(eqtl.ES.shape)" = "eqtl.ES.shape",
            "(eqtl.ES.rate)" = "eqtl.ES.rate"
        ),
        "Condition params:" = c(
            "[nConditions]" = "nConditions",
            "[condition.prob]" = "condition.prob",
            "[cde.prob]" = "cde.prob",
            "[cde.downProb]" = "cde.downProb",
            "[cde.facLoc]" = "cde.facLoc",
            "[cde.facScale]" = "cde.facScale"
        )
    )

    callNextMethod()
    showPP(object, pp)
})


#' @rdname expandParams
setMethod("expandParams", "SplatPopParams", function(object) {
    n <- getParam(object, "nConditions")

    vectors <- c("cde.prob", "cde.downProb", "cde.facLoc", "cde.facScale")

    object <- paramsExpander(object, vectors, n)

    callNextMethod(object)
})
Oshlack/splatter documentation built on April 27, 2024, 8:20 p.m.