R/computeRDAR2.R

Defines functions computeRDAR2

Documented in computeRDAR2

#' Compute signification of RDA test
#' 
#' Compare R2 obtained in our region of interest with the global R^2 and the R^2 of regions with 
#' the same number of probes.
#' @param fullMat Matrix with the whole genome expression or methylation values
#' @param varsmodel Matrix with the model
#' @param covarsmodel Matrix with the covariables model
#' @param featNum Numeric with the number of features of the RDA model
#' @param R2 Numeric with the R2 of the RDA model
#' @param num_permutations Numeric with the number of permutations.
#' @return Numeric vector with the probability of finding a region with the same number of probes
#' with a bigger R2 and the global R2.
computeRDAR2 <- function(fullMat, varsmodel, covarsmodel = NULL, featNum, R2, 
                         num_permutations = 1e5-1){

  allvar <- matrixStats::rowVars(fullMat)

   ## If there are covariables, substract their effect prior to adjusting 
  if (!is.null(covarsmodel)){
    covfit <- limma::fitted.MArrayLM(limma::lmFit(fullMat, covarsmodel))
    fullMat <- fullMat - covfit
  }
  fit <- limma::fitted.MArrayLM(limma::lmFit(fullMat, varsmodel))
  varfit <- matrixStats::rowVars(fit)
  inds <- sample(1:(nrow(fullMat) - featNum), num_permutations, replace = TRUE)
  
  ## Compute the R2 explained by groups with the same number of features than the region of interest
  randomR2 <- vapply(inds, function(x) { 
      R2 <- sum(varfit[x:(x + featNum - 1)])/sum(allvar[x:(x + featNum - 1)])
      }, numeric(1))
  randomR2 <- c(randomR2, R2)
  pval <- sum(randomR2 >= R2)/(num_permutations + 1)

  globalR2 <- sum(varfit)/sum(allvar)
  c(globalpval = pval, globalR2 = globalR2)
}

Try the MEAL package in your browser

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

MEAL documentation built on Feb. 3, 2021, 2 a.m.