R/subset.lineupdist.R

Defines functions `[.lineupdist` subset.lineupdist

Documented in subset.lineupdist

## subset.lineupdist.R
## Karl W Broman

#' Subsetting distance matrix
#'
#' Pull out a specified set of rows and columns from a distance matrix
#' calculated by [distee()] or [disteg()].
#'
#'
#' @aliases subset.lineupdist [.lineupdist
#' @param x A distance matrix object as obtained from [distee()] or
#' [disteg()].
#' @param rows Optional vector of selected rows.
#' @param cols Optional vector of selected columns.
#' @param \dots Ignored at this point.
#' @return The input distance matrix object, but with only the specified subset
#' of the data.
#' @author Karl W Broman, \email{broman@@wisc.edu}
#' @seealso [disteg()], [distee()], [pulldiag()]
#' @keywords manip
#'
#' @examples
#' data(expr1, expr2)
#' \dontshow{expr1 <- expr1[,1:100]; expr2 <- expr2[,1:100]}
#'
#' # find samples in common
#' id <- findCommonID(expr1, expr2)
#'
#' # calculate correlations between cols of x and cols of y
#' thecor <- corbetw2mat(expr1[id$first,], expr2[id$second,])
#'
#' expr1s <- expr1[,thecor > 0.8]/1000
#' expr2s <- expr2[,thecor > 0.8]/1000
#'
#' # calculate correlations among samples
#' d <- distee(expr1s, expr2s, d.method="cor")
#'
#' # pull out distances for samples 24, 92, 44, 66
#' samp <- c("24", "92", "44", "66")
#' d[samp, samp]
#'
#' @export
#' @rdname subset.lineupdist
subset.lineupdist <-
    function(x, rows=NULL, cols=NULL, ...)
{
    if(is.null(cols) && !is.null(rows) && length(rows)==prod(dim(x)))
        return(unclass(x)[rows])

    xnew <- unclass(x)
    if(!is.null(rows)) xnew <- xnew[rows,,drop=FALSE]
    if(!is.null(cols)) xnew <- xnew[,cols,drop=FALSE]

    class(xnew) <- class(x)

    possible.attributes <- c("d.method", "labels", "compareWithin", "orig.selfd",
                             "badind", "obsg", "infg", "y", "denom", "linkwts", "genonames")
    for(i in possible.attributes[possible.attributes %in% names(attributes(x))])
        attr(xnew, i) <- attr(x, i)

    xnew
}

#' @name [.lineupdist
#' @rdname subset.lineupdist
#' @export
`[.lineupdist` <-
    function(x, rows=NULL, cols=NULL)
    subset(x, rows, cols)

Try the lineup package in your browser

Any scripts or data that you put into this service are public.

lineup documentation built on July 10, 2022, 5:05 p.m.