R/PrbPROMISE.R

Defines functions PrbPROMISE

Documented in PrbPROMISE

PrbPROMISE<-function(geneSet, 
                  ESet,
                  MSet,                         
                  promise.pattern,             
                  strat.var=NULL,              
                  prlbl=NULL,                  
                  EMlbl=c('Expr', 'Mthyl'),     
                  pcut=0.05,                    
                  nbperm=FALSE,                 
                  max.ntail=100,                
                  nperms=10000,                
                  seed=13) 
{
  options(stringsAsFactors=FALSE)
  Edat<-exprs(ESet)
  Mdat<-exprs(MSet)
  pheDat<-phenoData(ESet)

  phdat<-pData(pheDat)
  Edat<-Edat[, is.element(dimnames(Edat)[[2]], dimnames(Mdat)[[2]]) & 
               is.element(dimnames(Edat)[[2]], dimnames(phdat)[[1]])]
  Mdat<-Mdat[, is.element(dimnames(Mdat)[[2]], dimnames(Edat)[[2]]) & 
               is.element(dimnames(Mdat)[[2]], dimnames(phdat)[[1]])]
  phdat<-phdat[is.element(dimnames(phdat)[[1]], dimnames(Edat)[[2]]) & 
               is.element(dimnames(phdat)[[1]], dimnames(Mdat)[[2]]), ]
  
  if(any(dimnames(Edat)[[2]]!=dimnames(Mdat)[[2]]))
  {
    message('Data Error!!!!!!!!!!!!!!!!!!!!!!!!!')
    break()
  }
  if(any(dimnames(Edat)[[2]]!=dimnames(phdat)[[1]]))
  {
    message('Data Error!!!!!!!!!!!!!!!!!!!!!!!!!')
    break()
  }  
   
  CORres<-PrbCor(geneSet=geneSet, Edat=Edat, Mdat=Mdat, 
                 EMlbl=EMlbl, phdat=phdat, pcut=pcut)
  cordat<-CORres$gen
  cordatf<-apply(cordat[, -1], 2, as.numeric)
  dimnames(cordatf)[[1]]<-cordat[,1]
   
  expr<-as.matrix(cordatf[, 1:(ncol(cordatf)/2)])
  mtyl<-as.matrix(cordatf[, (ncol(cordatf)/2+1):ncol(cordatf)])
  colnames(mtyl)<-colnames(expr)
  
  exprsetx<-new("ExpressionSet", exprs=expr, phenoData = pheDat) 
  exprsety<-new("ExpressionSet", exprs=mtyl, phenoData = pheDat)      
  
  PRres<-PROMISE2(exprSet=exprsetx, exprSet2=exprsety,
                    geneSet=NULL, 
                    promise.pattern=promise.pattern, 
                    strat.var=strat.var,  
                    nperms=nperms,
                    nbperm=nbperm,
                    max.ntail=max.ntail,
                    seed=seed)$generes
  if (is.null(prlbl ))  
  {prlbl<-c(promise.pattern[, 'endpt.vars'], paste('PR', nrow(promise.pattern), sep=""))}
  if (!nbperm)
  dimnames(PRres)[[2]]<-c('Gene', paste(paste(EMlbl[1], prlbl, sep="_"), 'Stat', sep="."), 
                            paste(paste(EMlbl[2], prlbl, sep="_"), 'Stat', sep="."), 
                            paste(prlbl[length(prlbl)], 'Stat', sep="."),
                            paste(paste(EMlbl[1], prlbl, sep="_"), 'Pval', sep="."), 
                            paste(paste(EMlbl[2], prlbl, sep="_"), 'Pval', sep="."), 
                            paste(prlbl[length(prlbl)], 'Pval', sep="."))
  if (nbperm) 
  dimnames(PRres)[[2]]<-c('Gene', paste(paste(EMlbl[1], prlbl, sep="_"), 'Stat', sep="."), 
                            paste(paste(EMlbl[2], prlbl, sep="_"), 'Stat', sep="."), 
                            paste(prlbl[length(prlbl)], 'Stat', sep="."),
                            paste(paste(EMlbl[1], prlbl, sep="_"), 'Pval', sep="."), 
                            paste(paste(EMlbl[2], prlbl, sep="_"), 'Pval', sep="."), 
                            paste(prlbl[length(prlbl)], 'Pval', sep="."), 'nperm')                                                              
  return(list(PRres=PRres, CORres=CORres$res))
} 
xueyuancao/CCPROMISE documentation built on May 6, 2023, 8:29 a.m.