Title: | Gene Set Regulation (GS-Reg) |
---|---|
Description: | A package for gene set analysis based on the variability of expressions as well as a method to detect Alternative Splicing Events . It implements DIfferential RAnk Conservation (DIRAC) and gene set Expression Variation Analysis (EVA) methods. For detecting Differentially Spliced genes, it provides an implementation of the Spliced-EVA (SEVA). |
Authors: | Bahman Afsari <[email protected]>, Elana J. Fertig <[email protected]> |
Maintainer: | Bahman Afsari <[email protected]>, Elana J. Fertig <[email protected]> |
License: | GPL-2 |
Version: | 1.41.0 |
Built: | 2024-12-26 06:02:33 UTC |
Source: | https://github.com/bioc/GSReg |
The GSReg package applies the analysis of variety among phenotypes for each gene set from gene expression as well as alternative splicing from junction expression. The user can also use Differential Rank Conservation (DIRAC) (Eddy et al. 2010) and a modified version which allows for efficient and easy p value calculation. Both DIRAC and its modified version are rank-based methods, i.e. they only consider the ordering of the expressions within the pathway.
The package contains several utilities enabling to:
A) Prune Gene Sets based on the available genes in the expression data;
B) Calculate the DIRAC measure and p-value for it based on permutation test;
C) Calculate for a modified DIRAC method and a fast-efficient p-valuebased on U-Statistic theory;
D) Alternative Splicing Events in genes from a phenotype to other phenotype using their junction expression;
Bahman Afsari [email protected], Elana J. Fertig [email protected]
http://www.ncbi.nlm.nih.gov/pubmed/20523739
Eddy et al., "Identifying tightly regulated and variably expressed networks by Differential Rank Conservation (DIRAC).", PLoS Comp. Bio., 2010, 6(5)
GSReg.GeneSets.DIRAC performs DIRAC for gene set analysis from the paper Eddy et al (2010). In fact, the Null hypothesis is that the conservation index is not significantly different under two phenotypes. The function calculates the p-value using permutation test; hence, extremely low p-value cannot be reached.
GSReg.GeneSets.DIRAC(geneexpres, pathways, phenotypes, Nperm = 0, alpha = 0.05, minGeneNum=5)
GSReg.GeneSets.DIRAC(geneexpres, pathways, phenotypes, Nperm = 0, alpha = 0.05, minGeneNum=5)
geneexpres |
the matrix of gene expressions. The rownames must represent gene names and the columns represent samples. There must not be any missing values. Please use imputation or remove the genes with missing values. |
pathways |
a list containing pathway information. Each element represents a pathway as a character vector. The genes shown in the pathway must be present in geneexpres. Please prune the genes in pathways using GSReg.Prune before applying this function. |
phenotypes |
a binary factor containing the phenotypes for samples in geneexpres; hence, the column number of geneexpres and the length of phenotypes must be equal. |
Nperm |
The number of permutation tests required for p-value calculation. If Nperm==0 then the function reports a normal approximation of the p-value. |
alpha |
A parameter smoothes the template estimate. The template corresponding to a comparison is 1, if the probability of the comparison of the two genes is bigger than 0.5 +alpha/n (where n is the number of samples in the phenotype), and otherwise zero. |
minGeneNum |
the minimum number of genes required in a pathway. |
IThe output is a list with three elements. Each element of the output list is a vector are named according to the pathway.
$mu1 |
a vector containing the variability in DIRAC sense (1- conservation indices in Eddy et al (2010) paper) for all pathways in phenotype == levels(phenotypes)[1]. |
$mu2 |
a vector containing the variability in DIRAC sense (1- conservation indices in Eddy et al (2010) paper) for all pathways in phenotype == levels(phenotypes)[2]. |
$pvalues |
a vector containing p-values for each pathway. Low p-values means that the gene expressions have different orderings under different phenotypes. |
Bahman Afsari
Eddy, James A., et al. "Identifying tightly regulated and variably expressed networks by Differential Rank Conservation (DIRAC)." PLoS computational biology 6.5 (2010): e1000792.
GSReg.GeneSet.VReg
library(GSBenchMark) ### loading and pruning the pathways data(diracpathways) ### loading the data data(leukemia_GSEA) ### extracting gene names genenames = rownames(exprsdata); ### DIRAC analysis DIRAna = GSReg.GeneSets.DIRAC(pathways=diracpathways,geneexpres=exprsdata,Nperm=0,phenotypes=phenotypes) dysregulatedpathways = rbind(DIRAna$mu1[which(DIRAna$pvalues<0.05)], DIRAna$mu2[which(DIRAna$pvalues<0.05)],DIRAna$pvalues[which(DIRAna$pvalues<0.05)]); rownames(dysregulatedpathways)<-c("mu1","mu2","pvalues"); print(dysregulatedpathways[,1:5]) plot(x=dysregulatedpathways["mu1",],y=dysregulatedpathways["mu2",], xlim=range(dysregulatedpathways[1:2,]),ylim=range(dysregulatedpathways[1:2,])) lines(x=c(min(dysregulatedpathways[1:2,]),max(dysregulatedpathways[1:2,])), y=c(min(dysregulatedpathways[1:2,]),max(dysregulatedpathways[1:2,])),type="l")
library(GSBenchMark) ### loading and pruning the pathways data(diracpathways) ### loading the data data(leukemia_GSEA) ### extracting gene names genenames = rownames(exprsdata); ### DIRAC analysis DIRAna = GSReg.GeneSets.DIRAC(pathways=diracpathways,geneexpres=exprsdata,Nperm=0,phenotypes=phenotypes) dysregulatedpathways = rbind(DIRAna$mu1[which(DIRAna$pvalues<0.05)], DIRAna$mu2[which(DIRAna$pvalues<0.05)],DIRAna$pvalues[which(DIRAna$pvalues<0.05)]); rownames(dysregulatedpathways)<-c("mu1","mu2","pvalues"); print(dysregulatedpathways[,1:5]) plot(x=dysregulatedpathways["mu1",],y=dysregulatedpathways["mu2",], xlim=range(dysregulatedpathways[1:2,]),ylim=range(dysregulatedpathways[1:2,])) lines(x=c(min(dysregulatedpathways[1:2,]),max(dysregulatedpathways[1:2,])), y=c(min(dysregulatedpathways[1:2,]),max(dysregulatedpathways[1:2,])),type="l")
GSReg.GeneSets.EVA performs modified version DIRAC papers. Using a theoretical analysis, we can calculate p-value which makes extreme low p-values available.
GSReg.GeneSets.EVA(geneexpres, pathways, phenotypes,minGeneNum=5)
GSReg.GeneSets.EVA(geneexpres, pathways, phenotypes,minGeneNum=5)
geneexpres |
the matrix of gene expressions. The rownames must represent gene names and the columns represent samples. There must not be any missing values. Please use imputation or remove the genes with missing values. |
pathways |
a list containing pathway information. Each element represents a pathway as a character vector. The genes shown in the pathway must be present in geneexpres. geneexpres must have numeric and finite numbers. |
phenotypes |
a binary factor containing the phenotypes for samples in geneexpres; hence, the column number of geneexpres and the length of phenotypes must be equal. |
minGeneNum |
the minimum number of genes required in a pathway. |
a list of analysis for all pathways.
$E1 |
the modified variance on the pathway within the samples from levels(phenotypes)[1]. |
$E2 |
the modified variance on the pathway within the samples from levels(phenotypes)[2]. |
$E12 |
the modified variance on the pathway across the samples from levels(phenotypes)[1] tolevels(phenotypes)[2]. |
$VarEta1 |
the estimation of the modified variance on the pathway within the samples from levels(phenotypes)[1]. |
$VarEta2 |
the estimation of the modified variance on the pathway within the samples from levels(phenotypes)[2]. |
$zscore |
zscore for the modified variance. |
$pvalue |
theoretical p-value for null E1 = E2. (Standard EVA). |
$pvalueD12D1 |
theoretical p-value for null E1 = E12. |
$pvalueD12D2 |
theoretical p-value for null E2 = E12. |
$pvalueTotal |
Bonferonni corrected p-value of the three p-values. |
Bahman Afsari
GSReg.GeneSets.DIRAC,cor
### loading and pruning the pathways library(GSBenchMark) data(diracpathways) ### loading the data data(leukemia_GSEA) ### removing genes which contain not a number. if(sum(apply(is.nan(exprsdata),1,sum)>0)) exprsdata = exprsdata[-which(apply(is.nan(exprsdata),1,sum)>0),]; ### extracting gene names genenames = rownames(exprsdata); ### DIRAC analysis VarAnKendallV = GSReg.GeneSets.EVA(geneexpres=exprsdata, pathways=diracpathways, phenotypes=as.factor(phenotypes)) E1 = sapply(VarAnKendallV,function(x) x$E1); E2 = sapply(VarAnKendallV,function(x) x$E2); Kpvalues = sapply(VarAnKendallV,function(x) x$pvalue); dysregulatedpathways = rbind(E1[which(Kpvalues<0.05)], E2[which(Kpvalues<0.05)],Kpvalues[which(Kpvalues<0.05)]); rownames(dysregulatedpathways)<-c("E1","E2","pvalues"); print(dysregulatedpathways) plot(x=dysregulatedpathways["E1",],y=dysregulatedpathways["E2",], xlim=range(dysregulatedpathways[1:2,]),ylim=range(dysregulatedpathways[1:2,])) lines(x=c(min(dysregulatedpathways[1:2,]),max(dysregulatedpathways[1:2,])), y=c(min(dysregulatedpathways[1:2,]),max(dysregulatedpathways[1:2,])),type="l")
### loading and pruning the pathways library(GSBenchMark) data(diracpathways) ### loading the data data(leukemia_GSEA) ### removing genes which contain not a number. if(sum(apply(is.nan(exprsdata),1,sum)>0)) exprsdata = exprsdata[-which(apply(is.nan(exprsdata),1,sum)>0),]; ### extracting gene names genenames = rownames(exprsdata); ### DIRAC analysis VarAnKendallV = GSReg.GeneSets.EVA(geneexpres=exprsdata, pathways=diracpathways, phenotypes=as.factor(phenotypes)) E1 = sapply(VarAnKendallV,function(x) x$E1); E2 = sapply(VarAnKendallV,function(x) x$E2); Kpvalues = sapply(VarAnKendallV,function(x) x$pvalue); dysregulatedpathways = rbind(E1[which(Kpvalues<0.05)], E2[which(Kpvalues<0.05)],Kpvalues[which(Kpvalues<0.05)]); rownames(dysregulatedpathways)<-c("E1","E2","pvalues"); print(dysregulatedpathways) plot(x=dysregulatedpathways["E1",],y=dysregulatedpathways["E2",], xlim=range(dysregulatedpathways[1:2,]),ylim=range(dysregulatedpathways[1:2,])) lines(x=c(min(dysregulatedpathways[1:2,]),max(dysregulatedpathways[1:2,])), y=c(min(dysregulatedpathways[1:2,]),max(dysregulatedpathways[1:2,])),type="l")
Different types of calculations of kendall-tau distance.
GSReg.kendall.tau.distance(V) GSReg.kendall.tau.distance.template(V, Temp) GSReg.kendall.tau.distance.restricted(V, RestMat)
GSReg.kendall.tau.distance(V) GSReg.kendall.tau.distance.template(V, Temp) GSReg.kendall.tau.distance.restricted(V, RestMat)
V |
A matrix on which the distances will be calculated. The distance will be calculated between any pair of columns |
Temp |
A square binary template matrix, like DIRAC template, whose columns and rows correspond to the rows of V. In general, Temp provides a template for comparisons in V. Temp[i,j]==1 means that the template expects that V[i,.]<V[j,.] and 0 means the reverse. |
RestMat |
Restricted matrix. It must be a square matrix and symmetric with binary 0 or 1 whose columns and rows correspond to the rows of V. Only comparisons with one will be considered. |
GSReg.kendall.tau.distance returns kendall-tau calculates distance matrix between any pair of columns of V.
GSReg.kendall.tau.distance.template returns kendall-tau calculates distance matrix between any column V and a template. Temp[i,j] represent a comaprison between the i-th and j-th element of a vector. Hence, the out come's k-th element is (V[i,k]<V[j,k] & RestMat[i,j]==1)/((nrow(RestMat)*(nrow(RestMat)-1))/2).
GSReg.kendall.tau.distance.restricted calculates the Kendall-tau distance and the only considered comparisons are those RestMat[i,j]==1. It is a modified Kendall-tau distance used by SEVA.
Kendall-tau distance.
Bahman Afsari
GSReg.GeneSets.DIRAC,GSReg.GeneSets.EVA
library(GSReg) V <- cbind(c(1,5,3),c(3,2,1)) rownames(V) <- c("F1","F2","F3") colnames(V) <- c("S1","S2") myRest1 <- cbind(c(0,1,1),c(1,0,1),c(1,1,0)) rownames(myRest1) <- rownames(V) colnames(myRest1) <- rownames(V) GSReg.kendall.tau.distance.restricted(V,myRest1) GSReg.kendall.tau.distance(V) myRest2 <- cbind(c(0,0,1),c(0,0,1),c(1,1,0)) rownames(myRest2) <- rownames(V) colnames(myRest2) <- rownames(V) GSReg.kendall.tau.distance.restricted(V,myRest2) Temp1 <- cbind(c(0,1,1),c(0,0,0),c(0,1,0)) rownames(Temp1) <- rownames(V) colnames(Temp1) <- rownames(V) GSReg.kendall.tau.distance.template(V,Temp = Temp1)
library(GSReg) V <- cbind(c(1,5,3),c(3,2,1)) rownames(V) <- c("F1","F2","F3") colnames(V) <- c("S1","S2") myRest1 <- cbind(c(0,1,1),c(1,0,1),c(1,1,0)) rownames(myRest1) <- rownames(V) colnames(myRest1) <- rownames(V) GSReg.kendall.tau.distance.restricted(V,myRest1) GSReg.kendall.tau.distance(V) myRest2 <- cbind(c(0,0,1),c(0,0,1),c(1,1,0)) rownames(myRest2) <- rownames(V) colnames(myRest2) <- rownames(V) GSReg.kendall.tau.distance.restricted(V,myRest2) Temp1 <- cbind(c(0,1,1),c(0,0,0),c(0,1,0)) rownames(Temp1) <- rownames(V) colnames(Temp1) <- rownames(V) GSReg.kendall.tau.distance.template(V,Temp = Temp1)
GSReg.overlapJunction generates junction overlap matrices required for SEVA. It may also perform the filtering the junctions based on the expression of the gene.
GSReg.overlapJunction <- function(juncExprs, GenestoStudy=NULL, geneexpr=NULL, minmeanloggeneexp= 3, alpha =0, sparse = F, genesCoordinatesTxDB = TxDb.Hsapiens.UCSC.hg19.knownGene, geneIDInTxDB = 'ENTREZID', geneIDOut = 'SYMBOL', org=org.Hs.eg.db, ...)
GSReg.overlapJunction <- function(juncExprs, GenestoStudy=NULL, geneexpr=NULL, minmeanloggeneexp= 3, alpha =0, sparse = F, genesCoordinatesTxDB = TxDb.Hsapiens.UCSC.hg19.knownGene, geneIDInTxDB = 'ENTREZID', geneIDOut = 'SYMBOL', org=org.Hs.eg.db, ...)
juncExprs |
A matrix containing junction expression whose columns represent samples. Rows correspond to junctions and whose names are formed in the following format, chrN:D-A, N represents chromosome number, D represents the start coordination coordinate and A the acceptor end coordinationcoordinate. If geneexprs is not specified, overlaps and consequently SEVA statistics become independent of the quantification method for expression (assuming they do not affect the order of the junction expression) because SEVA is a rank-based method. Otherwise, junction expression and total gene expression in geneexprs (expected to have the same quantification method as junction expression) would be log transformed for applying optimal filtering. |
geneexpr |
gene expression matrix whose values have been calculated using the same quantification as juncExprs. Columns must contain the same samples and same sample order as juncExprs. It is used for two types of filtering: see minmeanloggeneexp, alpha.If this parameter is missing, both filters will not be applied. |
minmeanloggeneexp |
The parameter for filtering a genes based on the gene expression. If the geneexpr after transformed in log2 does not pass minmeanloggeneexp, all its corresponding junctions would be filtered. |
alpha |
The parameter for the filter junction expression . By default this filter is off by alpha=0 but we recommend alpha= 0.1 for a default analysis. In fact, if a junction maximum expression in log2 does not pass the average of its corresponding gene expression in log2 times alpha, the junction will be filtered. |
sparse |
Use sparse matrices for junctions overlap. Not recommended unless you run out of memory. |
genesCoordinatesTxDB |
The annotation database used for alignment. The default is hg19. It must be the annotation dataset used for gene and junction expression alignment. |
geneIDInTxDB |
Gene IDs in the database. |
geneIDOut |
Gene IDs used for geneexpr. |
... |
Other parameters to be sent to mapIds function. |
$Rest |
a list for all genestoStudy. Each of them contains a square matrix whose rows and columns corresponds to the genes junction and the value is one if they overlap otherwise zero i.e. $Rest[["genes"]]["junci","juncj" = I(junc i and junc j overlap) |
$genesJunction |
a list for all geensToStudy. Each of them contains a vector of the names of the junctions. |
Bahman Afsari
GSReg.GeneSets.DIRAC,GSReg.GeneSets.EVA
library(GSReg) require('Homo.sapiens') require('org.Hs.eg.db') require('GenomicRanges') data(juncExprsSimulated) overlapMat <- GSReg.overlapJunction(juncExprs = junc.RPM.Simulated, geneexpr = geneExrsGSReg)
library(GSReg) require('Homo.sapiens') require('org.Hs.eg.db') require('GenomicRanges') data(juncExprsSimulated) overlapMat <- GSReg.overlapJunction(juncExprs = junc.RPM.Simulated, geneexpr = geneExrsGSReg)
GSReg.SEVA identifies Differential Spliced genes by assigning p-value by SEVA.
function(juncExprs, phenoVect, verbose=T, sparse =F, ...)
function(juncExprs, phenoVect, verbose=T, sparse =F, ...)
juncExprs |
A matrix containing junction expression whose columns represent samples. Rows correspond to junctions and whose names are formed in the following format, chrN:D-A, N represents chromosome number, D represents the start coordination coordinate and A the acceptor end coordinationcoordinate. If geneexprs is not specified, SEVA statistics are independent of the coordinates for junction expression because they are rank-based . Otherwise, junction expression would be log transformed and apply the same quantification method as used for total gene expression in geneexprs for optimal filtering. |
phenoVect |
a factor containing the labels for columns of juncExprs. |
verbose |
If True, reports that if the progress of the analysis after every 100 genes are analyzed. |
sparse |
Use sparse matrices for junctions overlap. Not recommended unless you run out of memory. |
... |
Parameters would be passed to GSReg.OverlapJunction function. |
a list of analysis for all genes.
$E1 |
the modified variance on the pathway within the samples from levels(phenotypes)[1]. |
$E2 |
the modified variance on the pathway within the samples from levels(phenotypes)[2]. |
$E12 |
the modified variance on the pathway across the samples from levels(phenotypes)[1] tolevels(phenotypes)[2]. |
$VarEta1 |
the estimation of the modified variance on the pathway within the samples from levels(phenotypes)[1]. |
$VarEta2 |
the estimation of the modified variance on the pathway within the samples from levels(phenotypes)[2]. |
$zscore |
zscore for the modified variance. |
$zscoreD12D1 |
zscoreD12D1 for the modified variance. |
$zscoreD12D2 |
zscoreD12D2 for the modified variance. |
$pvalue |
theoretical p-value for null E1 = E2. (Standard EVA). |
$pvalueD12D1 |
theoretical p-value for null E1 = E12. |
$pvalueD12D2 |
theoretical p-value for null E2 = E12. |
$pvalueTotal |
Bonferonni corrected p-value of the three p-values. |
Bahman Afsari
GSReg.OverlapJunction,GSReg.GeneSets.DIRAC,GSReg.GeneSets.EVA
library(GSReg) require('Homo.sapiens') require('org.Hs.eg.db') require('GenomicRanges') data(juncExprsSimulated) SEVAjunc <- GSReg.SEVA(juncExprs = junc.RPM.Simulated, phenoVect = phenotypes, geneexpr = geneExrsGSReg) print(sapply(SEVAjunc,function(x) x$pvalue))
library(GSReg) require('Homo.sapiens') require('org.Hs.eg.db') require('GenomicRanges') data(juncExprsSimulated) SEVAjunc <- GSReg.SEVA(juncExprs = junc.RPM.Simulated, phenoVect = phenotypes, geneexpr = geneExrsGSReg) print(sapply(SEVAjunc,function(x) x$pvalue))