R/bpiterate-methods.R

Defines functions .bpiterate_impl bpiterateAlong

Documented in bpiterateAlong .bpiterate_impl

bpiterateAlong <-
    function(X)
{
    n <- length(X)
    i <- 0L
    function() {
        if (i >= n)
            NULL
        else {
            i <<- i + 1L
            X[[i]]
        }
    }
}

### =========================================================================
### bpiterate methods
### -------------------------------------------------------------------------

## All params have dedicated bpiterate() methods.

setMethod("bpiterate", c("ANY", "ANY", "missing"),
    function(ITER, FUN, ..., BPREDO=list(),
             BPPARAM=bpparam(), BPOPTIONS=bpoptions())
{
    ITER <- tryCatch({
        match.fun(ITER)
    }, error = function(e) {
        bpiterateAlong(ITER)
    })
    FUN <- match.fun(FUN)
    bpiterate(ITER, FUN, ..., BPREDO = BPREDO,
              BPPARAM=BPPARAM, BPOPTIONS = BPOPTIONS)
})

## TODO: support BPREDO
.bpiterate_impl <-
    function(ITER, FUN, ..., REDUCE, init, reduce.in.order = FALSE,
             BPREDO = list(), BPPARAM = bpparam(), BPOPTIONS=bpoptions())
{
    ## Required API
    ##
    ## - BiocParallelParam()
    ## - bpschedule(), bpisup(), bpstart(), bpstop()
    ## - .sendto, .recvfrom, .recv, .close
    ITER <- tryCatch({
        match.fun(ITER)
    }, error = function(e) {
        bpiterateAlong(ITER)
    })
    FUN <- match.fun(FUN)

    if (missing(REDUCE)) {
        if (!missing(init))
            stop("REDUCE must be provided when 'init' is given")
    }

    ARGS <- list(...)

    manager <- structure(list(), class="iterate") # dispatch
    .bpinit(
        manager = manager,
        ITER = ITER,
        FUN = FUN,
        ARGS = ARGS,
        BPPARAM = BPPARAM,
        BPOPTIONS = BPOPTIONS,
        BPREDO = BPREDO,
        init = init,
        REDUCE = REDUCE,
        reduce.in.order = reduce.in.order
    )
}
Bioconductor/BiocParallel documentation built on March 7, 2024, 5:35 a.m.