#' This function are PSI calculater
#'
#' @rdname PSICalculater
#' @name PSICalculater
#' @title PSICalculater
#'
#' @param object an ICASDataSet
#' @param MMJF minimum minor-junction fraction of multiple-alternative-splice site (same start/end junction > 2)
#' @param MinSumSpliceSite The minimum number of reads of each SameStart or SameEnd for PSI Calculating
#' @export
#' @author Tang Chao
PSICalculater <- function(object, MMJF = 0.01, MinSumSpliceSite = 10) {
if(!is(object, "ICASDataSet"))
stop("The object must be a ICASDataSet data")
if(length(MMJF) != 1) {
stop("MMJF must be a numeric between [0, 1]")
}
if(!is.numeric(MMJF)) {
stop("MMJF must be a numeric between [0, 1]")
}
if(MMJF < 0 | MMJF > 1) {
stop("MMJF must be a numeric between [0, 1]")
}
if(length(MinSumSpliceSite) != 1) {
stop("MinSumSpliceSite must be a positive numeric number")
}
if(!is.numeric(MinSumSpliceSite)) {
stop("MinSumSpliceSite must be a positive numeric number")
}
if(MinSumSpliceSite < 0) {
stop("MinSumSpliceSite must be a positive numeric number")
}
AScountData <- ASSJFilter(counts(object), MMJF = MMJF)
psiMat <- PSICalculate(ASSJMat = AScountData, MinSumSpliceSite = MinSumSpliceSite)
psi(object) <- psiMat
return(object)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.