R/sequenceCalc.R

setGeneric("sequenceCalc", function(x, organism, ...) standardGeneric("sequenceCalc"))

setMethod("sequenceCalc", c("GRanges", "BSgenome"),
    function(x, organism, pattern, fixed = TRUE, positions = FALSE)
{
    chrs <- levels(seqnames(x))
    names(chrs) <- chrs
    if (!all(chrs %in% seqnames(organism))) stop("Chromosome name mismatch bewteen x and organism")
    hits <- as(as(lapply(chrs, function(x) IRanges(start(matchPattern(pattern, organism[[x]], fixed=fixed)), width=1)), "IRangesList"), "GRanges")
    if (!positions) return(countOverlaps(x, hits))
    scores <- vector(mode='list', length=length(x))
    temp <- as.matrix(findOverlaps(x, hits))
    temp[,2] <- start(hits)[temp[,2]]-start(x)[temp[,1]]
    scores[unique(temp[,1])] <- split(temp[,2], temp[,1])
    scores
})

setMethod("sequenceCalc", c("data.frame", "BSgenome"),
    function(x, organism, window = NULL, positions = FALSE, ...)
{
    if(is.null(window))
        stop("Window size not given.")

    if (is.null(x$position)) x$position <- ifelse(x$strand == '+', x$start, x$end)
    x <- GRanges(x$chr, IRanges(x$position, width=1), seqlengths=seqlengths(organism)[unique(x$chr)])
    x <- resize(x, window, fix = "center")
    if(positions)
    {
        pos <- sequenceCalc(x, organism, positions = TRUE, ...)
        lapply(pos, function(y) if(!is.null(y)) return(y - window / 2))
    } else sequenceCalc(x, organism, ...)
})
markrobinsonuzh/Repitools documentation built on March 20, 2024, 6:04 a.m.