R/assay-methods.R

#' @describeIn ExperimentList Obtain the specified assay with a \code{numeric}
#' or \code{character} reference
setMethod("assay", c("ANY", "missing"),
    function(x, i, withDimnames = TRUE, ...) {
        if (is(x, "ExpressionSet"))
            return(Biobase::exprs(x))
        return(x)
    }
)

setReplaceMethod("assay", c("ANY", "ANY"),
    function(x, withDimnames=TRUE, ..., value)
{
    if (!BiocBaseUtils::isTRUEorFALSE(withDimnames))
        stop(wmsg("'withDimnames' must be TRUE or FALSE"))
    if (withDimnames && !identical(dimnames(value), dimnames(x)))
        stop(
            "The rownames and colnames of 'value' are not identical to 'x', ",
            "use 'withDimnames=FALSE' "
        )
    tryCatch({
        BiocBaseUtils::setSlots(x, assays=value, check=FALSE)
    }, error = function(e) {
        value
    })
})


setReplaceMethod("assay", c("matrix", "ANY"),
    function(x, withDimnames = TRUE, ..., value)
{
    if (!BiocBaseUtils::isTRUEorFALSE(withDimnames))
        stop(wmsg("'withDimnames' must be TRUE or FALSE"))
    if (withDimnames && !identical(dimnames(value), dimnames(x)))
        stop(
            "The rownames and colnames of 'value' are not identical to 'x', ",
            "use 'withDimnames=FALSE' "
        )
    value
})

setReplaceMethod("assays", c("ExperimentList", "ANY"),
    function(x, withDimnames=TRUE, ..., value) {
        mendoapply(function(x, y, ...) {
            `assay<-`(x, withDimnames = withDimnames, ..., value = y)
        }, x = x, y = value, ...)
    }
)


#' @describeIn ExperimentList Get the assay data from each element in the
#' \link{ExperimentList}
#' @param withDimnames logical (default TRUE) whether to return dimension names
#' @aliases assay,ExperimentList,missing-method
setMethod("assays", "ExperimentList", function(x, withDimnames = TRUE, ...) {
    as(
        lapply(X = .setNames(nm = names(x)),
            FUN = function(i, y) {
                y <- y[[i]]
                if (is(y, "SummarizedExperiment") && length(assays(y)) > 1L)
                    warning("Dropping internal assays in '", i,
                        "'; taking first one", call. = FALSE)
                assay(y, withDimnames = withDimnames, ...)
            }, y = x
        ), "SimpleList"
    )
})

#' @rdname ExperimentList-class
#' @param i A scalar \code{character} or \code{integer} index
setMethod("assay", c("ExperimentList", "missing"),
    function(x, i, withDimnames = TRUE, ...) {
        if (!length(x))
            stop("'assay(<", class(x), ">, i=\"missing\", ...) ",
                 "length(<", class(x), ">) is 0'")
        assay(x[[1L]], ...)
    }
)

#' @rdname ExperimentList-class
setMethod("assay", c("ExperimentList", "numeric"),
    function(x, i, withDimnames = TRUE, ...) {
        tryCatch({
            assay(x[[i]], ...)
        }, error = function(err) {
            stop("'assay(<", class(x), ">, i=\"numeric\", ...)' ",
                 "invalid subscript 'i'\n", conditionMessage(err))
        })
    }
)

#' @rdname ExperimentList-class
setMethod("assay", c("ExperimentList", "character"),
    function(x, i, withDimnames = TRUE, ...) {
        msg <- paste0("'assay(<", class(x), ">, i=\"character\", ...)' ",
                      "invalid subscript 'i'")
        res <- tryCatch({
            assay(x[[i]], ...)
        }, error = function(err) {
            stop(msg, "\n", conditionMessage(err))
        })
        if (is.null(res))
            stop(msg, "\n'i' not in names(<", class(x), ">)")
        res
    }
)

#' @describeIn MultiAssayExperiment Obtain a \code{\link{SimpleList}} of assay
#' data for all available experiments in the object
#' @param withDimnames logical (default TRUE) whether to return dimension names
#' included in the object
#' @exportMethod assays
setMethod("assays", "MultiAssayExperiment",
    function(x, withDimnames = TRUE, ...) {
        assays(experiments(x), withDimnames = withDimnames, ...)
    }
)

#' @describeIn MultiAssayExperiment Convenience function for extracting the
#' assay of the first element (default) in the \code{ExperimentList}. A
#' \code{numeric} or \code{character} index can also be provided
#' @exportMethod assay
setMethod("assay", c("MultiAssayExperiment", "missing"),
    function(x, i, withDimnames = TRUE, ...) {
        assay(experiments(x), withDimnames = withDimnames, ...)
    }
)

#' @rdname MultiAssayExperiment-class
#' @param i An integer or character scalar indicating the assay to return
setMethod("assay", c("MultiAssayExperiment", "numeric"),
    function(x, i, withDimnames = TRUE, ...) {
        assay(experiments(x), i = i, withDimnames = withDimnames, ...)
    }
)

#' @rdname MultiAssayExperiment-class
setMethod("assay", c("MultiAssayExperiment", "character"),
    function(x, i, withDimnames = TRUE, ...) {
        assay(experiments(x), i = i, ...)
    }
)
waldronlab/MultiAssayExperiment documentation built on Feb. 7, 2024, 12:24 p.m.