R/treeMean.R

Defines functions treeMean

Documented in treeMean

treeMean <- function(rwl, ids, na.rm=FALSE) {
    rwl2 <- as.matrix(rwl)
    if (!is.data.frame(ids) || !("tree" %in% names(ids))) {
        stop("'ids' must be a data.frame with column 'tree'")
    }
    colnames.rwl <- colnames(rwl2)
    trees <- as.matrix(ids["tree"])
    rownames.ids <- rownames(trees)
    ## If all column names in 'rwl' are present in the set of row
    ## names in 'ids', arrange 'ids' to matching order
    if (!is.null(rownames.ids) && !is.null(colnames.rwl) &&
        anyDuplicated(colnames.rwl) == 0 &&
        all(colnames.rwl %in% rownames.ids)) {
        trees <- trees[colnames.rwl, ]
    } else if (length(trees) == ncol(rwl2)) {
        trees <- as.vector(trees)
    } else {
        stop("dimension problem: ", "'ncol(rwl)' != 'nrow(ids)'")
    }
    uTrees <- unique(trees)
    if (any(is.na(uTrees))) {
        stop("missing tree IDs are not allowed")
    }
    matches <- match(trees, uTrees)
    res <- matrix(NA_real_, nrow=nrow(rwl2), ncol=length(uTrees))
    for (i in seq_along(uTrees)) {
      res[,i] <- rowMeans(rwl2[, matches == i, drop=FALSE], na.rm=na.rm)
    }
    res[is.nan(res)] <- NA_real_
    res <- as.data.frame(res, row.names = rownames(rwl2))
    names(res) <- uTrees
    class(res) <- c("rwl", "data.frame")
    res
}
AndyBunn/dplR documentation built on April 20, 2024, 10:33 p.m.