R/constructDens.R

Defines functions constructDens

Documented in constructDens

#' Construct the cumulative density
#'
#' @param densList.ii the estimated density parameters
#' @param exprmt.design experiment configuration
#' @param DE.ind.ii a boolean, is the gene to be DE?
#' @param returnDens A boolean, should densities rather than cumulative 
#' densities be returned?
#'
#' @return The cumulative density
constructDens = function(densList.ii, exprmt.design, DE.ind.ii, 
                         returnDens = FALSE){
    lapply(seq_along(exprmt.design$sub.batchs), function(i){
      batch = exprmt.design$sub.batchs[[i]]
      dl = if(DE.ind.ii){
        densList.ii[[batch]][[exprmt.design$sub.group[[i]]]]
      } else {
        densList.ii[[batch]]
      }
      Coef = dl$coef
      if(is.null(Coef)){
        gy = dl$g0*dl$n
      } else {
        s.mat <- buildXmat(dl$mids, nc = length(Coef))
        gy = dl$g0*dl$n*exp(s.mat %*% Coef)
        id = is.infinite(gy)
        if(any(id)){
          gy[id] = max(gy[!id])
        }
      }
      if(returnDens){
        return(list(gy = c(gy), breaks = dl$breaks, mids = dl$mids))
      } else{
        Gy = cumsum(gy)/sum(gy) 
        return(list(Gy = Gy, breaks = dl$breaks))
      }
    })
  }

Try the SPsimSeq package in your browser

Any scripts or data that you put into this service are public.

SPsimSeq documentation built on Nov. 8, 2020, 5:09 p.m.