R/label_compare.R

Defines functions label_compare

Documented in label_compare

#' Calculate and Compare Labelling Values between Conditions
#' 
#' Calculate the proportion of labelling of the isotopologues found for each group of features and statistically compare them. If only one condition is available only the labelling proportions are reported
#' @param geoRgeR Result of basepeak_finder
#' @param XCMSet The xcmsSet with labelled and unlabelled samples
#' @param ppm.s ppm window to use to search the monoisotopic peak
#' @param control.cond Condition tag to be used as reference for the Welch t.test statistics
#' @param fc.vs.Control Default fold-change value to applied to report changes between different conditions
#' @param p.value.vs.Control Default p-value to applied to report changes between different conditions
#' @param Show.bp Boolean that switches if the monoisotopic labelling percentages should be reported in the output table
#' @return Dataframe with results of comparing the enrichment between \code{control.cond} and the rest of conditions
#' @export
label_compare <- function(geoRgeR=NULL, XCMSet=NULL,  ppm.s=NULL, control.cond=NULL,
                            fc.vs.Control=1, p.value.vs.Control=0.05, Show.bp= T) {
    
    if(is.null(control.cond)){stop("Please indicate a control condition for statistical reference")}
    georgedf <- geoRgeR[["geoRge"]]
    puinc_params <- geoRgeR$params
    XCMSmode <- puinc_params$XCMSmode 
    ULtag <- puinc_params$ULtag 
    Ltag <- puinc_params$Ltag 
    UL.atomM <- puinc_params$UL.atomM
    L.atomM <- puinc_params$L.atomM
    separator <- puinc_params$separator
    sep.pos.front <- puinc_params$sep.pos.front 
    conditions <- puinc_params$conditions
    mass_diff <- L.atomM - UL.atomM
    
    xdata <- getData(XCMSet,XCMSmode)
    D1 <- xdata$D1
    classv <- xdata$classv
    featdef <- xdata$featdef
    xgroup <- cbind(featdef[,c("mzmed", "rtmed")], D1)
    
    percent.incorp <- lapply(unique(georgedf$inc_id), function(y){
        
        inc_id_features <- georgedf[which(georgedf$inc_id==y), ] 
        inc_id_int <- inc_id_features[ ,7:ncol(inc_id_features)]
        
        rts <- inc_id_features$rtmed  
        rt_range <- c(min(rts), max(rts))
        
        inc_isot <- max(inc_id_features$atoms)+1
        isot_m <- inc_id_features[1, "mzmed"] + (inc_isot * mass_diff) # mass of isotope of the incorporation
        
        isot_id <- lapply(isot_m,function(x) { # seek isotope of the incorporation in raw data
            mass_range <- c(x - ppm.s*(x/1e6), x + ppm.s*(x / 1e6))
            a <- which(xgroup[,"mzmed"] >= mass_range[1] & xgroup[,"mzmed"] <= mass_range[2])  
            b <- which(xgroup[,"rtmed"] >= rt_range[1] & xgroup[,"rtmed"] <= rt_range[2])
            r <- intersect(a,b)
            return(r)
        })
        
        isot_id <- unlist(isot_id)
        
        if(length(isot_id)<1) {
            all_id <- xgroup[as.character(inc_id_features$feature_id), ] 
        } else {
            isot_id <- isot_id[1]
            all_id <- c(as.character(inc_id_features$feature_id), isot_id)
            all_id <- xgroup[all_id, ]  
        }
        
        all_id_int <- all_id[ ,3:ncol(all_id)] # intensities
        
        inc_percent <- sapply(conditions,function(x){
            inc_id_intL <- inc_id_int[,intersect(grep(Ltag,classv),grep(x,classv))]
            all_id_intL <- all_id_int[,intersect(grep(Ltag,classv),grep(x,classv))]
            
            inc_cal <- sapply(1:ncol(inc_id_intL), function(x) {(inc_id_intL[ ,x] / sum(all_id_intL[ ,x]))*100})
            return(inc_cal)
        })
        colnames(inc_percent) <- conditions
        
        atoms <- inc_id_features$atoms
        rownames(inc_percent) <- rep(atoms, length.out=nrow(inc_percent)) 
        
        mean_inc <- sapply(conditions, USE.NAMES=T, simplify=T, function(x) {
            sapply(atoms, function(z) {
                inc_p_v <- inc_percent[which(rownames(inc_percent) == z), x]
                inc_p_m <- mean(inc_p_v)  
                return(inc_p_m)
            })
        })
        colnames(mean_inc) <- paste0(colnames(mean_inc),"_MEAN")
        
        sd_inc <- sapply(conditions, USE.NAMES=T, simplify=T, function(x) {
            sapply(atoms,function (z) {
                inc_p_v <- inc_percent[which(rownames(inc_percent)==z),x]
                inc_p_s <- sd(inc_p_v)  
                return(inc_p_s)
            })
        })
        colnames(sd_inc) <- paste0(colnames(sd_inc), "_SD")
        return(list(data.frame(mean_inc,sd_inc),inc_percent))
    })
    names(percent.incorp) <- unique(georgedf$inc_id)
    
    percent.test <- lapply( unique(georgedf$inc_id),function(x){
        inc_percent <- percent.incorp[[x]][[2]]
        mean_inc <-  percent.incorp[[x]][[1]][,1:ncol(inc_percent)]
        inc_id_features <- georgedf[which(georgedf$inc_id==x), ] 
        atoms <- inc_id_features$atoms
        noncontrol <- setdiff(conditions, control.cond)
        
        pvals <- sapply(noncontrol, function (x) {
            sapply(atoms, function(y) {
                a <- try(t.test(inc_percent[which(rownames(inc_percent) == y), which(conditions == x)],
                                inc_percent[which(rownames(inc_percent) == y), which(conditions == control.cond)],
                                var.equal=T)$p.value,silent=T)
                if(is(a,"try-error")) {a <- 1}
                return(a)
            })
        })
        
        fct <- sapply(noncontrol, simplify=T, function (x) {
            sapply(1:nrow(mean_inc), function (y) { 
                case <- mean_inc[y, which(conditions == x)]
                control <- mean_inc[y, which(conditions == control.cond)]
                FC <- case/control
                FC2 <- (-(control/case))
                FC[FC<1] <- FC2[FC<1]
                names(FC) <- NULL
                return(FC)
            })
        })
        
        comp <- rep("",times=length(atoms))
        
        if (length(noncontrol)>0){
            comp <- sapply(1:nrow(pvals),function(x) {
                t <- which(pvals [x, ] < p.value.vs.Control)
                if(length(t) == 0) {
                    t <- ""
                    return(t)
                } else {
                    up <- which(fct[x, names(t)] > fc.vs.Control)
                    down <- which(fct[x, names(t)] < (-fc.vs.Control))
                    if(length(up)!=0) {
                        names(t)[up] <- paste("UP", names(t)[up], sep="_")
                    }
                    if(length(down)!=0) {
                        names(t)[down] <- paste("DOWN", names(t)[down], sep="_")
                    }
                    return(names(t))
                }
            })
            
            if(is.matrix(comp)) {
                comp <- sapply(1:ncol(comp), function(x) {
                    a <- paste(comp[ ,x], collapse=";")
                })
            } else {
                comp <- lapply(1:length(comp), function(x) paste(comp[[x]], collapse=";"))
                comp <- unlist(comp)
            }
        }
        
        comp[1] <- "Base peak"
        
        colnames(pvals) <- paste0(colnames(pvals),"_pvaluevs",control.cond)
        colnames(fct) <- paste0(colnames(fct),"_foldchangevs",control.cond)
        stats_res <- data.frame(comp,pvals,fct)
        return(stats_res)
        
    })
    
    percent.res <- lapply(1:length(percent.test),function(x){
        res <- data.frame(percent.test[[x]],percent.incorp[[x]][[1]])
        colnames(res)[1] <- "Comparison"
        if (!Show.bp) {res[1, ] <- rep("Base Peak", times=ncol(res))}
        return(res)
    })
    
    percent.incorpdf <- do.call("rbind",percent.res)
    
    return(percent.incorpdf)
}
jcapelladesto/geoRge documentation built on Sept. 18, 2021, 2:05 p.m.