Title: | Enrichment Analysis for Gene Ontology |
---|---|
Description: | topGO package provides tools for testing GO terms while accounting for the topology of the GO graph. Different test statistics and different methods for eliminating local similarities and dependencies between GO terms can be implemented and applied. |
Authors: | Adrian Alexa, Jorg Rahnenfuhrer |
Maintainer: | Adrian Alexa <[email protected]> |
License: | LGPL |
Version: | 2.59.0 |
Built: | 2025-01-17 05:10:22 UTC |
Source: | https://github.com/bioc/topGO |
topGO package provides tools for testing GO terms while accounting for the topology of the GO graph. Different test statistics and different methods for eliminating local similarities and dependencies between GO terms can be implemented and applied.
Package: | topGO |
Type: | Package |
Version: | 1.0 |
Date: | 2006-10-02 |
License: | What license is it under? |
TODO: An overview of how to use the package, including the most important functions
Adrian Alexa, J\"org Rahnenf\"uhrer
Maintainer: Adrian Alexa
Alexa A., Rahnenf\"uhrer J., Lengauer T., Improved scoring of functional groups from gene expression data by decorrelating GO graph structure, Bioinformatics 22(13): 1600-1607, 2006
topGOdata-class
, groupStats-class
,
getSigGroups-methods
These functions are used to compile a list of GO terms such that each element in the list is a character vector containing all the gene identifiers that are mapped to the respective GO term.
annFUN.db(whichOnto, feasibleGenes = NULL, affyLib) annFUN.org(whichOnto, feasibleGenes = NULL, mapping, ID = "entrez") annFUN(whichOnto, feasibleGenes = NULL, affyLib) annFUN.gene2GO(whichOnto, feasibleGenes = NULL, gene2GO) annFUN.GO2genes(whichOnto, feasibleGenes = NULL, GO2genes) annFUN.file(whichOnto, feasibleGenes = NULL, file, ...) readMappings(file, sep = "\t", IDsep = ",") inverseList(l)
annFUN.db(whichOnto, feasibleGenes = NULL, affyLib) annFUN.org(whichOnto, feasibleGenes = NULL, mapping, ID = "entrez") annFUN(whichOnto, feasibleGenes = NULL, affyLib) annFUN.gene2GO(whichOnto, feasibleGenes = NULL, gene2GO) annFUN.GO2genes(whichOnto, feasibleGenes = NULL, GO2genes) annFUN.file(whichOnto, feasibleGenes = NULL, file, ...) readMappings(file, sep = "\t", IDsep = ",") inverseList(l)
whichOnto |
character string specifying one of the three GO
ontologies, namely: |
feasibleGenes |
character vector containing a subset of gene
identifiers. Only these genes will be used to annotate GO
terms. Default value is |
affyLib |
character string containing the name of the Bioconductor annotaion package for a specific microarray chip. |
gene2GO |
named list of character vectors. The list names are genes identifiers. For each gene the character vector contains the GO identifiers it maps to. Only the most specific annotations are required. |
GO2genes |
named list of character vectors. The list names are GO identifiers. For each GO the character vector contains the genes identifiers which are mapped to it. Only the most specific annotations are required. |
mapping |
character string specifieng the name of the
Bioconductor package containing the gene mappings for a
specific organism. For example: |
ID |
character string specifing the gene identifier to
use. Currently only the following identifiers can be used:
|
file |
character string specifing the file containing the annotations. |
... |
other parameters |
sep |
the character used to separate the columns in the CSV file |
IDsep |
the character used to separate the annotated entities |
l |
a list containing mappings |
All these function restrict the GO terms to the ones belonging
to the specified ontology and to the genes listed in the
feasibleGenes
attribute (if not empty).
The function annFUN.db
uses the mappings provided
in the Bioconductor annotation data packages. For example, if the
Affymetrix hgu133a
chip it is used, then the user should set
affyLib = "hgu133a.db"
.
The functions annFUN.gene2GO
and annFUN.GO2genes
are
used when the user provide his own annotations either as a gene-to-GOs
mapping, either as a GO-to-genes mapping.
The annFUN.org
function is using the mappings from the
"org.XX.XX" annotation packages. The function supports different gene
identifiers.
The annFUN.file
function will read the annotationsof the type
gene2GO or GO2genes from a text file.
A named(GO identifiers) list of character vectors.
Adrian Alexa
library(hgu133a.db) set.seed(111) ## generate a gene list and the GO annotations selGenes <- sample(ls(hgu133aGO), 50) gene2GO <- lapply(mget(selGenes, envir = hgu133aGO), names) gene2GO[sapply(gene2GO, is.null)] <- NA ## the annotation for the first three genes gene2GO[1:3] ## inverting the annotations G2g <- inverseList(gene2GO) ## inverting the annotations and selecting an ontology go2genes <- annFUN.gene2GO(whichOnto = "CC", gene2GO = gene2GO) ## generate a GO list with the genes annotations selGO <- sample(ls(hgu133aGO2PROBE), 30) GO2gene <- lapply(mget(selGO, envir = hgu133aGO2PROBE), as.character) GO2gene[1:3] ## select only the GO terms for a specific ontology go2gene <- annFUN.GO2genes(whichOnto = "CC", GO2gene = GO2gene) ################################################## ## Using the org.XX.xx.db annotations ################################################## ## GO to Symbol mappings (only the BP ontology is used) xx <- annFUN.org("BP", mapping = "org.Hs.eg.db", ID = "symbol") head(xx) ## Not run: allGenes <- unique(unlist(xx)) myInterestedGenes <- sample(allGenes, 500) geneList <- factor(as.integer(allGenes names(geneList) <- allGenes GOdata <- new("topGOdata", ontology = "BP", allGenes = geneList, nodeSize = 5, annot = annFUN.org, mapping = "org.Hs.eg.db", ID = "symbol") ## End(Not run)
library(hgu133a.db) set.seed(111) ## generate a gene list and the GO annotations selGenes <- sample(ls(hgu133aGO), 50) gene2GO <- lapply(mget(selGenes, envir = hgu133aGO), names) gene2GO[sapply(gene2GO, is.null)] <- NA ## the annotation for the first three genes gene2GO[1:3] ## inverting the annotations G2g <- inverseList(gene2GO) ## inverting the annotations and selecting an ontology go2genes <- annFUN.gene2GO(whichOnto = "CC", gene2GO = gene2GO) ## generate a GO list with the genes annotations selGO <- sample(ls(hgu133aGO2PROBE), 30) GO2gene <- lapply(mget(selGO, envir = hgu133aGO2PROBE), as.character) GO2gene[1:3] ## select only the GO terms for a specific ontology go2gene <- annFUN.GO2genes(whichOnto = "CC", GO2gene = GO2gene) ################################################## ## Using the org.XX.xx.db annotations ################################################## ## GO to Symbol mappings (only the BP ontology is used) xx <- annFUN.org("BP", mapping = "org.Hs.eg.db", ID = "symbol") head(xx) ## Not run: allGenes <- unique(unlist(xx)) myInterestedGenes <- sample(allGenes, 500) geneList <- factor(as.integer(allGenes names(geneList) <- allGenes GOdata <- new("topGOdata", ontology = "BP", allGenes = geneList, nodeSize = 5, annot = annFUN.org, mapping = "org.Hs.eg.db", ID = "symbol") ## End(Not run)
This class that extends the virtual class "groupStats" by adding a slot representing the significant members.
This class is used for test statistic based on counts, like Fisher's exact test
Objects can be created by calls of the form
new("classicCount",
testStatistic = "function",
name = "character",
allMembers = "character",
groupMembers = "character",
sigMembers = "character")
.
significant
:Object of class "integer"
~~
name
:Object of class "character"
~~
allMembers
:Object of class "character"
~~
members
:Object of class "character"
~~
testStatistic
:Object of class "function"
~~
Class "groupStats"
, directly.
signature(object = "classicCount")
: ...
signature(.Object = "classicCount")
: ...
signature(object = "classicCount")
: ...
signature(object = "classicCount")
: ...
signature(object = "classicCount")
: ...
signature(object = "classicCount")
: ...
signature(object = "classicCount")
: ...
Adrian Alexa
classicScore-class
,
groupStats-class
,
getSigGroups-methods
##---- Should be DIRECTLY executable !! ----
##---- Should be DIRECTLY executable !! ----
This class that extends the virtual class "groupStats" by adding two slots for accomodating gene expression data.
Objects can be created by calls of the form new("classicExpr", testStatistic, name, groupMembers, exprDat, pType, ...)
.
eData
:Object of class "environment"
~~
pType
:Object of class "factor"
~~
name
:Object of class "character"
~~
allMembers
:Object of class "character"
~~
members
:Object of class "character"
~~
testStatistic
:Object of class "function"
~~
testStatPar
:Object of class "list"
~~
Class "groupStats"
, directly.
signature(object = "classicExpr")
: ...
signature(object = "classicExpr")
: ...
signature(object = "topGOdata", test.stat = "classicExpr")
: ...
signature(object = "classicExpr")
: ...
signature(.Object = "classicExpr")
: ...
signature(object = "classicExpr")
: ...
signature(object = "classicExpr")
: ...
signature(object = "classicExpr")
: ...
Adrian Alexa
classicScore-class
,
groupStats-class
,
getSigGroups-methods
showClass("classicExpr")
showClass("classicExpr")
A class that extends the virtual class "groupStats" by adding a slot representing the score of each gene. It is used for tests like Kolmogorov-Smirnov test.
Objects can be created by calls of the form new("classicScore", testStatistic, name, allMembers, groupMembers, score, decreasing)
.
score
:Object of class "numeric"
~~
name
:Object of class "character"
~~
allMembers
:Object of class "character"
~~
members
:Object of class "character"
~~
testStatistic
:Object of class "function"
~~
scoreOrder
:Object of class "character"
~~
testStatPar
:Object of class "ANY"
~~
Class "groupStats"
, directly.
Method to obtain the score of all members.
Returns TRUE if the score should be ordered increasing, FALSE otherwise.
signature(object = "classicScore")
: ...
signature(object = "classicScore")
: ...
signature(object = "classicScore")
: ...
Adrian Alexa
classicCount-class
,
groupStats-class
,
getSigGroups-methods
## define the type of test you want to use test.stat <- new("classicScore", testStatistic = GOKSTest, name = "KS tests")
## define the type of test you want to use test.stat <- new("classicScore", testStatistic = GOKSTest, name = "KS tests")
Basic functions to work witg DAGs
buildLevels(dag, root = NULL, leafs2root = TRUE) getNoOfLevels(graphLevels) getGraphRoot(dag, leafs2root = TRUE) reverseArch(dirGraph, useAlgo = "sparse", useWeights = TRUE)
buildLevels(dag, root = NULL, leafs2root = TRUE) getNoOfLevels(graphLevels) getGraphRoot(dag, leafs2root = TRUE) reverseArch(dirGraph, useAlgo = "sparse", useWeights = TRUE)
dag |
A |
root |
A character vector specifing the root(s) of the DAG. If not specified the root node is autmatically computed. |
leafs2root |
The leafs2root parameter tell if the graph has edges directed from the leaves to the root, or vice-versa |
graphLevels |
An object of type list, returned by the |
dirGraph |
A |
useAlgo |
A character string specifing one of the following options
|
useWeights |
If weights should be used (if |
buildLevels
function determines the levels of a Directed
Acyclic Graph (DAG). The level of a node is defined as the longest
path from the node to the root. The function take constructs a named
list containg varios information about each nodes level. The root has
level 1.
getNoOfLevels
- a convenient function to extract the number of
levels from the object returned by buildLevels
getGraphRoot
finds the root(s) of the DAG
reverseArch
- simple function to invert the direction of edges
in a DAG. The returned graph is of class graphNEL. It can use either
simple matrices or sparse matrices (SparseM library)
buildLevels
returns a list containing:
level2nodes |
Environment where the key is the level number with the value being the nodes on that level. |
nodes2level |
Environment where the key is the node label (the GO ID) and the value is the level on which that node lies. |
noOfLevels |
The number of levels |
noOfNodes |
The number of nodes |
An object of class graphNEL-class
is returned.
Adrian Alexa
##---- Should be DIRECTLY executable !! ---- ##-- ==> Define data, use random, ##-- or do help(data=index) for the standard data sets.
##---- Should be DIRECTLY executable !! ---- ##-- ==> Define data, use random, ##-- or do help(data=index) for the standard data sets.
The GenTable
function generates a summary of the
results of the enrichment analysis.
The showGroupDensity
function plots the distributions of the
gene' scores/ranks inside a GO term.
The printGenes
function shows a short summary of the top genes annotated
to the specified GO terms.
GenTable(object, ...) showGroupDensity(object, whichGO, ranks = FALSE, rm.one = TRUE) printGenes(object, whichTerms, file, ...)
GenTable(object, ...) showGroupDensity(object, whichGO, ranks = FALSE, rm.one = TRUE) printGenes(object, whichTerms, file, ...)
object |
an object of class |
whichGO |
the GO terms for which the plot should be generated. |
ranks |
if ranks should be used instead of scores. |
rm.one |
the p-values which are 1 are removed. |
whichTerms |
character vector listing the GO terms for which the summary should be printed. |
file |
character string specifying the file in which the results should be printed. |
... |
Extra arguments for
Extra arguments for
|
GenTable
is an easy to use function for summarising the most
significant GO terms and the corresponding p-values. The function
dispatches for topGOdata
and topGOresult
objects, and
it can take an arbitrary number of the later, making comparison
between various results easier.
Note: One needs to type the complete attribute names (the exact name)
of this function, like: topNodes = 5
, rankOf = "resultFis"
, etc.
This being the price paid for flexibility of specifying different
number of topGOdata
objects.
The showGroupDensity
function analyse the distribution of the
gene-wise scores for a specified GO term.
The function will show the distribution of the genes in a GO term
compared with the complementary set, using a lattice plot.
printGenes
The function will generate a table with all the probes annotated to
the specified GO term. Various type of identifiers, the gene name and
the gene-wise statistics are provided in the table.
One or more GO identifiers can be given to the function using the
whichTerms
argument. When more than one GO is specified, the
function returns a list of data.frames
, otherwise only one
data.frame
is returned.
The function has a argument file
which, when specified, will
save the results into a file using the CSV format.
For the moment the function will work only when the chip used has an annotation package available in Bioconductor. It will not work with other type of custom annotations.
A data.frame or a list of data.fames.
Adrian Alexa
groupStats-class
,
getSigGroups-methods
data(GOdata) ######################################## ## GenTable ######################################## ## load two topGOresult sample objects: resultFisher and resultKS data(results.tGO) ## generate the result of Fisher's exact test sig.tab <- GenTable(GOdata, Fis = resultFisher, topNodes = 20) ## results of both test sig.tab <- GenTable(GOdata, resultFisher, resultKS, topNodes = 20) ## results of both test with specified names sig.tab <- GenTable(GOdata, Fis = resultFisher, KS = resultKS, topNodes = 20) ## results of both test with specified names and specified ordering sig.tab <- GenTable(GOdata, Fis = resultFisher, KS = resultKS, orderBy = "KS", ranksOf = "Fis", topNodes = 20) ######################################## ## showGroupDensity ######################################## goID <- "GO:0006091" print(showGroupDensity(GOdata, goID, ranks = TRUE)) print(showGroupDensity(GOdata, goID, ranks = FALSE, rm.one = FALSE)) ######################################## ## printGenes ######################################## ## Not run: library(hgu95av2.db) goID <- "GO:0006629" gt <- printGenes(GOdata, whichTerms = goID, chip = "hgu95av2.db", numChar = 40) goIDs <- c("GO:0006629", "GO:0007076") gt <- printGenes(GOdata, whichTerms = goIDs, chip = "hgu95av2.db", pvalCutOff = 0.01) gt[goIDs[1]] ## End(Not run)
data(GOdata) ######################################## ## GenTable ######################################## ## load two topGOresult sample objects: resultFisher and resultKS data(results.tGO) ## generate the result of Fisher's exact test sig.tab <- GenTable(GOdata, Fis = resultFisher, topNodes = 20) ## results of both test sig.tab <- GenTable(GOdata, resultFisher, resultKS, topNodes = 20) ## results of both test with specified names sig.tab <- GenTable(GOdata, Fis = resultFisher, KS = resultKS, topNodes = 20) ## results of both test with specified names and specified ordering sig.tab <- GenTable(GOdata, Fis = resultFisher, KS = resultKS, orderBy = "KS", ranksOf = "Fis", topNodes = 20) ######################################## ## showGroupDensity ######################################## goID <- "GO:0006091" print(showGroupDensity(GOdata, goID, ranks = TRUE)) print(showGroupDensity(GOdata, goID, ranks = FALSE, rm.one = FALSE)) ######################################## ## printGenes ######################################## ## Not run: library(hgu95av2.db) goID <- "GO:0006629" gt <- printGenes(GOdata, whichTerms = goID, chip = "hgu95av2.db", numChar = 40) goIDs <- c("GO:0006629", "GO:0007076") gt <- printGenes(GOdata, whichTerms = goIDs, chip = "hgu95av2.db", pvalCutOff = 0.01) gt[goIDs[1]] ## End(Not run)
Classes that extend the "classicCount" class by adding a slot representing the members that need to be removed.
Objects can be created by calls of the form new("elimCount", testStatistic, name, allMembers, groupMembers, sigMembers, elim, cutOff, ...)
.
elim
:Object of class "integer"
~~
cutOff
:Object of class "numeric"
~~
significant
:Object of class "integer"
~~
name
:Object of class "character"
~~
allMembers
:Object of class "character"
~~
members
:Object of class "character"
~~
testStatistic
:Object of class "function"
~~
testStatPar
:Object of class "list"
~~
Class "classicCount"
, directly.
Class "groupStats"
, by class "classicCount", distance 2.
No methods defined with class "elimCount" in the signature.
Adrian Alexa
classicScore-class
,
groupStats-class
,
getSigGroups-methods
Classes that extend the "classicExpr" class by adding a slot representing the members that need to be removed.
TODO: Some datails here.....
Objects can be created by calls of the form new("elimExpr", testStatistic, name, groupMembers, exprDat, pType, elim, cutOff, ...)
.
~~ describe objects here ~~
cutOff
:Object of class "numeric"
~~
elim
:Object of class "integer"
~~
eData
:Object of class "environment"
~~
pType
:Object of class "factor"
~~
name
:Object of class "character"
~~
allMembers
:Object of class "character"
~~
members
:Object of class "character"
~~
testStatistic
:Object of class "function"
~~
testStatPar
:Object of class "list"
~~
Class "weight01Expr"
, directly.
Class "classicExpr"
, by class "weight01Expr", distance 2.
Class "groupStats"
, by class "weight01Expr", distance 3.
signature(object = "elimExpr")
: ...
signature(object = "elimExpr")
: ...
signature(object = "topGOdata", test.stat = "elimExpr")
: ...
signature(.Object = "elimExpr")
: ...
Adrian Alexa
classicScore-class
,
groupStats-class
,
getSigGroups-methods
showClass("elimExpr")
showClass("elimExpr")
Classes that extend the "classicScore" class by adding a slot representing the members that need to be removed.
TODO:
Objects can be created by calls of the form new("elimScore", testStatistic, name, allMembers, groupMembers, score, alternative, elim, cutOff, ...)
.
~~ describe objects here ~~
elim
:Object of class "integer"
~~
cutOff
:Object of class "numeric"
~~
score
:Object of class "numeric"
~~
.alternative
:Object of class "logical"
~~
name
:Object of class "character"
~~
allMembers
:Object of class "character"
~~
members
:Object of class "character"
~~
testStatistic
:Object of class "function"
~~
testStatPar
:Object of class "list"
~~
Class "classicScore"
, directly.
Class "groupStats"
, by class "classicScore", distance 2.
No methods defined with class "elimScore" in the signature.
Adrian Alexa
classicScore-class
,
groupStats-class
,
getSigGroups-methods
##---- Should be DIRECTLY executable !! ----
##---- Should be DIRECTLY executable !! ----
Methods which implement and run a group test statistic for
a class inheriting from groupStats
class. See Details section
for a description of each method.
GOFisherTest(object) GOKSTest(object) GOtTest(object) GOglobalTest(object) GOSumTest(object) GOKSTiesTest(object)
GOFisherTest(object) GOKSTest(object) GOtTest(object) GOglobalTest(object) GOSumTest(object) GOKSTiesTest(object)
object |
An object of class |
GOFisherTest: implements Fischer's exact test (based on contingency
table) for groupStats
objects dealing with "counts".
GOKSTest: implements the Kolmogorov-Smirnov test for groupStats
objects dealing with gene "scores". This test uses the ks.test
function and does not implement the running-sum-statistic test based
on permutations.
GOtTest: implements the t-test for groupStats
objects dealing
with gene "scores". It should be used when the gene scores are
t-statistics or any other score following a normal distribution.
GOglobalTest: implement Goeman's globaltest.
All these methods return the p-value computed by the respective test statistic.
Adrian Alexa
groupStats-class
,
getSigGroups-methods
The geneList
data is compiled from a differential expression
analysis of the ALL
dataset. It contains just a small number
of genes with the corespondent p-values. The information on where
to find the GO annotations is stored in the ALL
object.
The topDiffGenes
function included in this dataset will select
the differentially expressed genes, at 0.01 significance level, from
geneList
.
data(geneList)
data(geneList)
Generated using the ALL
gene expression data. See the "scripts" directory.
data(geneList) ## print the object head(geneList) length(geneList) ## the number of genes with a p-value less than 0.01 sum(topDiffGenes(geneList))
data(geneList) ## print the object head(geneList) length(geneList) ## the number of genes with a p-value less than 0.01 sum(topDiffGenes(geneList))
Warping function of "mt.teststat", for computing p-values of a gene expression matrix.
getPvalues(edata, classlabel, test = "t", alternative = c("greater", "two.sided", "less")[1], genesID = NULL, correction = c("none", "Bonferroni", "Holm", "Hochberg", "SidakSS", "SidakSD", "BH", "BY")[8])
getPvalues(edata, classlabel, test = "t", alternative = c("greater", "two.sided", "less")[1], genesID = NULL, correction = c("none", "Bonferroni", "Holm", "Hochberg", "SidakSS", "SidakSD", "BH", "BY")[8])
edata |
Gene expression matrix. |
classlabel |
The phenotype of the data |
test |
Which test statistic to use |
alternative |
The alternative of the test statistic |
genesID |
if a subset of genes is provided |
correction |
Multiple testing correction procedure |
An named numeric vector of p-values.
Adrian Alexa
GOKSTest
, groupStats-class
,
getSigGroups-methods
library(ALL) data(ALL) ## discriminate B-cell from T-cell classLabel <- as.integer(sapply(ALL$BT, function(x) return(substr(x, 1, 1) == 'T'))) ## Differentially expressed genes geneList <- getPvalues(exprs(ALL), classlabel = classLabel, alternative = "greater", correction = "BY") hist(geneList, 50)
library(ALL) data(ALL) ## discriminate B-cell from T-cell classLabel <- as.integer(sapply(ALL$BT, function(x) return(substr(x, 1, 1) == 'T'))) ## Differentially expressed genes geneList <- getPvalues(exprs(ALL), classlabel = classLabel, alternative = "greater", correction = "BY") hist(geneList, 50)
These function are used for dispatching the specific algorithm for
a given topGOdata
object and a test statistic.
getSigGroups(object, test.stat, ...) runTest(object, algorithm, statistic, ...) whichAlgorithms() whichTests()
getSigGroups(object, test.stat, ...) runTest(object, algorithm, statistic, ...) whichAlgorithms() whichTests()
object |
An object of class |
test.stat |
An object of class |
algorithm |
Character string specifing which algorithm to use. |
statistic |
Character string specifing which test to use. |
... |
Other parameters. In the case of |
The runTest
function can be used only with a predefined set of
test statistics and algorithms. The algorithms and the statistical
tests which are accessible via the runTest
function are shown
by the whichAlgorithms()
and whichTests()
functions.
The runTest function is a warping of the getSigGroups
and the
initialisation of a groupStats
object functions.
...
An object of class topGOresult
.
Adrian Alexa
topGOdata-class
,
groupStats-class
,
topGOresult-class
## load a sample topGOdata object data(GOdata) GOdata ############################## ## getSigGroups interface ############################## ## define a test statistic test.stat <- new("classicCount", testStatistic = GOFisherTest, name = "Fisher test") ## perform the test resultFis <- getSigGroups(GOdata, test.stat) resultFis ############################## ## runTest interface ############################## ## Enrichment analysis by using the "classic" method and Fisher's exact test resultFis <- runTest(GOdata, algorithm = "classic", statistic = "fisher") resultFis ## weight01 is the default algorithm weight01.fisher <- runTest(GOdata, statistic = "fisher") weight01.fisher ## not all combinations are possible! # weight.ks <- runTest(GOdata, algorithm = "weight", statistic = "t")
## load a sample topGOdata object data(GOdata) GOdata ############################## ## getSigGroups interface ############################## ## define a test statistic test.stat <- new("classicCount", testStatistic = GOFisherTest, name = "Fisher test") ## perform the test resultFis <- getSigGroups(GOdata, test.stat) resultFis ############################## ## runTest interface ############################## ## Enrichment analysis by using the "classic" method and Fisher's exact test resultFis <- runTest(GOdata, algorithm = "classic", statistic = "fisher") resultFis ## weight01 is the default algorithm weight01.fisher <- runTest(GOdata, statistic = "fisher") weight01.fisher ## not all combinations are possible! # weight.ks <- runTest(GOdata, algorithm = "weight", statistic = "t")
The GOdata
contains an instance of a topGOdata
object.
It can be used to run an enrichment analysis directly.
The resultFisher
contains the results of an enrichment
analysis.
data(GOdata)
data(GOdata)
Generated using the ALL
gene expression data. See
topGOdata-class
for code examples on how-to generate
such an object.
data(GOdata) ## print the object GOdata data(results.tGO) ## print the object resultFisher
data(GOdata) ## print the object GOdata data(results.tGO) ## print the object resultFisher
This function split the GOTERM environment into three different ontologies. The newly created environments contain each only the terms from one of the following ontologies 'BP', 'CC', 'MF'
groupGOTerms(where)
groupGOTerms(where)
where |
The the environment where you want to bind the results. |
The function returns NULL.
Adrian Alexa
groupGOTerms()
groupGOTerms()
A virtual class containing basic gene set information: the gene universe, the member of the current group, the test statistic defined for this group, etc.
A virtual Class: No objects may be created from it.
name
:Object of class "character"
~~
allMembers
:Object of class "character"
~~
members
:Object of class "character"
~~
testStatistic
:Object of class "function"
~~
testStatPar
:Object of class "ANY"
~~
signature(object = "groupStats")
: ...
signature(object = "groupStats")
: ...
signature(.Object = "groupStats")
: ...
signature(object = "groupStats")
: ...
signature(object = "groupStats")
: ...
signature(object = "groupStats")
: ...
signature(object = "groupStats")
: ...
signature(object = "groupStats")
: ...
signature(object = "groupStats")
: ...
signature(object = "groupStats")
: ...
signature(object = "groupStats")
: ...
Adrian Alexa
classicCount-class
,
getSigGroups-methods
Given a set of nodes (GO terms) this function is returning the subgraph containing these nodes and their ancestors.
inducedGraph(dag, startNodes) nodesInInducedGraph(dag, startNodes)
inducedGraph(dag, startNodes) nodesInInducedGraph(dag, startNodes)
dag |
An object of class |
startNodes |
A character vector giving the starting nodes. |
An object of class graphNEL-class
is returned.
Adrian Alexa
data(GOdata) ## the GO graph g <- graph(GOdata) g ## select 10 random nodes sn <- sample(nodes(g), 10) ## the subgraph induced by these nodes sg <- inducedGraph(g, sn) sg
data(GOdata) ## the GO graph g <- graph(GOdata) g ## select 10 random nodes sn <- sample(nodes(g), 10) ## the subgraph induced by these nodes sg <- inducedGraph(g, sn) sg
Classes that extend the "classicCount" class by adding support for the parent-child test.
Objects can be created by calls of the form new("parentChild", testStatistic, name, groupMembers, parents, sigMembers, joinFun, ...)
.
splitIndex
:Object of class "integer"
~~
joinFun
:Object of class "character"
~~
significant
:Object of class "integer"
~~
name
:Object of class "character"
~~
allMembers
:Object of class "character"
~~
members
:Object of class "character"
~~
testStatistic
:Object of class "function"
~~
testStatPar
:Object of class "list"
~~
Class "classicCount"
, directly.
Class "groupStats"
, by class "classicCount", distance 2.
signature(object = "parentChild")
: ...
signature(object = "parentChild")
: ...
signature(object = "parentChild")
: ...
signature(object = "topGOdata", test.stat = "parentChild")
: ...
signature(.Object = "parentChild")
: ...
signature(object = "parentChild")
: ...
signature(object = "parentChild")
: ...
signature(object = "parentChild")
: ...
signature(object = "parentChild")
: ...
signature(object = "parentChild")
: ...
signature(object = "parentChild", name = "missing", members = "character")
: ...
Adrian Alexa
classicCount-class
,
groupStats-class
,
getSigGroups-methods
showClass("parentChild") showClass("pC")
showClass("parentChild") showClass("pC")
Functions to plot the subgraphs induced by the most significant GO terms
showSigOfNodes(GOdata, termsP.value, firstSigNodes = 10, reverse = TRUE, sigForAll = TRUE, wantedNodes = NULL, putWN = TRUE, putCL = 0, type = NULL, showEdges = TRUE, swPlot = TRUE, useFullNames = TRUE, oldSigNodes = NULL, useInfo = c("none", "pval", "counts", "def", "np", "all")[1], plotFunction = GOplot, .NO.CHAR = 20) printGraph(object, result, firstSigNodes, refResult, ...)
showSigOfNodes(GOdata, termsP.value, firstSigNodes = 10, reverse = TRUE, sigForAll = TRUE, wantedNodes = NULL, putWN = TRUE, putCL = 0, type = NULL, showEdges = TRUE, swPlot = TRUE, useFullNames = TRUE, oldSigNodes = NULL, useInfo = c("none", "pval", "counts", "def", "np", "all")[1], plotFunction = GOplot, .NO.CHAR = 20) printGraph(object, result, firstSigNodes, refResult, ...)
object |
an object of class |
GOdata |
an object of class |
result |
an object of class |
firstSigNodes |
the number of top scoring GO terms which .... |
refResult |
an object of class |
termsP.value |
named vector of p-values. |
reverse |
the direction of the edges. |
sigForAll |
if |
wantedNodes |
the nodes that we want to find, we will plot this nodes with a different color. The vector contains the names of the nodes |
putWN |
the graph is generated with using the firstSigNodes and the wantedNodes. |
putCL |
we generate the graph from the nodes given by all previous parameters, plus their children. if putCL = 1 than only the children are added, if putCL = n we get the nodes form the next n levels. |
type |
used for ploting pie charts |
showEdges |
if |
swPlot |
if true the graph is ploted, if not no ploting is done. |
useInfo |
aditional info to be ploted to each node. |
oldSigNodes |
used to plot the (new) sigNodes in the same collor range as the old ones |
useFullNames |
argument for internal use .. |
plotFunction |
argument for internal use .. |
.NO.CHAR |
argument for internal use .. |
... |
Extra arguments for
|
There are two functions available. The showSigOfNodes
will plot
the induced subgraph to the current graphic device. The
printGraph
is a warping function for showSigOfNodes
and
will save the resulting graph into a PDF or PS file.
In the plots, the significant nodes are represented as rectangles. The plotted graph is the upper induced graph generated by these significant nodes.
Adrian Alexa
groupStats-class
,
getSigGroups-methods
## Not run: data(GOdata) data(results.tGO) showSigOfNodes(GOdata, score(resultFisher), firstSigNodes = 5, useInfo = 'all') printGraph(GOdata, resultFisher, firstSigNodes = 5, fn.prefix = "sampleFile", useInfo = "all", pdfSW = TRUE) ## End(Not run)
## Not run: data(GOdata) data(results.tGO) showSigOfNodes(GOdata, score(resultFisher), firstSigNodes = 5, useInfo = 'all') printGraph(GOdata, resultFisher, firstSigNodes = 5, fn.prefix = "sampleFile", useInfo = "all", pdfSW = TRUE) ## End(Not run)
TODO: The node attributes are environments containing the genes/probes annotated to the respective node
If genes is a numeric vector than this should represent the gene's score. If it is factor it should discriminate the genes in interesting genes and the rest
TODO: it will be a good idea to replace the allGenes and allScore with an ExpressionSet class. In this way we can use tests like global test, globalAncova.... – ALL variables starting with . are just for internal class usage (private)
Objects can be created by calls of the form new("topGOdata", ontology, allGenes, geneSelectionFun, description, annotationFun, ...)
.
~~ describe objects here ~~
description
:Object of class "character"
~~
ontology
:Object of class "character"
~~
allGenes
:Object of class "character"
~~
allScores
:Object of class "ANY"
~~
geneSelectionFun
:Object of class "function"
~~
feasible
:Object of class "logical"
~~
nodeSize
:Object of class "integer"
~~
graph
:Object of class "graphNEL"
~~
expressionMatrix
:Object of class "matrix"
~~
phenotype
:Object of class "factor"
~~
signature(object = "topGOdata")
: ...
signature(object = "topGOdata", attr = "character", whichGO = "character")
: ...
signature(object = "topGOdata", attr = "character", whichGO = "missing")
: ...
signature(object = "topGOdata", whichGO = "character")
: ...
signature(object = "topGOdata", whichGO = "missing")
: ...
signature(object = "topGOdata")
: ...
signature(object = "topGOdata")
: ...
signature(object = "topGOdata")
: ...
signature(object = "topGOdata")
: ...
signature(object = "topGOdata")
: ...
signature(object = "topGOdata")
: ...
signature(object = "topGOdata")
: ...
signature(object = "topGOdata")
: A method for
obtaining the list of genes, as a characther vector, which will be
used in the further analysis.
signature(object = "topGOdata")
: A method for
obtaining the number of genes, which will be used in the further
analysis. It has the same effect as: lenght(genes(object))
.
signature(object = "topGOdata")
: A method for
obtaining the list of significant genes, as a charachter vector.
signature(object = "topGOdata", whichGO = "character")
: ...
signature(object = "topGOdata", whichGO = "missing")
: ...
signature(object = "topGOdata", test.stat = "classicCount")
: ...
signature(object = "topGOdata", test.stat = "classicScore")
: ...
signature(object = "topGOdata")
: ...
signature(object = "topGOdata")
: ...
signature(.Object = "topGOdata")
: ...
signature(object = "topGOdata")
: ...
signature(object = "topGOdata")
: ...
signature(object = "topGOdata", whichGO = "character")
: ...
signature(object = "topGOdata", whichGO = "missing")
: ...
signature(object = "topGOdata", geneList = "numeric", geneSelFun = "function")
: ...
signature(object = "topGOdata", geneList = "factor", geneSelFun = "missing")
: ...
signature(object = "topGOdata", attr = "character")
: ...
signature(object = "topGOdata")
: ...
Adrian Alexa
## load the dataset data(geneList) library(package = affyLib, character.only = TRUE) ## the distribution of the adjusted p-values hist(geneList, 100) ## how many differentially expressed genes are: sum(topDiffGenes(geneList)) ## build the topGOdata class GOdata <- new("topGOdata", ontology = "BP", allGenes = geneList, geneSel = topDiffGenes, description = "GO analysis of ALL data: Differential Expression between B-cell and T-cell", annot = annFUN.db, affyLib = affyLib) ## display the GOdata object GOdata ########################################################## ## Examples on how to use the methods ########################################################## ## description of the experiment description(GOdata) ## obtain the genes that will be used in the analysis a <- genes(GOdata) str(a) numGenes(GOdata) ## obtain the score (p-value) of the genes selGenes <- names(geneList)[sample(1:length(geneList), 10)] gs <- geneScore(GOdata, whichGenes = selGenes) print(gs) ## if we want an unnamed vector containing all the feasible genes gs <- geneScore(GOdata, use.names = FALSE) str(gs) ## the list of significant genes sg <- sigGenes(GOdata) str(sg) numSigGenes(GOdata) ## to update the gene list .geneList <- geneScore(GOdata, use.names = TRUE) GOdata ## more available genes GOdata <- updateGenes(GOdata, .geneList, topDiffGenes) GOdata ## the available genes are now the feasible genes ## the available GO terms (all the nodes in the graph) go <- usedGO(GOdata) length(go) ## to list the genes annotated to a set of specified GO terms sel.terms <- sample(go, 10) ann.genes <- genesInTerm(GOdata, sel.terms) str(ann.genes) ## the score for these genes ann.score <- scoresInTerm(GOdata, sel.terms) str(ann.score) ## to see the number of annotated genes num.ann.genes <- countGenesInTerm(GOdata) str(num.ann.genes) ## to summarise the statistics termStat(GOdata, sel.terms)
## load the dataset data(geneList) library(package = affyLib, character.only = TRUE) ## the distribution of the adjusted p-values hist(geneList, 100) ## how many differentially expressed genes are: sum(topDiffGenes(geneList)) ## build the topGOdata class GOdata <- new("topGOdata", ontology = "BP", allGenes = geneList, geneSel = topDiffGenes, description = "GO analysis of ALL data: Differential Expression between B-cell and T-cell", annot = annFUN.db, affyLib = affyLib) ## display the GOdata object GOdata ########################################################## ## Examples on how to use the methods ########################################################## ## description of the experiment description(GOdata) ## obtain the genes that will be used in the analysis a <- genes(GOdata) str(a) numGenes(GOdata) ## obtain the score (p-value) of the genes selGenes <- names(geneList)[sample(1:length(geneList), 10)] gs <- geneScore(GOdata, whichGenes = selGenes) print(gs) ## if we want an unnamed vector containing all the feasible genes gs <- geneScore(GOdata, use.names = FALSE) str(gs) ## the list of significant genes sg <- sigGenes(GOdata) str(sg) numSigGenes(GOdata) ## to update the gene list .geneList <- geneScore(GOdata, use.names = TRUE) GOdata ## more available genes GOdata <- updateGenes(GOdata, .geneList, topDiffGenes) GOdata ## the available genes are now the feasible genes ## the available GO terms (all the nodes in the graph) go <- usedGO(GOdata) length(go) ## to list the genes annotated to a set of specified GO terms sel.terms <- sample(go, 10) ann.genes <- genesInTerm(GOdata, sel.terms) str(ann.genes) ## the score for these genes ann.score <- scoresInTerm(GOdata, sel.terms) str(ann.score) ## to see the number of annotated genes num.ann.genes <- countGenesInTerm(GOdata) str(num.ann.genes) ## to summarise the statistics termStat(GOdata, sel.terms)
Class instance created by
getSigGroups-methods
or by runTest
Objects can be created by calls of the form new("topGOresult",
description, score, testName, algorithm, geneData)
.
description
:character string containing a short description on how the object was build.
score
:named numerical vector containing the p-values or the scores of the tested GO terms.
testName
:character string containing the name of the test statistic used.
algorithm
:character string containing the name of the algorithm used.
geneData
:list containing summary statistics on the genes/gene universe/annotations.
score
:method to access the score
slot.
testName
:method to access the testName
slot.
algorithm
:method to access the algorithm
slot.
geneData
:method to access the geneData
slot.
show
:method to print the object.
combineResults
:method to aggregate two or more
topGOresult objects. method = c("gmean", "mean", "median",
"min", "max")
provides the way the object scores (which most of
the time are p-values) are combined.
.
Adrian Alexa
groupStats-class
,
getSigGroups-methods
data(results.tGO) s <- score(resultFisher) go <- sort(names(s)) go.sub<- sample(go, 100) go.mixed <- c(sample(go, 50), sample(ls(GOCCTerm), 20)) go.others <- sample(ls(GOCCTerm), 100) str(go) str(go.sub) str(go.mixed) str(go.others) str(score(resultFisher, whichGO = go)) str(score(resultFisher, whichGO = go.sub)) str(score(resultFisher, whichGO = go.mixed)) str(score(resultFisher, whichGO = go.others)) avgResult <- combineResults(resultFisher, resultKS) avgResult combineResults(resultFisher, resultKS, method = "min")
data(results.tGO) s <- score(resultFisher) go <- sort(names(s)) go.sub<- sample(go, 100) go.mixed <- c(sample(go, 50), sample(ls(GOCCTerm), 20)) go.others <- sample(ls(GOCCTerm), 100) str(go) str(go.sub) str(go.mixed) str(go.others) str(score(resultFisher, whichGO = go)) str(score(resultFisher, whichGO = go.sub)) str(score(resultFisher, whichGO = go.mixed)) str(score(resultFisher, whichGO = go.others)) avgResult <- combineResults(resultFisher, resultKS) avgResult combineResults(resultFisher, resultKS, method = "min")
~~ A concise (1-5 lines) description of what the class is. ~~
TODO: Some details here.....
Objects can be created by calls of the form new("weightCount", testStatistic, name, allMembers, groupMembers, sigMembers, weights, sigRatio, penalise, ...)
.
weights
:Object of class "numeric"
~~
sigRatio
:Object of class "function"
~~
penalise
:Object of class "function"
~~
roundFun
:Object of class "function"
~~
significant
:Object of class "integer"
~~
name
:Object of class "character"
~~
allMembers
:Object of class "character"
~~
members
:Object of class "character"
~~
testStatistic
:Object of class "function"
~~
testStatPar
:Object of class "list"
~~
Class "classicCount"
, directly.
Class "groupStats"
, by class "classicCount", distance 2.
No methods defined with class "weightCount" in the signature.
Adrian Alexa
groupStats-class
,
getSigGroups-methods