Skip to main content
PLOS ONE logoLink to PLOS ONE
. 2018 Nov 9;13(11):e0206864. doi: 10.1371/journal.pone.0206864

A simple null model for inferences from network enrichment analysis

Gustavo S Jeuken 1, Lukas Käll 1,*
Editor: Junwen Wang2
PMCID: PMC6226187  PMID: 30412619

Abstract

A prevailing technique to infer function from lists of identifications, from molecular biological high-throughput experiments, is over-representation analysis, where the identifications are compared to predefined sets of related genes often referred to as pathways. As at least some pathways are known to be incomplete in their annotation, algorithmic efforts have been made to complement them with information from functional association networks. While the terminology varies in the literature, we will here refer to such methods as Network Enrichment Analysis (NEA). Traditionally, the significance of inferences from NEA has been assigned using a null model constructed from randomizations of the network. Here we instead argue for a null model that more directly relates to the set of genes being studied, and have designed one dynamic programming algorithm that calculates the score distribution of NEA scores that makes it possible to assign unbiased mid p values to inferences. We also implemented a random sampling method, carrying out the same task. We demonstrate that our method obtains a superior statistical calibration as compared to the popular NEA inference engine, BinoX, while also providing statistics that are easier to interpret.

Introduction

Over-Representation Analysis (ORA) is commonly used to infer function from sets of analytes such as genes, transcripts, proteins or metabolites [13]. The technique estimates which functional modules, such as complexes or pathways, are overrepresented among a set of identified analytes. One prominent application of the technique is expression analysis, where ORA is regularly used to assess alternation in pathway activity by examining significantly different concentrations of analytes between biological conditions, such as disease state or treatment group. Most ORA methods are assessing the overlap between the investigated set of analytes, the query set, and a functional module, the pathway set, using hypergeometric test or a Fisher’s exact test. However, variants such as Gene Set Enrichment Analysis (GSEA) [4] also includes information on expression levels of the analytes of the query set.

A limiting factor of ORA is the quality of the databases defining pathways. While http://pathguide.org list 708 databases of pathway definitions [5], some critique has been voiced concerning the completeness and rigour of current pathway databases. Hence, efforts have been directed to designing methods that extend the pathway definitions, by functional association networks, like STRING [6] and FunCoup [7]. Instead of directly examining the overlap between the query and pathway sets, one can evaluate the number of links in the functional association network that connect the query and pathway set [812]. We will refer to such methods as Network Enrichment Analysis (NEA), although the concept also is known as crosstalk analysis.

The significance of the inferences from NEA is assessed by null models that investigate the number of expected random links from the query gene set to the pathway. Previous efforts have settled for network randomization, where the network definitions are randomly constructed by methods with varying degrees of topological conservation in respect to the original network. Yet, the methods that are used for network randomization are often mentally untractable, as they include a big number of steps that are subject to complex constraints. As an example, in the link assignment plus second-order conservation method [10], links are assigned at random, but sequentially and at each step they must follow constraints that depend on previous link assignments. While this results in a network that is both randomized and contains some desired topological features, preserved from the original network, these nested constraints make it very hard to verify that the resulting network is representative.

In theory there is a space of all possible networks that could be made up from a certain number of nodes and node degree distribution, however, it is not clear that the link assignment and second-order conservation method samples evenly from that distribution. And, if the resulting networks are not representative, the rejection of the resulting null hypothesis is uninformative, defeating the purpose of the statistical test.

We argue that the network perturbation methods used in most flavours of NEA are missleading. Users of NEA do not differ from users of ORA, they want to test an association between a query set of genes and pathways. The typical user has used an experimental or computational method to derive a set of query genes and wants to know if it is a random set, or if it is enriched with respect to a pathway. In this question, the introduction of a network is not relevant. A network may help to increase the sensitivity of ORA methods, but for practical reasons it is better left out of the null hypothesis. Tests of significance in this type of analysis is naturally implemented as tests of the query set. That is, is the query set a randomly selected set of genes or is there an over-representation of well-connected genes in the query set?

Hence, here we employ a different null model, more directly aimed at modelling the lack of association between query and pathway gene sets, which we formulate as “there are not more links between the query and pathway gene sets than expected by chance”. Here, we present a dynamic programming algorithm, which we dubbed GeneSetDP, that calculates the exact score distribution of any query of a given size. We also implemented one random sampling algorithm for the same task, that we called GeneSetMC. Both algorithms circumvent the need of network pertubations for the calculations of significance. Combining the GeneSetDP and GeneSetMC with the scoring system of the popular method BinoX, we use simulations to demonstrate that both our algorithms produced unbiased statistics.

Algorithms

In network-based gene set analysis one scores a query set of genes, Q={g1gQ}, from a genome with genes, G={g1gG} (i.e. QG), and how they relate to a pathway, P={p1pP}. In NEA the pathway maps to the genome through a network, xij, where xij = 1 if gi and pj are connected, or xij = 0 otherwise. The pathways are scored by summing up all connections, i.e. the pathway score can be expressed as,

s=i=1Qj=1Pxij. (1)

We wanted to evaluate our score under the null hypothesis, H0: “There are not more links between the query and pathway gene sets than expected by chance”. This formulation translates to calculating the distribution of scores that would occur if the Q query genes are randomly selected from the genome, and see how frequently a score as extreme or more extreme than the current score would appear in that distribution. Hence, we wanted to determine a score distribution, i.e. the number of ways, N(s), we can pick Q genes and obtain a score, s, which we will give two methods for below. Given such a score distribution, we can express a mid p value [13, 14] for obtaining a score, s, as,

p(s)=N(s)/2+s=s+1SN(s)s=0SN(s), (2)

where S is the maximal score, s, that Q genes can obtain from Eq (1).

We can reformulate Eq (1) by defining the number of links, li=j=1Pxij, which gives us a score,

s=i=1Qli. (3)

Such a number of links, li, can be pre-computed for all genes in G. For later purposes we also define a mapping, ka = ∑{i:li=a} 1, giving the number of genes having, a, links to the investigated pathway.

Random sampling algorithm

We first implemented a random sampling algorithm to assess N(s). We randomly selected sets of Q genes from G. These sets scores were calculated with Eq (3). We counted the number of times, FB(s), a score of s was obtained when sampling B gene sets. We see that FB(s) will approximately have the same shape as N(s) when selecting a large B, and we can hence calculate p values by replacing N with FB in Eq (2). We refer to this procedure as GeneSetMC.

Computation of the score distribution

An alternative approach is to calculate the exact score distribution using dynamic programming. This can be done if we formulate N(s) as a recursion, by observing a partial sum function, Na(s, c), which expresses the number of ways to select a set of c query genes, each with ≤ a links to the pathway set and obtain a score of s. If we know the distribution of the number of ways to select genes with ≤ a − 1 genes, Na−1(s, c), for all s and c, Na(s, c) can be determined by investigating the ways to select genes with exactly a links to the investigated pathway. As there are (kab) ways to select b from ka elements, there contribution to Na(s, c) from the selection of b genes with exactly a links are (kab)Na1(sab,cb). When evaluating all possible values of b we see that

Na(s,c)=b=0ka(kab)Na1(sab,cb). (4)

We also see that Na(s, c) = 0 for all s < 0, c < 0 or a < 0, with the exception of N−1(0, 0) = 1.

The final score distribution is given by N(s) = NR(s, Q), where R = maxi li, i.e the largest number of links to the pathway from any gene in the genome.

Listing 1. The central part of the dynamic programing algorithm for finding N(s). The function takes the vector of links per gene, ka, as well as the number of query genes, Q as an input. The function depends on two additional functions find_maxscore(k,Q), which calculates the maximal score a query of size Q can obtain, and comb(a,b), which calculates (ab).

def genesetdp (k, Q):

 max_s = find_maxscore (k, Q)

 N = np.zeros ((max_s+1,Q+1))

 N[0, 0] = 1

for a in range (len (k)):

  for s in range (max_s, −1, −1):

   for c in range (Q, −1, −1):

    for b in range (k [a], 0, −1): # Stop at b = 1

     if c−b>=0 and s−a*b>=0:

      N[s, c] += comb(k [a], b) * N[s−a*b, c−b]

return N[:, q]

Implementation

There is a memory efficient implementation. We first note that

Na(s,c)=b=0ka(kab)Na1(sab,cb)=b=1ka(kab)Na1(sab,cb)+Na1(s,c).

This enables us to calculate N in-place, at least as long as we update the elements in Na in a reverse order so that we do not alter elements from Na−1 still needed to update subsequent elements. That is, we do not have to copy the dynamic programming matrix in each iteration over a, instead, we can add b=1ka(kab)Na1(sab,cb) to previous iterations Na−1(s, c), by nested updates over s ∈ {S, S − 1, …, 0} and c ∈ {Q, Q − 1, …, 0}. For details see Listing 1. We refer to this method as GeneSetDP.

Methods

We downloaded network definitions and the BinoX software (on 2018-04-28) for comparisons from https://bitbucket.org/sonnhammergroup/binox. BinoX was run with the default parameters.

We also downloaded the NEA example given at the BinoX web site. The example files include a pathway definition file that groups 6819 genes into 289 human pathways and a network definition file that, after thresholding the links with a score of 0.7, gave 1244992 links between those genes.

For the purpose of demonstrating our argument, we selected a representative example in the “Glycolysis/Gluconeogenesis” pathway, as it contained a number of genes that coincided with the median number of genes of the pathways in the definition file.

Results

We implemented a Python program that reads network and pathway definition files and scores a query sets against a pathway according to Eq (3), using GeneSetDP and GeneSetMC described in the Algorithm section, that enabled us to assign p values according to Eq (2). We downloaded pathway and network definitions from the BinoX’s website and used the same network threshold as BinoX default (0.7).

To illustrate the p value calculation procedure, we plotted the score distributions N(s) for a query size of 10, 20 and 30 genes in Fig 1, using GeneSetDP.

Fig 1. Score distribution of a query size of 10, 20 and 30 genes against the “Glycolysis/Gluconeogenesis” pathway.

Fig 1

GeneSetDP enables us to calculate the full score distribution for a query of a given size, Q, i.e. how many ways one can reach a certain score when adding up the scores for Q genes. A red dot marks the maximum score, S, for each case.

Test of calibration

In order to test the statistical calibration of our method, we calculated p values for 10000 random picks of gene sets of size Q from the investigated genome using both GeneSetDP and GeneSetMC with B = 100000. As our selection is random and following our null hypothesis, we expected the resulting p values to be uniformly distributed. To test this we plotted the p values against their quantile in Fig 2 for 10000 randomly assembled queries from the human genome. As a comparison, we also added a calibration curve, under our null hypothesis, for the popular NEA method BinoX [11]. Here, for all three methods, we are only testing the queries for enrichment, that is, we are only concerned with a higher number of links than expected by random, and this differs from the default BinoX setting which tests for both enrichment and depletion.

Fig 2. Calibration of GeneSetDP and GeneSetMC.

Fig 2

We selected 10000 random sets of 10, 20 and 30 genes from the investigated genome definition and calculated their p values with GeneSetMC and GeneSetDP against the “Glycolysis/Gluconeogenesis” pathway. To test the p values uniformity we plotted them against their normalized rank, i.e. each p value’s (<rank>-0.5)/<total number of p values>. We also added the calibration curve of BinoX, evaluated on the same random sets. The dashed line shows y = x and the dotted lines y = 2x and y = 0.5x, for comparison.

We note that the calibration of GeneSetDP is slightly conservative, i.e. the calculated p values are larger than expected. Meanwhile, BinoX appears strongly anti-conservative, that is, the p values are lower than expected, even when not taking into account significance by depletion.

To test the consistency of the methods, we also investigated the correspondence between the p values reported by GeneSetDP and GeneSetMC. As can be seen in Fig 3, the results are consistent as expected.

Fig 3. Correspondence between GeneSetDP’s and GeneSetMC’s p values.

Fig 3

We selected 10000 random sets of 10, 20 and 30 genes from the investigated genome definition and calculated their p values with GeneSetMC and GeneSetDP against the “Glycolysis/Gluconeogenesis” pathway. We subsequently plotted the obtained p values against each other. Again, the dashed line shows y = x and the dotted lines y = 2x and y = 0.5x.

Discussion

Here we have implemented two methods, GeneSetDP and GeneSetMC, to calculate unbiased p values for inferences from NEA. Instead of testing our methods’ performance in terms of sensitivity, we here instead chose to test the method in terms of the methods statistical accuracy. We argue that more studies should make a point at demonstrating that their methods are well-calibrated, as it is a prerequisite for measuring performance, most importantly when the ground truth of biological effect is not known.

Both our implementations, GeneSetDP and GeneSetMC, are intended for measuring the enrichment of links between the query and the pathway set of genes. Most other NEA methods also report depletion of such links. One could easily modify our code to, instead of only measuring the higher scoring tail, measuring both tails of N(s). However, this might result in a drop in sensitivity, so we have so far not implemented such a mechanism.

We made an explicit definition of the null hypothesis we employed, which centers on the query, H0: “There are not more links between the query and pathway gene sets than expected by chance”. Previous implementations of NEA in the literature use network randomization methods to determine parameters for various types parametric distributions, by perturbations of the investigated network. In practice, such perturbations are very heuristic in their nature, and hence are difficult to use for calculating accurate statistics. Generally, it is easier to understand null models that relate to user actions.

Furthermore, network randomization methods focus on significance of the links in the network instead of the query set itself. In effect, NEA is an attempt to increase the sensitivity of ORA. The standard user of NEA would typically have identified a set of query genes which she wants to evaluate for over-representation in respect to a pathway database. This goal is the same as for users of ORA. Hence, the null model should be of the same nature for NEA and ORA. GeneSetDP and GeneSetMC are two algorithms that prove that one in NEA can test the uniqueness of the query set in respect to a pathway, just as done in ORA.

Acknowledgments

LK was supported by a grant from the Swedish Foundation for Strategic Research (BD15-0043).

Data Availability

Data are available from the following repositories: https://github.com/statisticalbiotechnology/genesetdphttps://bitbucket.org/sonnhammergroup/binox.

Funding Statement

LK was supported by a grant from the Swedish Foundation for Strategic Research (BD15-0043).

References

  • 1.Tavazoie S, Hughes JD, Campbell MJ, Cho RJ, Church GM. Systematic determination of genetic network architecture. Nature genetics. 1999;22(3):281 10.1038/10343 [DOI] [PubMed] [Google Scholar]
  • 2.Khatri P, Sirota M, Butte AJ. Ten years of pathway analysis: current approaches and outstanding challenges. PLoS computational biology. 2012;8(2):e1002375 10.1371/journal.pcbi.1002375 [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 3.Goeman JJ, Bühlmann P. Analyzing gene expression data in terms of gene sets: methodological issues. Bioinformatics. 2007;23(8):980–987. 10.1093/bioinformatics/btm051 [DOI] [PubMed] [Google Scholar]
  • 4.Subramanian A, Tamayo P, Mootha VK, Mukherjee S, Ebert BL, Gillette MA, et al. Gene set enrichment analysis: a knowledge-based approach for interpreting genome-wide expression profiles. Proceedings of the National Academy of Sciences. 2005;102(43):15545–15550. 10.1073/pnas.0506580102 [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 5.Bader GD, Cary MP, Sander C. Pathguide: a pathway resource list. Nucleic acids research. 2006;34(suppl_1):D504–D506. 10.1093/nar/gkj126 [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 6.Szklarczyk D, Franceschini A, Wyder S, Forslund K, Heller D, Huerta-Cepas J, et al. STRING v10: protein–protein interaction networks, integrated over the tree of life. Nucleic acids research. 2014;43(D1):D447–D452. 10.1093/nar/gku1003 [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 7.Ogris C, Guala D, Kaduk M, Sonnhammer EL. FunCoup 4: new species, data, and visualization. Nucleic acids research. 2017;46(D1):D601–D607. 10.1093/nar/gkx1138 [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 8.Alexeyenko A, Lee W, Pernemalm M, Guegan J, Dessen P, Lazar V, et al. Network enrichment analysis: extension of gene-set enrichment analysis to gene networks. BMC bioinformatics. 2012;13(1):226 10.1186/1471-2105-13-226 [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 9.Glaab E, Baudot A, Krasnogor N, Schneider R, Valencia A. EnrichNet: network-based gene set enrichment analysis. Bioinformatics. 2012;28(18):i451–i457. 10.1093/bioinformatics/bts389 [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 10.McCormack T, Frings O, Alexeyenko A, Sonnhammer EL. Statistical assessment of crosstalk enrichment between gene groups in biological networks. PloS one. 2013;8(1):e54945 10.1371/journal.pone.0054945 [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 11.Ogris C, Guala D, Helleday T, Sonnhammer EL. A novel method for crosstalk analysis of biological networks: improving accuracy of pathway annotation. Nucleic acids research. 2016;45(2):e8–e8. 10.1093/nar/gkw849 [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 12.Signorelli M, Vinciotti V, Wit EC. NEAT: an efficient network enrichment analysis test. BMC bioinformatics. 2016;17(1):352 10.1186/s12859-016-1203-6 [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 13.Lancaster HO. Significance tests in discrete distributions. Journal of the American Statistical Association. 1961;56(294):223–234. 10.1080/01621459.1961.10482105 [DOI] [Google Scholar]
  • 14.Hwang JG, Yang MC. An optimality theory for mid p–values In 2× 2 contingency tables. Statistica Sinica. 2001; p. 807–826. [Google Scholar]

Associated Data

This section collects any data citations, data availability statements, or supplementary materials included in this article.

Data Availability Statement

Data are available from the following repositories: https://github.com/statisticalbiotechnology/genesetdphttps://bitbucket.org/sonnhammergroup/binox.


Articles from PLoS ONE are provided here courtesy of PLOS

RESOURCES