R/utils_reorder.R

Defines functions .reindex_pairings .restore_original_order

.restore_original_order <- function(batch.ordering, ncells.per.batch) 
# Generates a permutation vector to recover the old order of cells
# (assuming that within-batch order is preserved).
{ 
    nbatches <- length(batch.ordering)
    if (nbatches!=length(ncells.per.batch)) {
        stop("length of batch information vectors are not equal")
    }
    if (nbatches==0L) {
        return(integer(0))
    }

    reorder <- vector("list", nbatches)
    last <- 0L
    for (idx in batch.ordering) {
        ncells <- ncells.per.batch[idx]
        reorder[[idx]] <- last + seq_len(ncells)
        last <- last + ncells
    }
    unlist(reorder)
}

.reindex_pairings <- function(pairings, new.order) 
# Restores the MNN pairing indices to the original positions,
# i.e., after cells have been reordered by 'new.order'.
{
    rev.order <- integer(length(new.order))
    rev.order[new.order] <- seq_along(new.order)
    for (x in seq_along(pairings)) {
        current <- pairings[[x]]
        current$left <- rev.order[current$left]
        current$right <- rev.order[current$right]
        pairings[[x]] <- current
    }
    pairings
}
LTLA/batchelor documentation built on July 10, 2024, 9:09 p.m.