R/SVD.R

Defines functions .svd

.svd <- function(dmat, k, ...){
    stopifnot("DelayedMatrix" %in% is(dmat))
    if(options()$delayedtensor.sparse){
        if(k >= min(dim(dmat))){
            stop("Please specify the smaller lower dimension k")
        }else{
            smat <- as(dmat, "sparseMatrix")
            out <- suppressWarnings(irlba(A=smat, nv=k))
        }
    }else{
        if(k >= 0.5 * min(dim(dmat))){
            out <- suppressWarnings(runExactSVD(dmat, k, ...))
        }else{
            out <- suppressWarnings(runIrlbaSVD(dmat, k, ...))
        }
    }
    out
}
rikenbit/DelayedTensor documentation built on Jan. 30, 2023, 6:15 p.m.