Network motif

Network motif

All networks, including biological networks, social networks, technological networks (e.g., computer networks and electrical circuits) and more, can be represented as graphs, which include a wide variety of subgraphs. One important local property of networks are so-called network motifs, which are defined as recurrent and statistically significant sub-graphs or patterns.

Motifs, sub-graphs that repeat themselves in a specific network or even among various networks, would be consistent with the tenets of evolutionary theory. Each of these sub-graphs, defined by a particular pattern of interactions between vertices, may reflect a framework in which particular functions are achieved efficiently. Indeed, motifs are of notable importance largely because they may reflect functional properties. They have recently gathered much attention as a useful concept to uncover structural design principles of complex networks.[1] Although network motifs may provide a deep insight into the network’s functional abilities, their detection is computationally challenging.


  • Definition 1
  • History 2
  • Motif Discovery Algorithms 3
    • mfinder 3.1
    • FPF (Mavisto) 3.2
    • ESU (FANMOD) 3.3
    • NeMoFinder 3.4
    • Grochow-Kellis 3.5
    • Color-Coding Approach 3.6
    • MODA 3.7
    • Kavosh 3.8
    • G-Tries 3.9
    • Comparison 3.10
    • Classification of Algorithms 3.11
  • Well-Established Motifs and Their Functions 4
    • Negative auto-regulation (NAR) 4.1
    • Positive auto-regulation (PAR) 4.2
    • Feed-forward loops (FFL) 4.3
    • Coherent type 1 FFL (C1-FFL) 4.4
    • Incoherent type 1 FFL (I1-FFL) 4.5
    • Multi-output FFLs 4.6
    • Single-input modules (SIM) 4.7
    • Dense overlapping regulons (DOR) 4.8
  • Activity motifs 5
  • Criticism 6
  • See Also 7
  • References 8
  • External links 9


Let G = (V, E) and G′ = (E′, V′) be two graphs. Graph G′ is a sub-graph of graph G (written as G′ ⊆ G) if V′ ⊆ V and E′ ⊆ E ∩ (V′ × V′). If G′ ⊆ G and G′ contains all of the edges ‹u, v› ∈ E with u, v ∈ V′, then G′ is an induced sub-graph of G. We call G′ and G isomorphic (written as G′ ↔ G), if there exists a bijection (one-to-one) f:V′ → V with ‹u, v› ∈ E′ ⇔ ‹f(u), f(v)› ∈ E for all u, v ∈ V′. The mapping f is called an isomorphism between G and G′.[2]

When G″ ⊂ G and there exist an isomorphism between the sub-graph G″ and a graph G′, this mapping represents an appearance of G′ in G. The number of appearances of graph G′ in G is called the frequency FG of G′ in G. A graph is called recurrent (or frequent) in G, when its frequency FG(G′) is above a predefined threshold or cut-off value. We used terms pattern and frequent sub-graph in this review interchangeably. There is an ensemble Ω(G) of random graphs corresponding to the null-model associated to G. We should choose N random graphs uniformly from Ω(G) and calculate the frequency for a particular frequent sub-graph G′ in G. If the frequency of G′ in G is higher than its arithmetic mean frequency in N random graphs Ri, where 1 ≤ i ≤ N, we call this recurrent pattern significant and hence treat G′ as a network motif for G. For a small graph G′, the network G and a set of randomized networks R(G) ⊆ Ω(R), where , the Z-Score that has been defined by the following formula:

Z(G^\prime) = \frac{F_G(G^\prime) - \mu_R(G^\prime)}{\sigma_R(G^\prime)}

where μR(G′) and σR(G′) stand for mean and standard deviation frequency in set R(G), respectively.[3][4][5][6][7][8] The larger the Z(G′), the more significant is the sub-graph G′ as a motif. Alternatively, another measurement in statistical hypothesis testing that can be considered in motif detection is the P-Value, given as the probability of FR(G′) ≥ FG(G′) (as its null-hypothesis), where FR(G′) indicates the frequency of G' in a randomized network.[6] A sub-graph with P-value less than a threshold (commonly 0.01 or 0.05) will be treated as a significant pattern. The P-value is defined as

P(G^\prime) = \frac{1}{N}\sum_{i=1}^N \delta(c(i)) ; c(i): F_R^i(G^\prime) \ge F_G(G^\prime)

Different occurrences of a sub-graph in a graph. (M1 – M4) are different occurrences of sub-graph (b) in graph (a). For frequency concept F1, the set M1, M2, M3, M4 represent all matches, so F1 = 4. For F2, one of the two set M1, M4 or M2, M3 are possible matches, F2 = 2. Finally, for frequency concept F3, merely one of the matches (M1 to M4) is allowed, therefore F3 = 1. The frequency of these three frequency concepts decrease as the usage of network elements are restricted.

Where N indicates number of randomized networks, i is defined over an ensemble of randomized networks and the Kronecker delta function δ(c(i)) is one if the condition c(i) holds. The concentration [9][10] of a particular n-size sub-graph G′ in network G refers to the ratio of the sub-graph appearance in the network to the total n-size non-isomorphic sub-graphs’ frequencies, which is formulated by

C_G(G^\prime) = \frac{F_G(G^\prime)}{\sum_i F_G(G_i)}

where index i is defined over the set of all non-isomorphic n-size graphs. Another statistical measurement is defined for evaluating network motifs, but it is rarely used in known algorithms. This measurement is introduced by Picard et al. in 2008 and used the Poisson distribution, rather than the Gaussian normal distribution that is implicitly being used above.[11]

In addition, three specific concepts of sub-graph frequency have been proposed.[12] As figure illustrates, the first frequency concept F1 considers all matches of a graph in original network. This definition is similar to what we have introduced above. The second concept F2 is defined as the maximum number of edge-disjoint instances of a given graph in original network. And finally, the frequency concept F3 entails matches with disjoint edges and nodes. Therefore, the two concepts F2 and F3 restrict the usage of elements of the graph, and as can be inferred, the frequency of a sub-graph declines by imposing restrictions on network element usage. As a result, a network motif detection algorithm would pass over more candidate sub-graphs if we insist on frequency concepts F2 and F3.


This idea was first presented in 2002 by Uri Alon and his group [13] when network motifs were discovered in the gene regulation (transcription) network of the bacteria E. coli and then in a large set of natural networks. Since then, a considerable number of studies have been conducted on the subject. Some of these studies focus on the biological applications, while others focus on the computational theory of network motifs.

The biological studies endeavor to interpret the motifs detected for biological networks. For example, in work following,[13] the network motifs found in E. coli Much experimental work has been devoted to understanding network motifs in

Well-Established Motifs and Their Functions

Addresses of Designers of Algorithms
Algorithm Lab / Dept. Name Department / School Institute Address E-Mail
mfinder Uri Alon's Group Department of Molecular Cell Biology Weizmann Institute of Science Rehovot, Israel, Wolfson, Rm. 607 urialon at
FPF (Mavisto) ---- ---- Leibniz-Institut für Pflanzengenetik und Kulturpflanzenforschung (IPK) Corrensstraße 3, D-06466 Stadt Seeland, OT Gatersleben, Deutschland schreibe at
ESU (FANMOD) Lehrstuhl Theoretische Informatik I Institut für Informatik Friedrich-Schiller-Universität Jena Ernst-Abbe-Platz 2,D-07743 Jena, Deutschland sebastian.wernicke at
NeMoFinder ---- School of Computing National University of Singapore Singapore 119077 chenjin at
Grochow-Kellis Theory Group Computer Science The University of Chicago 1100 East 58th Street, Chicago, IL 60637 joshuag at
N. Alon et al.’s Algorithm Department of Pure Mathematics School of Mathematical Sciences Tel Aviv University Tel Aviv 69978, Israel nogaa at
MODA Laboratory of Systems Biology and Bioinformatics (LBB) Institute of Biochemistry and Biophysics (IBB) University of Tehran Enghelab Square, Enghelab Ave, Tehran, Iran amasoudin at
Kavosh (used in CytoKavosh) Laboratory of Systems Biology and Bioinformatics (LBB) Institute of Biochemistry and Biophysics (IBB) University of Tehran Enghelab Square, Enghelab Ave, Tehran, Iran amasoudin at
G-Tries Center for Research in Advanced Computing Systems Computer Science University of Porto Rua Campo Alegre 1021/1055, Porto, Portugal pribeiro at
Classification of Motif Discovery Algorithms
Counting Method Basis Name Directed / Undirected Induced / Non-Induced
Exact Network-Centric mfinder Both Induced
ESU (FANMOD) Both Induced
Kavosh (used in CytoKavosh) Both Induced
G-Tries Both Induced
Subgraph-Centric FPF (Mavisto) Both Induced
NeMoFinder Undirected Induced
Grochow-Kellis Both Both
MODA Both Both
Estimation / Sampling Color-Coding Approach N. Alon et al.’s Algorithm Undirected Non-Induced
Other Approaches mfinder Both Induced
ESU (FANMOD) Both Induced

Furthermore, table indicates whether an algorithm can be used for directed or undirected networks as well as induced or non-induced subgraphs. For more information refer to the provided web links or lab addresses.

On the other hand, estimation methods might utilize color-coding approach as described before. Other approaches used in this category usually skip some subgraphs during enumeration (e.g., as in FANMOD) and base their estimation on the enumerated subgraphs.

In the next level, the exact counting algorithms can be classified to network-centric and subgraph-centric methods. The algorithms of the first class search the given network for all subgraphs of a given size, while the algorithms falling into the second class first generate different possible non-isomorphic graphs of the given size, and then explore the network for each generated subgraph separately. Each approach has its advantages and disadvantages which are discussed above.

As seen in the table, motif discovery algorithms can be divided into two general categories: those based on exact counting and those using statistical sampling and estimations instead. Because the second group does not count all the occurrences of a subgraph in the main network, the algorithms belonging to this group are faster, but they might yield in biased and unrealistic results.

Classification of Algorithms

Runtimes of mfinder, FANMOD, Mavisto and Kavosh for subgraphs from three nodes up to ten nodes on three different networks.[35]
  Size → 3 4 5 6 7 8 9 10
Networks ↓ Algorithms ↓
E. coli Kavosh 0.30 1.84 14.91 141.98 1374.0 13173.7 121110.3 1120560.1
FANMOD 0.81 2.53 15.71 132.24 1205.9 9256.6 - -
Mavisto 13532 - - - - - - -
Mfinder 31.0 297 23671 - - - - -
Electronic Kavosh 0.08 0.36 8.02 11.39 77.22 422.6 2823.7 18037.5
FANMOD 0.53 1.06 4.34 24.24 160 967.99 - -
Mavisto 210.0 1727 - - - - - -
Mfinder 7 14 109.8 2020.2 - - - -
Social Kavosh 0.04 0.23 1.63 10.48 69.43 415.66 2594.19 14611.23
FANMOD 0.46 0.84 3.07 17.63 117.43 845.93 - -
Mavisto 393 1492 - - - - - -
Mfinder 12 49 798 181077 - - - -
Runtimes of Grochow-Kellis, FANMOD, and G-Trie for subgraphs from three nodes up to nine nodes on five different networks.[37]
Network Size Census Original Network Average Census on Random Networks
Dolphins 5 0.07 0.03 0.01 0.13 0.04 0.01
6 0.48 0.28 0.04 1.14 0.35 0.07
7 3.02 3.44 0.23 8.34 3.55 0.46
8 19.44 73.16 1.69 67.94 37.31 4.03
9 100.86 2984.22 6.98 493.98 366.79 24.84
Circuit 6 0.49 0.41 0.03 0.55 0.24 0.03
7 3.28 3.73 0.22 3.53 1.34 0.17
8 17.78 48.00 1.52 21.42 7.91 1.06
Social 3 0.31 0.11 0.02 0.35 0.11 0.02
4 7.78 1.37 0.56 13.27 1.86 0.57
5 208.30 31.85 14.88 531.65 62.66 22.11
Yeast 3 0.47 0.33 0.02 0.57 0.35 0.02
4 10.07 2.04 0.36 12.90 2.25 0.41
5 268.51 34.10 12.73 400.13 47.16 14.98
Power 3 0.51 1.46 0.00 0.91 1.37 0.01
4 1.38 4.34 0.02 3.01 4.40 0.03
5 4.68 16.95 0.10 12.38 17.54 0.14
6 20.36 95.58 0.55 67.65 92.74 0.88
7 101.04 765.91 3.36 408.15 630.65 5.17
Runtimes of Grochow-Kellis, mfinder, FANMOD, FPF and MODA for subgraphs from three nodes up to nine nodes.[32]

Tables and figure below show the results of running the mentioned algorithms on different standard networks. These results are taken from the corresponding sources,[32][35][37] thus they should be treated individually.


Among the mentioned algorithms, G-Tries is the fastest. But, the excessive use of memory is the drawback of this algorithm, which might limit the size of discoverable motifs by a personal computer with average memory.

A g-trie is a multiway tree that can store a collection of graphs. Each tree node contains information about a single graph vertex and its corresponding edges to ancestor nodes. A path from the root to a leaf corresponds to one single graph. Descendants of a g-trie node share a common sub-graph. Constructing a g-trie is well described in.[37] After constructing a g-trie, the counting part takes place. The main idea in counting process is to backtrack by all possible sub-graphs, but at the same time do the isomorphism tests. This backtracking technique is essentially the same technique employed by other motif-centric approaches like MODA and GK algorithms. Taking advantage of common substructures in the sense that at a given time there is a partial isomorphic match for several different candidate sub-graphs.

In 2010, Pedro Ribeiro and Fernando Silva proposed a novel data structure for storing a collection of sub-graphs, called a g-trie.[37] This data structure, which is conceptually akin to a prefix tree, stores sub-graphs according to their structures and finds occurrences of each of these sub-graphs in a larger graph. One of the noticeable aspects of this data structure is that coming to the network motif discovery, the sub-graphs in the main network are needed to be evaluated. So, there is no need to find the ones in random network which are not in the main network. This can be one of the time-consuming parts in the algorithms in which all sub-graphs in random networks are derived.


Recently a Cytoscape plugin called CytoKavosh [36] is developed for this software. It is available via Cytoscape web page [1].

Enumeration of Kavosh
Enumerate_Vertex(G, u, S, Remainder, i)

Input: G: Input graph
 u: Root vertex
 S: selection (S = { S0,S1,...,Sk-1} is an array of the set of all Si)
 Remainder: number of remaining vertices to be selected
 i: Current depth of the tree.
Output: all k-size sub-graphs of graph G rooted in u.

if Remainder = 0 then
 ValList ← Validate(G, Si-1, u)
 niMin(|ValList|, Remainder)
 for ki = 1 to ni do
 C ← Initial_Comb(ValList, ki)
 (Make the first vertex combination selection according)
 Si ← C
 Enumerate_Vertex(G, u, S, Remainder-ki, i+1)
 Next_Comb(ValList, ki)
 (Make the next vertex combination selection according)
 until C = NILL
 end for
 for each v ∈ ValList do
 Visited[v] ← false
 end for
end if

Validate(G, Parents, u)

Input: G: input graph, Parents: selected vertices of last layer, u: Root vertex.
Output: Valid vertices of the current level.

ValList ← NILL
for each v ∈ Parents do
 for each w ∈ Neighbor[u] do
 if label[u] < label[w] AND NOT Visited[w] then
 Visited[w] ← true
 ValList = ValList + w
 end if
 end for
end for
return ValList

The protocol for extracting sub-graphs makes use of the compositions of an integer. For the extraction of sub-graphs of size k, all possible compositions of the integer k-1 must be considered. The compositions of k-1 consist of all possible manners of expressing k-1 as a sum of positive integers. Summations in which the order of the summands differs are considered distinct. A composition can be expressed as k2,k3,…,km where k2 + k3 + … + km = k-1. To count sub-graphs based on the composition, ki nodes are selected from the i-th level of the tree to be nodes of the sub-graphs (i = 2,3,…,m). The k-1 selected nodes along with the node at the root define a sub-graph within the network. After discovering a sub-graph involved as a match in the target network, in order to be able to evaluate the size of each class according to the target network, Kavosh employs the nauty algorithm [24][25] in the same way as FANMOD. The enumeration part of Kavosh algorithm is shown below:

For counting the sub-graphs of size k that include a particular node, trees with maximum depth of k, rooted at this node and based on neighborhood relationship are implicitly built. Children of each node include both incoming and outgoing adjacent nodes. To descend the tree, a child is chosen at each level with the restriction that a particular child can be included only if it has not been included at any upper level. After having descended to the lowest level possible, the tree is again ascended and the process is repeated with the stipulation that nodes visited in earlier paths of a descendent are now considered unvisited nodes. A final restriction in building trees is that all children in a particular tree must have numerical labels larger than the label of the root of the tree. The restrictions on the labels of the children are similar to the conditions which GK and ESU algorithm use to avoid overcounting sub-graphs.

A recently introduced algorithm named Kavosh [35] aims at improved main memory usage. Kavosh is usable to detect NM in both directed and undirected networks. The main idea of the enumeration is similar to the GK and MODA algorithms, which first find all k-size sub-graphs that a particular node participated in, then remove the node, and subsequently repeat this process for the remaining nodes.[35]


Input: G: Input graph, k: sub-graph size, Δ: threshold value

Output: Frequent Subgraph List: List of all frequent k-size sub-graphs

Note: FG: set of mappings from G in the input graph G

fetch Tk


 G′ = Get-Next-BFS(Tk) // G′ is a query graph

 if |E(G′)| = (k – 1)

 call Mapping-Module(G′, G)


 call Enumerating-Module(G′, G, Tk)

 end if

 save F2

 if |FG| > Δ then

 add G′ into Frequent Subgraph List

 end if

Until |E(G')| = (k – 1)/2)

return Frequent Subgraph List

Illustration of the expansion tree T4 for 4-node query graphs. At the first level, there are non-isomorphic k-size trees and at each level, an edge is added to the parent graph to form a child graph. In the second level, there is a graph with two alternative edges that is shown by a dashed red edge. In fact, this node represents two expanded graphs that are isomorphic.[32]

MODA traverses Tk and when it extracts query trees from the first level of Tk it computes their mapping sets and saves these mappings for the next step. For non-tree queries from Tk, the algorithm extracts the mappings associated with the parent node in Tk and determines which of these mappings can support the current query graphs. The process will continue until the algorithm gets the complete query graph. The query tree mappings are extracted using the Grochow-Kellis algorithm. For computing the frequency of non-tree query graphs, the algorithm employs a simple routine that takes O(1) steps. In addition, MODA exploits a sampling method where the sampling of each node in the network is linearly proportional to the node degree, the probability distribution is exactly similar to the well-known Barabási-Albert preferential attachment model in the field of complex networks.[33] This approach generates approximations; however, the results are almost stable in different executions since sub-graphs aggregate around highly connected nodes.[34] The pseudocode of MODA is shown below:

As discussed above, the algorithm starts by computing sub-tree frequencies in the network and then expands sub-trees edge by edge. One way to implement this idea is called the expansion tree Tk for each k. Figure shows the expansion tree for size-4 sub-graphs. Tk organizes the running process and provides query graphs in a hierarchical manner. Strictly speaking, the expansion tree Tk is simply a directed acyclic graph or DAG, with its root number k indicating the graph size existing in the expansion tree and each of its other nodes containing the adjacency matrix of a distinct k-size query graph. Nodes in the first level of Tk are all distinct k-size trees and by traversing Tk in depth query graphs expand with one edge at each level. A query graph in a node is a sub-graph of the query graph in a node’s child with one edge difference. The longest path in Tk consists of (k2-3k+4)/2 edges and is the path from the root to the leaf node holding the complete graph. Generating expansion trees can be done by a simple routine which is explained in.[32]

Here is the main idea: by a simple criterion one can generalize a mapping of a k-size graph into the network to its same size supergraphs. For example, suppose there is mapping f(G) of graph G with k nodes into the network and we have a same size graph G′ with one more edge ‹u, v›; fG will map G′ into the network, if there is an edge ‹fG(u), fG(v)› in the network. As a result, we can exploit the mapping set of a graph to determine the frequencies of its same order supergraphs simply in O(1) time without carrying out sub-graph isomorphism testing. The algorithm starts ingeniously with minimally connected query graphs of size k and finds their mappings in the network via sub-graph isomorphism. After that, with conservation of the graph size, it expands previously considered query graphs edge-by-edge and computes the frequency of these expanded graphs as mentioned above. The expansion process continues until reaching a complete graph Kk (fully connected with k(k-1)2 edge).

Using a hierarchical structure called an expansion tree, the MODA algorithm is able to extract NMs of a given size systematically and similar to FPF that avoids enumerating unpromising sub-graphs; MODA takes into consideration potential queries (or candidate sub-graphs) that would result in frequent sub-graphs. Despite the fact that MODA resembles FPF in using a tree like structure, the expansion tree is applicable merely for computing frequency concept F1. As we will discuss next, the advantage of this algorithm is that it does not carry out the sub-graph isomorphism test for non-tree query graphs. Additionally, it utilizes a sampling method in order to speed up the running time of the algorithm.

Omidi et al. [32] introduced a new algorithm for motif detection named MODA which is applicable for induced and non-induced NM discovery in undirected networks. It is based on the motif-centric approach discussed in the Grochow-Kellis algorithm section. It is very important to distinguish motif-centric algorithms such as MODA and GK algorithm because of their ability to work as query-finding algorithms. This feature allows such algorithms to be able to find a single motif query or a small number of motif queries (not all possible sub-graphs of a given size) with larger sizes. As the number of possible non-isomorphic sub-graphs increases exponentially with sub-graph size, for large size motifs (even larger than 10), the network-centric algorithms, those looking for all possible sub-graphs, face a problem. Although motif-centric algorithms also have problems in discovering all possible large size sub-graphs, but their ability to find small numbers of them is sometimes a significant property.


As available PPI networks are far from complete and error free, this approach is suitable for NM discovery for such networks. As Grochow-Kellis Algorithm and this one are the ones popular for non-induced sub-graphs, it is worth to mention that the algorithm introduced by Alon et al. is less time consuming than the Grochow-Kellis Algorithm.[31]

3. Repeat the above two steps O(ek) times and add up the number of occurrences of T to get an estimate on the number of its occurrences in G.

2. Counting. Apply a dynamic programming routine to count the number of non-induced occurrences of T in which each vertex has a unique color. For more details on this step, see.[31]

1. Color coding. Color each vertex of input network G independently and uniformly at random with one of the k colors.

This algorithm counts the number of non-induced occurrences of a tree T with k = O(logn) vertices in a network G with n vertices as follows:

Most algorithms in the field of NM discovery are used to find induced sub-graphs of a network. In 2008, Noga Alon et al. [31] introduced an approach for finding non-induced sub-graphs too. Their technique works on undirected networks such as PPI ones. Also, it counts non-induced trees and bounded treewidth sub-graphs. This method is applied for sub-graphs of size up to 10.

Color-Coding Approach

As it is mentioned above, the symmetry-breaking technique is a simple mechanism that precludes spending time finding a sub-graph more than once due to its symmetries.[29][30] Note that, computing symmetry-breaking conditions requires finding all automorphisms of a given query graph. Even though, there is no efficient (or polynomial time) algorithm for the graph automorphism problem, this problem can be tackled efficiently in practice by McKay’s tools.[24][25] As it is claimed, using symmetry-breaking conditions in NM detection lead to save a great deal of running time. Moreover, it can be inferred from the results in [29][30] that using the symmetry-breaking conditions results in high efficiency particularly for directed networks in comparison to undirected networks. The symmetry-breaking conditions used in the GK algorithm are similar to the restriction which ESU algorithm applies to the labels in EXT and SUB sets. In conclusion, the GK algorithm computes the exact number of appearance of a given query graph in a large complex network and exploiting symmetry-breaking conditions improves the algorithm performance. Also, GK algorithm is one of the known algorithms having no limitation for motif size in implementation and potentially it can find motifs of any size.

The GK algorithm discovers the whole set of mappings of a given query graph to the network in two major steps. It starts with the computation of symmetry-breaking conditions of the query graph. Next, by means of a branch-and-bound method, the algorithm tries to find every possible mapping from the query graph to the network that meets the associated symmetry-breaking conditions. An example of the usage of symmetry-breaking conditions in GK algorithm is demonstrated in figure.

(a) graph G, (b) illustration of all automorphisms of G that is showed in (a). From set AutG we can obtain a set of symmetry-breaking conditions of G given by SymG in (c). Only the first mapping in AutG satisfies the SynG conditions; as a result, by applying SymG in the Isomorphism Extension module the algorithm only enumerate each match-able sub-graph in the network to G once. Note that SynG is not necessarily a unique set for an arbitrary graph G.

Grochow and Kellis [29] proposed an exact algorithm for enumerating sub-graph appearances. The algorithm is based on a motif-centric approach, which means that the frequency of a given sub-graph,called the query graph, is exhaustively determined by searching for all possible mappings from the query graph into the larger network. It is claimed [29] that a motif-centric method in comparison to network-centric methods has some beneficial features. First of all it avoids the increased complexity of sub-graph enumeration. Also, by using mapping instead of enumerating, it enables an improvement in the isomorphism test. To improve the performance of the algorithm, since it is an inefficient exact enumeration algorithm, the authors introduced a fast method which is called symmetry-breaking conditions. During straightforward sub-graph isomorphism tests, a sub-graph may be mapped to the same sub-graph of the query graph multiple times. In the Grochow-Kellis (GK) algorithm symmetry-breaking is used to avoid such multiple mappings. Here we introduce the GK algorithm and the symmetry-breaking condition which eliminates redundant isomorphism tests.



G - PPI network;

N - Number of randomized networks;

K - Maximal network motif size;

F - Frequency threshold;

S - Uniqueness threshold;


U - Repeated and unique network motif set;

D ← ∅;

for motif-size k from 3 to K do

 T ← FindRepeatedTrees(k);

 GDk ← GraphPartition(G, T)

 D ← D ∪ T;

 D′ ← T;

 i ← k;

 while D″ = ∅ and i ≤ k × (k - 1) / 2 do

 D′ ← FindRepeatedGraphs(k, i, D′);

 D ← D ∪ D′;

 i ← i + 1;

 end while

end for

for counter i from 1 to N do

 Grand ← RandomizedNetworkGeneration();

 for each g ∈ D do

 GetRandFrequency(g, Grand);

 end for

end for

U ← ∅;

for each g ∈ D do

 s ← GetUniqunessValue(g);

 if s ≥ S then

 U ← U ∪ {g};

 end if

end for

return U

NeMoFinder consists of three main steps. First, finding frequent size-n trees, then utilizing repeated size-n trees to divide the entire network into a collection of size-n graphs, finally, performing sub-graph join operations to find frequent size-n sub-graphs.[26] In the first step, the algorithm detects all non-isomorphic size-n trees and mappings from a tree to the network. In the second step, the ranges of these mappings are employed to partition the network into size-n graphs. Up to this step, there is no distinction between NeMoFinder and an exact enumeration method. However, a large portion of non-isomorphic size-n graphs still remain. NeMoFinder exploits a heuristic to enumerate non-tree size-n graphs by the obtained information from the preceding steps. The main advantage of the algorithm is in the third step, which generates candidate sub-graphs from previously enumerated sub-graphs. This generation of new size-n sub-graphs is done by joining each previous sub-graph with derivative sub-graphs from itself called cousin sub-graphs. These new sub-graphs contain one additional edge in comparison to the previous sub-graphs. However, there exist some problems in generating new sub-graphs: There is no clear method to derive cousins from a graph, joining a sub-graph with its cousins leads to redundancy in generating particular sub-graph more than once, and cousin determination is done by a canonical representation of the adjacency matrix which is not closed under join operation. NeMoFinder is an efficient network motif finding algorithm for motifs up to size 12 only for protein-protein interaction networks, which are presented as undirected graphs. And it is not able to work on directed networks which are so important in the field of complex and biological networks. The pseudocode of NeMoFinder is shown below:

Chen et al. [26] introduced a new NM discovery algorithm called NeMoFinder, which adapts the idea in SPIN [27] to extract frequent trees and after that expands them into non-isomorphic graphs.[8] NeMoFinder utilizes frequent size-n trees to partition the input network into a collection of size-n graphs, afterward finding frequent size-n sub-graphs by expansion of frequent trees edge-by-edge until getting a complete size-n graph Kn. The algorithm finds NMs in undirected networks and is not limited to extracting only induced sub-graphs. Furthermore, NeMoFinder is an exact enumeration algorithm and is not based on a sampling method. As Chen et al. claim, NeMoFinder is applicable for detecting relatively large NMs, for instance, finding NMs up to size-12 from the whole S. cerevisiae (yeast) PPI network as the authors claimed.[28]


Enumeration of ESU (FANMOD)

Input: A graph G = (V, E) and an integer 1 ≤ k ≤ |V|.

Output: All size-k subgraphs in G.

for each vertex v ∈ V do

 VExtension ← {u ∈ N({v}) | u > v}

 call ExtendSubgraph({v}, VExtension, v)


ExtendSubgraph(VSubgraph, VExtension, v)

if |VSubgraph| = k then output G[VSubgraph] and return

while VExtension ≠ ∅ do

 Remove an arbitrarily chosen vertex w from VExtension

 VExtension′ ← VExtension ∪ {u ∈ Nexcl(w, VSubgraph) | u > v}

 call ExtendSubgraph(VSubgraph ∪ {w}, VExtension′, v)


(a) A target graph of size 5, (b) the ESU-tree of depth k that is associated to the extraction of sub-graphs of size 3 in the target graph. Leaves correspond to set S3 or all of the size-3 induced sub-graphs of the target graph (a). Nodes in the ESU-tree include two adjoining sets, the first set contains adjacent nodes called SUB and the second set named EXT holds all nodes that are adjacent to at least one of the SUB nodes and where their numerical labels are larger than the SUB nodes labels. The EXT set is utilized by the algorithm to expand a SUB set until it reaches a desired sub-graph size that are placed at the lowest level of ESU-Tree (or its leaves).

How has the exact ESU been algorithm modified to RAND-ESU that estimates sub-graph concentrations? The procedure of implementing RAND-ESU is quite straightforward and is one of the main advantages of FANMOD. One can change the ESU algorithm to explore just a portion of the ESU-Tree leaves by applying a probability value 0 ≤ pd ≤ 1 for each level of the ESU-Tree and oblige ESU to traverse each child node of a node in level d-1 with probability pd. This new algorithm is called RAND-ESU. Evidently, when pd = 1 for all levels, RAND-ESU acts like ESU. For pd = 0 the algorithm finds nothing. Note that, this procedure ensures that the chances of visiting each leaf of the ESU-Tree are the same, resulting in unbiased sampling of sub-graphs through the network. The probability of visiting each leaf is dpd and this is identical for all of the ESU-Tree leaves; therefore, this method guarantees unbiased sampling of sub-graphs from the network. Nonetheless, determining the value of pd for 1 ≤ d ≤ k is another issue that must be determined manually by an expert to get precise results of sub-graph concentrations.[8] While there is no lucid prescript for this matter, the Wernicke provides some general observations that may help in determining p_d values. In summary, RAND-ESU is a very fast algorithm for NM discovery in the case of induced sub-graphs supporting unbiased sampling method. Although, the main ESU algorithm and so the FANMOD tool is known for discovering induced sub-graphs, there is trivial modification to ESU which makes it possible for finding non-induced sub-graphs, too. The pseudo code of ESU (FANMOD) is shown below:

The algorithms ESU and RAND-ESU are fairly simple, and hence easy to implement. ESU first finds the set of all induced sub-graphs of size k, let Sk be this set. ESU can be implemented as a recursive function; the running of this function can be displayed as a tree-like structure of depth k, called the ESU-Tree (see figure). Each of the ESU-Tree nodes indicate the status of the recursive function that entails two consecutive sets SUB and EXT. SUB refers to nodes in the target network that are adjacent and establish a partial sub-graph of size |SUB| ≤ k. If |SUB| = k, the algorithm has found an induced complete sub-graph, so Sk = SUB ∪ Sk. However, if |SUB| < k, the algorithm must expand SUB to achieve cardinality k. This is done by the EXT set that contains all the nodes that satisfy two conditions: First, each of the nodes in EXT must be adjacent to at least one of the nodes in SUB; second, their numerical labels must be larger than the labels of SUB nodes. The first condition makes sure that the expansion of SUB nodes yields a connected graph and the second condition causes ESU-Tree leafs (see figure) to be distinct; as a result, it prevents overcounting. Note that, the EXT set is not a static set, so in each step it may expand by some new nodes that do not breach the two conditions. The next step of ESU involves classification of sub-graphs placed in the ESU-Tree leafs into non-isomorphic size-k graph classes; consequently, ESU determines sub-graphs frequencies and concentrations. This stage has been implemented simply by employing McKay’s nauty algorithm,[24][25] which classifies each sub-graph by performing a graph isomorphism test. Therefore, ESU finds the set of all induced k-size sub-graphs in a target graph by a recursive algorithm and then determines their frequency using an efficient tool.

Wernicke [10] introduced an algorithm named RAND-ESU that provides a significant improvement over mfinder.[9] This algorithm, which is based on the exact enumeration algorithm ESU, has been implemented as an application called FANMOD.[10] RAND-ESU is a NM discovery algorithm applicable for both directed and undirected networks, effectively exploits an unbiased node sampling throughout the network, and prevents overcounting sub-graphs more than once. Furthermore, RAND-ESU uses a novel analytical approach called DIRECT for determining sub-graph significance instead of using an ensemble of random networks as a Null-model. The DIRECT method estimates the sub-graph concentration without explicitly generating random networks.[10] Empirically, the DIRECT method is more efficient in comparison with the random network ensemble in case of sub-graphs with a very low concentration; however, the classical Null-model is faster than the DIRECT method for highly concentrated sub-graphs.[3][10] In the following, we detail the ESU algorithm and then we show how this exact algorithm can be modified efficiently to RAND-ESU that estimates sub-graphs concentrations.

The sampling bias of Kashtan et al. [9] provided great impetus for designing better algorithms for the NM discovery problem. Although Kashtan et al. tried to settle this drawback by means of a weighting scheme, this method imposed an undesired overhead on the running time as well a more complicated implementation. This tool is one of the most useful ones, as it supports visual options and also is an efficient algorithm with respect to time. But, it has a limitation on motif size as it does not allow searching for motifs of size 9 or higher because of the way the tool is implemented.


Data: Graph G, target pattern size t, frequency concept F

Result: Set R of patterns of size t with maximum frequency.

R ← φ, fmax ← 0

P ←start pattern p1 of size 1

Mp1all matches of p1 in G

While P ≠ φ do

 Pmaxselect all patterns from P with maximum size.

 P ← select pattern with maximum frequency from Pmax

 Ε = ExtensionLoop(G, p, Mp)

 Foreach pattern p ∈ E

 If F = F1 then f ← size(Mp)

 Else f ← Maximum Independent set(F, Mp)


 If size(p) = t then

 If f = fmax then R ← R ⋃ {p}

 Else if f > fmax then R ← {p}; fmax ← f



 If F = F1 or f ≥ fmax then P ← P ⋃ {p}





The advantage of the algorithm is that it does not consider infrequent sub-graphs and tries to finish the enumeration process as soon as possible; therefore, it only spends time for promising nodes in the pattern tree and discards all other nodes. As an added bonus, the pattern tree notion permits FPF to be implemented and executed in a parallel manner since it is possible to traverse each path of the pattern tree independently. However, FPF is most useful for frequency concepts F2 and F3, because downward closure is not applicable to F1. Nevertheless, the pattern tree is still practical for F1 if the algorithm runs in parallel. Another advantage of the algorithm is that the implementation of this algorithm has no limitation on motif size, which makes it more amenable to improvements. The pseudocode of FPF (Mavisto) is shown below:

At first, the FPF algorithm enumerates and maintains the information of all matches of a sub-graph located at the root of the pattern tree. Then, one-by-one it builds child nodes of the previous node in the pattern tree by adding one edge supported by a matching edge in the target graph, and tries to expand all of the previous information about matches to the new sub-graph (child node). In next step, it decides whether the frequency of the current pattern is lower than a predefined threshold or not. If it is lower and if downward closure holds, FPF can abandon that path and not traverse further in this part of the tree; as a result, unnecessary computation is avoided. This procedure is continued until there is no remaining path to traverse.

Illustration of the pattern tree in FPF algorithm.[12]

Schreiber and Schwöbbermeyer [12] proposed an algorithm named flexible pattern finder (FPF) for extracting frequent sub-graphs of an input network and implemented it in a system named Mavisto.[23] Their algorithm exploits the downward closure property which is applicable for frequency concepts F2 and F3. The downward closure property asserts that the frequency for sub-graphs decrease monotonically by increasing the size of sub-graphs; however, this property does not hold necessarily for frequency concept F1. FPF is based on a pattern tree (see figure) consisting of nodes that represents different graphs (or patterns), where the parent of each node is a sub-graph of its children nodes; in other words, the corresponding graph of each pattern tree’s node is expanded by adding a new edge to the graph of its parent node.

FPF (Mavisto)

Definitions: Esis the set of picked edges. Vs is the set of all nodes that are touched by the edges in E.
Init Vs and Es to be empty sets.

1. Pick a random edge e1 = (vi, vj). Update Es = {e1}, Vs = {vi, vj}

2. Make a list L of all neighbor edges of Es. Omit from L all edges between members of Vs.

3. Pick a random edge e = {vk,vl} from L. Update Es = Es ⋃ {e}, Vs = Vs ⋃ {vk, vl}.

4. Repeat steps 2-3 until completing an n-node subgraph (until |Vs| = n).

5. Calculate the probability to sample the picked n-node subgraph.

In expanded to include sharp contrast to exhaustive search, the computational time of the algorithm surprisingly is asymptotically independent of the network size. An analysis of the computational time of the algorithm has shown that it takes O(nn) for each sample of a sub-graph of size n from the network. On the other hand, there is no analysis in [9] on the classification time of sampled sub-graphs that requires solving the graph isomorphism problem for each sub-graph sample. Additionally, an extra computational effort is imposed on the algorithm by the sub-graph weight calculation. But it is unavoidable to say that the algorithm may sample the same sub-graph multiple times – spending time without gathering any information.[10] In conclusion, by taking the advantages of sampling, the algorithm performs more efficiently than an exhaustive search algorithm; however, it only determines sub-graphs concentrations approximately. This algorithm can find motifs up to size 6 because of its main implementation, and as result it gives the most significant motif, not all the others too. Also, it is necessary to mention that this tool has no option of visual presentation. The sampling algorithm is shown briefly:

Kashtan et al. [9] presented the first sampling NM discovery algorithm, which was based on edge sampling throughout the network. This algorithm estimates concentrations of induced sub-graphs and can be utilized for motif discovery in directed or undirected networks. The sampling procedure of the algorithm starts from an arbitrary edge of the network that leads to a sub-graph of size two, and then expands the sub-graph by choosing a random edge that is incident to the current sub-graph. After that, it continues choosing random neighboring edges until a sub-graph of size n is obtained. Finally, the sampled sub-graph is expanded to include all of the edges that exist in the network between these n nodes. When an algorithm uses a sampling approach, taking unbiased samples is the most important issue that the algorithm might address. The sampling procedure, however, does not take samples uniformly and therefore Kashtan et al. proposed a weighting scheme that assigns different weights to the different sub-graphs within network.[9] The underlying principle of weight allocation is exploiting the information of the sampling probability for each sub-graph, i.e. the probable sub-graphs will obtain comparatively less weights in comparison to the improbable sub-graphs; hence, the algorithm must calculate the sampling probability of each sub-graph that has been sampled. This weighting technique assists mfinder to determine sub-graph concentrations impartially.

mfinder, the first motif-mining tool, implements two kinds of motif finding algorithms: a full enumeration and a sampling method. Until 2004, the only exact counting method for NM detection was the brute-force one proposed by Milo et al..[3] This algorithm was successful for discovering small motifs, but using this method for finding even size 5 or 6 motifs was not computationally feasible. Hence, a new approach to this problem was needed.


Here, a review on computational aspects of major algorithms is given and their related benefits and drawbacks from an algorithmic perspective are discussed.

Various solutions have been proposed for the challenging problem of motif discovery. These algorithms can be classified under various paradigms such as exact counting methods, sampling methods, pattern growth methods and so on. However, motif discovery problem comprises two main steps: first, calculating the number of occurrences of a sub-graph and then, evaluating the sub-graph significance. The recurrence is significant if it is detectably far more than expected. Roughly speaking, the expected number of appearances of a sub-graph can be determined by a Null-model, which is defined by an ensemble of random networks with some of the same properties as the original network.

Motif Discovery Algorithms

Most recently, the acc-MOTIF tool to detect network motifs was released.[22]

The computational research has focused on improving existing motif detection tools to assist the biological investigations and allow larger networks to be analyzed. Several different algorithms have been provided so far, which are elaborated in the next section in chronological order.

[21][20][5] A distinct set of network motifs were identified in other types of biological networks such as neuronal networks and protein interaction networks.[19][18][17] and yeast, for example, is made of three main motif families, that make up almost the entire network. The leading hypothesis is that the network motif were independently selected by evolutionary processes in a converging manner,[38][39] since the creation or elimination of regulatory interactions is fast on evolutionary time scale, relative to the rate at which genes change,[38][39][40] Furthermore, experiments on the dynamics generated by network motifs in living cells indicate that they have characteristic dynamical functions. This suggests that the network motif serve as building blocks in gene regulatory networks that are beneficial to the organism.

The functions associated with common network motifs in transcription networks were explored and demonstrated by several research projects both theoretically and experimentally. Below are some of the most common network motifs and their associated function.

Negative auto-regulation (NAR)

Schematic representation of an auto-regulation motif

One of simplest and most abundant network motifs in E. coli is negative auto-regulation in which a transcription factor (TF) represses its own transcription. This motif was shown to perform two important functions. The first function is response acceleration. NAR was shown to speed-up the response to signals both theoretically [41] and experimentally. This was first shown in a synthetic transcription network[42] and later on in the natural context in the SOS DNA repair system of E .coli.[43] The second function is increased stability of the auto-regulated gene product concentration against stochastic noise, thus reducing variations in protein levels between different cells.[44][45]

Positive auto-regulation (PAR)

Positive auto-regulation (PAR) occurs when a transcription factor enhances its own rate of production. Opposite to the NAR motif this motif slows the response time compared to simple regulation.[46] In the case of a strong PAR the motif may lead to a bimodal distribution of protein levels in cell populations.[47]

Feed-forward loops (FFL)

Schematic representation of a Feed-forward motif

This motif is commonly found in many gene systems and organisms. The motif consists of three genes and three regulatory interactions. The target gene C is regulated by 2 TFs A and B and in addition TF B is also regulated by TF A . Since each of the regulatory interactions may either be positive or negative there are possibly eight types of FFL motifs.[48] Two of those eight types: the coherent type 1 FFL (C1-FFL) (where all interactions are positive) and the incoherent type 1 FFL (I1-FFL) (A activates C and also activates B which represses C) are found much more frequently in the transcription network of E. coli and yeast than the other six types.[48][49] In addition to the structure of the circuitry the way in which the signals from A and B are integrated by the C promoter should also be considered. In most of the cases the FFL is either an AND gate (A and B are required for C activation) or OR gate (either A or B are sufficient for C activation) but other input function are also possible.

Coherent type 1 FFL (C1-FFL)

The C1-FFL with an AND gate was shown to have a function of a ‘sign-sensitive delay’ element and a persistence detector both theoretically [48] and experimentally[50] with the arabinose system of E. coli. This means that this motif can provide pulse filtration in which short pulses of signal will not generate a response but persistent signals will generate a response after short delay. The shut off of the output when a persistent pulse is ended will be fast. The opposite behavior emerges in the case of a sum gate with fast response and delayed shut off as was demonstrated in the flagella system of E. coli.[51]

Incoherent type 1 FFL (I1-FFL)

The I1-FFL is a pulse generator and response accelerator. The two signal pathways of the I1-FFL act in opposite directions where one pathway activates Z and the other represses it. When the repression is complete this leads to a pulse-like dynamics. It was also demonstrated experimentally that the I1-FFL can serve as response accelerator in a way which is similar to the NAR motif. The difference is that the I1-FFL can speed-up the response of any gene and not necessarily a transcription factor gene.[52] Recently additional function was assigned to the I1-FFL network motif: it was shown both theoretically and experimentally that the I1-FFL can generate non-monotonic input function in both a synthetic [53] and native systems.[54]

Multi-output FFLs

In some cases the same regulators X and Y regulate several Z genes of the same system. By adjusting the strength of the interactions this motif was shown to determine the temporal order of gene activation. This was demonstrated experimentally in the flagella system of E. coli.[55]

Single-input modules (SIM)

This motif occurs when a single regulator regulates a set of genes with no additional regulation. This is useful when the genes are cooperatively carrying out a specific function and therefore always need to be activated in a synchronized manner. By adjusting the strength of the interactions it can create temporal expression program of the genes it regulates.[56]

In the literature, Multiple-input modules (MIM) arose as a generalization of SIM. However, the precise definitions of SIM and MIM have been a source of inconsistency. There are attempts to provide orthogonal definitions for canonical motifs in biological networks and algorithms to enumerate them, especially SIM, MIM and Bi-Fan (2x2 MIM).[57]

Dense overlapping regulons (DOR)

This motif occurs in the case that several regulators combinatorially control a set of genes with diverse regulatory combinations. This motif was found in E. coli in various systems such as carbon utilization, anaerobic growth, stress response and others.[13][18] In order to better understand the function of this motif one has to obtain more information about the way the multiple inputs are integrated by the genes. Kaplan et al.[58] has mapped the input functions of the sugar utilization genes in E. coli, showing diverse shapes.

Activity motifs

An interesting generalization of the network-motifs, activity motifs are over occurring patterns that can be found when nodes and edges in the network are annotated with quantitative features. For instance, when edges in a metabolic pathways are annotated with the magnitude or timing of the corresponding gene expression, some patterns are over occurring given the underlying network structure.[59]


An assumption (sometimes more sometimes less implicit) behind the preservation of a topological sub-structure is that it is of a particular functional importance. This assumption has recently been questioned. Some authors have argued that motifs, like bi-fan motifs, might show a variety depending on the network context, and therefore,[60] structure of the motif does not necessarily determine function. Network structure certainly does not always indicate function; this is an idea that has been around for some time, for an example see the Sin operon.[61]

Most analyses of motif function are carried out looking at the motif operating in isolation. Recent research[62] provides good evidence that network context, i.e. the connections of the motif to the rest of the network, is too important to draw inferences on function from local structure only — the cited paper also reviews the criticisms and alternative explanations for the observed data. An analysis of the impact of a single motif module on the global dynamics of a network is studied in.[63] Yet another recent work suggests that certain topological features of biological networks naturally give rise to the common appearance of canonical motifs, thereby questioning whether frequencies of occurrences are reasonable evidence that the structures of motifs are selected for their functional contribution to the operation of networks.[64]

See Also

Clique (graph theory)

Graphical model


  1. ^ Masoudi-Nejad A, Schreiber F, Razaghi MK Z (2012). "Building Blocks of Biological Networks: A Review on Major Network Motif Discovery Algorithms". IET Systems Biology, in press. 
  2. ^ Diestel R (2005). "Graph Theory (Graduate Texts in Mathematics)" 173. New York: Springer-Verlag Heidelberg. 
  3. ^ a b c Milo R, Shen-Orr SS, Itzkovitz S, Kashtan N, Chklovskii D, Alon U (2002). "Network motifs: simple building blocks of complex networks". Science 298 (5594): 824–827.  
  4. ^ Albert R, Barabási AL (2002). "Statistical mechanics of complex networks". Reviews of Modern Physics 74: 47–49.  
  5. ^ a b Milo R, Itzkovitz S, Kashtan N, Levitt R, Shen-Orr S, Ayzenshtat I, Sheffer M, Alon U (2004). "Superfamilies of designed and evolved networks". Science 303 (5663): 1538–1542.  
  6. ^ a b Schwöbbermeyer, H (2008). "Network Motifs". In Junker BH, Schreiber F. Analysis of Biological Networks. Hoboken, New Jersey: John Wiley & Sons. pp. 85–108. 
  7. ^ Bornholdt, S; Schuster, HG (2003). Handbook of graphs and networks : from the genome to the Internet. Weinheim: Wiley-VCH. 
  8. ^ a b c Ciriello G, Guerra C (2008). "A review on models and algorithms for motif discovery in protein-protein interaction networks". Briefings in Functional Genomics and Proteomics 7 (2): 147–156.  
  9. ^ a b c d e f Kashtan N, Itzkovitz S, Milo R, Alon U (2004). "Efficient sampling algorithm for estimating sub-graph concentrations and detecting network motifs". Bioinformatics 20 (11): 1746–1758.  
  10. ^ a b c d e f Wernicke S (2006). "Efficient detection of network motifs". IEEE/ACM Transactions on Computational Biology and Bioinformatics 3 (4): 347–359.  
  11. ^ Picard F, Daudin J-J, Schbath S, Robin S (2005). "Assessing the Exceptionality of Network Motifs". J. Comp. Bio. 15 (1): 1–20. 
  12. ^ a b c Schreiber F, Schwöbbermeyer H (2005). "Frequency concepts and pattern detection for the analysis of motifs in networks". Transactions on Computational Systems Biology III: 89–104. 
  13. ^ a b c Shen-Orr SS, Milo R, Mangan S, Alon U (May 2002). "Network motifs in the transcriptional regulation network of Escherichia coli". Nat. Genet. 31 (1): 64–8.  
  14. ^ Eichenberger P, Fujita M, Jensen ST, et al. (October 2004). "Bacillus subtilis"The program of gene transcription for a single differentiating cell type during sporulation in . PLOS Biology 2 (10): e328.  
  15. ^ Milo R, Shen-Orr S, Itzkovitz S, Kashtan N, Chklovskii D, Alon U (October 2002). "Network motifs: simple building blocks of complex networks". Science 298 (5594): 824–7.  
  16. ^ Lee TI, Rinaldi NJ, Robert F, et al. (October 2002). "Transcriptional regulatory networks in Saccharomyces cerevisiae". Science 298 (5594): 799–804.  
  17. ^ Odom DT, Zizlsperger N, Gordon DB, et al. (February 2004). "Control of pancreas and liver gene expression by HNF transcription factors". Science 303 (5662): 1378–81.  
  18. ^ a b Boyer LA, Lee TI, Cole MF, et al. (September 2005). "Core transcriptional regulatory circuitry in human embryonic stem cells". Cell 122 (6): 947–56.  
  19. ^ Iranfar N, Fuller D, Loomis WF (February 2006). "Transcriptional regulation of post-aggregation genes in Dictyostelium by a feed-forward loop involving GBF and LagC". Dev. Biol. 290 (2): 460–9.  
  20. ^ Ma'ayan A, Jenkins SL, Neves S, et al. (August 2005). "Formation of regulatory patterns during signal propagation in a Mammalian cellular network". Science 309 (5737): 1078–83.  
  21. ^ Ptacek J, Devgan G, Michaud G, et al. (December 2005). "Global analysis of protein phosphorylation in yeast". Nature 438 (7068): 679–84.  
  22. ^
  23. ^ Schreiber F, Schwobbermeyer H (2005). "MAVisto: a tool for the exploration of network motifs". Bioinformatics 21 (17): 3572–3574.  
  24. ^ a b c McKay BD (1981). "Practical graph isomorphism". Congressus Numerantium 30: 45–87. 
  25. ^ a b c McKay BD (1998). "Isomorph-free exhaustive generation". Journal of Algorithms 26: 306–324.  
  26. ^ a b Chen J, Hsu W, Li Lee M et al. (2006). "NeMoFinder: dissecting genome-wide protein-protein interactions with meso-scale network motifs". the 12th ACM SIGKDD international conference on Knowledge discovery and data mining. Philadelphia, Pennsylvania, USA. pp. 106–115. 
  27. ^ Huan J, Wang W, Prins J et al. (2004). "SPIN: mining maximal frequent sub-graphs from graph databases". the 10th ACM SIGKDD international conference on Knowledge discovery and data mining. pp. 581–586. 
  28. ^ Uetz P, Giot L, Cagney G et al. (2000). "A comprehensive analysis of protein-protein interactions in Saccharomyces cerevisiae". Nature 403 (6770): 623–627.  
  29. ^ a b c d Grochow JA, Kellis M (2007). "Network Motif Discovery Using Sub-graph Enumeration and Symmetry-Breaking". RECOMB. pp. 92–106.  
  30. ^ a b Grochow JA (2006). "On the structure and evolution of protein interaction networks". Thesis M. Eng., Massachusetts Institute of Technology, Dept. of Electrical Engineering and Computer Science. 
  31. ^ a b c Alon N, Dao P, Hajirasouliha I, Hormozdiari F, Sahinalp S.C (2008). "Biomolecular network motif counting and discovery by color coding". Bioinformatics 24: i241–i249.  
  32. ^ a b c d e Omidi S, Schreiber F, Masoudi-Nejad A (2009). "MODA: an efficient algorithm for network motif discovery in biological networks". Genes Genet Syst 84 (5): 385–395.  
  33. ^ Barabasi AL, Albert R (1999). "Emergence of scaling in random networks". Science 286 (5439): 509–512.  
  34. ^ Vázquez A, Dobrin R, Sergi D, et al. (2004). "The topological relationship between the large-scale attributes and local interaction patterns of complex networks". PNAS 101 (52): 17940–17945.  
  35. ^ a b c d Kashani ZR, Ahrabian H, Elahi E, Nowzari-Dalini A, Ansari ES, Asadi S, Mohammadi S, Schreiber F, Masoudi-Nejad A (2009). "Kavosh: a new algorithm for finding network motifs". BMC Bioinformatics 10 (318).  
  36. ^ Ali Masoudi-Nejad, Mitra Anasariola, Ali Salehzadeh-Yazdi, Sahand Khakabimamaghani (2012). "CytoKavosh: a Cytoscape Plug-in for Finding Network Motifs in Large Biological Networks". PLOS ONE, in press. 
  37. ^ a b c d Ribeiro P, Silva F (2010). "G-Tries: an efficient data structure for discovering network motifs". ACM 25th Symposium On Applied Computing - Bioinformatics Track. Sierre, Switzerland. pp. 1559–1566. 
  38. ^ a b Babu MM, Luscombe NM, Aravind L, Gerstein M, Teichmann SA (June 2004). "Structure and evolution of transcriptional regulatory networks". Current Opinion in Structural Biology 14 (3): 283–91.  
  39. ^ a b Conant GC, Wagner A (July 2003). "Convergent evolution of gene circuits". Nat. Genet. 34 (3): 264–6.  
  40. ^ Dekel E, Alon U (July 2005). "Optimality and evolutionary tuning of the expression level of a protein". Nature 436 (7050): 588–92.  
  41. ^ Zabet NR (September 2011). "Negative feedback and physical limits of genes". Journal of Theoretical Biology 248 (1): 82–91.  
  42. ^ Rosenfeld N, Elowitz MB, Alon U (November 2002). "Negative autoregulation speeds the response times of transcription networks". J. Mol. Biol. 323 (5): 785–93.  
  43. ^ Camas FM, Blázquez J, Poyatos JF (August 2006). "Autogenous and nonautogenous control of response in a genetic network". Proc. Natl. Acad. Sci. U.S.A. 103 (34): 12718–23.  
  44. ^ Becskei A, Serrano L (June 2000). "Engineering stability in gene networks by autoregulation". Nature 405 (6786): 590–3.  
  45. ^ Dublanche Y, Michalodimitrakis K, Kümmerer N, Foglierini M, Serrano L (2006). "Noise in transcription negative feedback loops: simulation and experimental analysis". Mol. Syst. Biol. 2 (1): 41.  
  46. ^ Maeda YT, Sano M (June 2006). "Regulatory dynamics of synthetic gene networks with positive feedback". J. Mol. Biol. 359 (4): 1107–24.  
  47. ^ Becskei A, Séraphin B, Serrano L (May 2001). "Positive feedback in eukaryotic gene networks: cell differentiation by graded to binary response conversion". EMBO J. 20 (10): 2528–35.  
  48. ^ a b c Mangan S, Alon U (October 2003). "Structure and function of the feed-forward loop network motif". Proc. Natl. Acad. Sci. U.S.A. 100 (21): 11980–5.  
  49. ^ Ma HW, Kumar B, Ditges U, Gunzer F, Buer J, Zeng AP (2004). and analysis of its hierarchical structure and network motifs"Escherichia coli"An extended transcriptional regulatory network of . Nucleic Acids Res. 32 (22): 6643–9.  
  50. ^ Mangan S, Zaslaver A, Alon U (November 2003). "The coherent feedforward loop serves as a sign-sensitive delay element in transcription networks". J. Mol. Biol. 334 (2): 197–204.  
  51. ^ Kalir S, Mangan S, Alon U (2005). "Escherichia coli"A coherent feed-forward loop with a SUM input function prolongs flagella expression in . Mol. Syst. Biol. 1 (1): 2005.0006.  
  52. ^ Mangan S, Itzkovitz S, Zaslaver A, Alon U (March 2006). "Escherichia coli"The incoherent feed-forward loop accelerates the response-time of the gal system of . J. Mol. Biol. 356 (5): 1073–81.  
  53. ^ Entus R, Aufderheide B, Sauro HM (August 2007). "Design and implementation of three incoherent feed-forward motif based biological concentration sensors". Syst Synth Biol 1 (3): 119–28.  
  54. ^ Kaplan S, Bren A, Dekel E, Alon U (2008). "The incoherent feed-forward loop can generate non-monotonic input functions for genes". Mol. Syst. Biol. 4 (1): 203.  
  55. ^ Kalir S, McClure J, Pabbaraju K, et al. (June 2001). "Ordering genes in a flagella pathway by analysis of expression kinetics from living bacteria". Science 292 (5524): 2080–3.  
  56. ^ Zaslaver A, Mayo AE, Rosenberg R, et al. (May 2004). "Just-in-time transcription program in metabolic pathways". Nat. Genet. 36 (5): 486–91.  
  57. ^ Konagurthu AS, Lesk AM. (2008). "Single and Multiple Input Modules in regulatory networks". Proteins 73 (2): 320–324.  
  58. ^ Kaplan S, Bren A, Zaslaver A, Dekel E, Alon U (March 2008). "Diverse two-dimensional input functions control bacterial sugar genes". Mol. Cell 29 (6): 786–92.  
  59. ^ Chechik G, Oh E, Rando O, Weissman J, Regev A, Koller D (November 2008). "Activity motifs reveal principles of timing in transcriptional control of the yeast metabolic network". Nat. Biotechnol. 26 (11): 1251–9.  
  60. ^ Ingram PJ, Stumpf MP, Stark J (2006). "Network motifs: structure does not determine function". BMC Genomics 7: 108.  
  61. ^ Voigt CA, Wolf DM, Arkin AP (March 2005). sin operon: an evolvable network motif"Bacillus subtilis"The . Genetics 169 (3): 1187–202.  
  62. ^ Knabe JF, Nehaniv CL, Schilstra MJ (2008). "Do motifs reflect evolved function?—No convergent evolution of genetic regulatory network subgraph topologies". BioSystems 94 (1-2): 68–74.  
  63. ^ Taylor D, Restrepo JG (2011). "Network connectivity during mergers and growth: Optimizing the addition of a module". Physical Review E 83 (6): 066112.  
  64. ^ Konagurthu AS, Lesk AM (2008). "On the origin of distribution patterns of motifs in biological networks". BMC Syst Biol 2: 73.  

External links

  • Uri Alon's web page
  • A software tool that can detect network motifs
  • bio-physics-wiki NETWORK MOTIFS
  • FANMOD: a tool for fast network motif detection
  • MAVisto: network motif analysis and visualisation tool
  • NeMoFinder
  • Grochow-Kellis
  • Noga Alon's web page
  • MODA
  • Kavosh
  • CytoKavosh
  • G-Tries
  • acc-MOTIF detection tool