data:image/s3,"s3://crabby-images/ca364/ca36463f9b82c90b6f3e27c6326cdcdc31617e4c" alt=""
Color-coding
Encyclopedia
In computer science
and graph theory
, the method of color-coding efficiently finds k-vertex simple paths
, k-vertex cycles
, and other small subgraphs within a given graph
using probabilistic algorithms, which can then be derandomized and turned into deterministic algorithm
s. This method shows that many subcases of the subgraph isomorphism problem (an NP-complete
problem) can in fact be solved in polynomial time.
The theory and analysis of the color-coding method was proposed in 1994 by Noga Alon
, Raphael Yuster, and Uri Zwick.
in a given graph
, where
can be a path, a cycle, or any bounded treewidth graph where
, the method of color-coding begins by randomly coloring each vertex of
with
colors, and then tries to find a colorful copy of
in colored
. Here, a graph is colorful if every vertex in it is colored with a distinct color. This method works by repeating (1) random coloring a graph and (2) finding colorful copy of the target subgraph, and eventually the target subgraph can be found if the process is repeated a sufficient number of times.
Suppose
becomes colorful with some non-zero probability
. It immediately follows that if the random coloring is repeated
times, then
is expected to become colorful once. Note that though
is small, it is shown that if
,
is only polynomially small. Suppose again there exists an algorithm such that, given a graph
and a coloring which maps each vertex of
to one of the
colors, it finds a copy of colorful
, if one exists, within some runtime
. Then the expected time to find a copy of
in
, if one exists, is
.
Sometimes it is also desirable to use a more restricted version of colorfulness. For example, in the context of finding cycles in planar graphs, it is possible to develop an algorithm that finds well-colored cycles. Here, a cycle is well-colored if its vertices are colored by consecutive colors.
in graph
.
By applying random coloring method, each simple cycle has a probability of
to become colorful, since there are
ways of coloring the
vertices on the path, among which there are
colorful occurrences. Then an algorithm (described below) of runtime
can be adopted to find colorful cycles in the randomly colored graph
. Therefore, it takes
overall time to find a simple cycle of length
in
.
The colorful cycle-finding algorithm works by first finding all pairs of vertices in V that are connected by a simple path of length k − 1, and then checking whether the two vertices in each pair are connected. Given a coloring function
to color graph
, enumerate all partitions of the color set
into two subsets
,
of size
each. Note that
can be divided into
and
accordingly, and let
and
denote the subgraphs induced by
and
respectively. Then, recursively finds colorful path of length
in each of
and
. Suppose the boolean matrix
and
represent the connectivity of each pair of vertices in
and
by a colorful path, respectively, and let
be the matrix describing the adjacency relations between vertices of
and those of
, the boolean product
gives all pairs of vertices in
that are connected by a colorful path of length
. Thus, the recursive relation of matrix multiplications is
, which yields a runtime of
. Although this algorithm finds only the end points of the colorful path, another algorithm by Alon and Naor that finds colorful paths themselves can be incorporated into it.
, such that the randomness of coloring
is no longer required. For the target subgraph
in
to be discoverable, the enumeration has to include at least one instance where the
is colorful. To achieve this, enumerating a
-perfect family
of hash functions from
to
is sufficient. By definition,
is k-perfect if for every subset
of
where
, there exists a hash function
such that
is perfect. In other words, there must exist a hash function in
that colors any given
vertices with
distinct colors.
There are several approaches to construct such a
-perfect hash family:
In the case of derandomizing well-coloring, where each vertex on the subgraph is colored consecutively, a
-perfect family of hash functions from
to
is needed. A sufficient
-perfect family which maps from
to
can be constructed in a way similar to the approach 3 above (the first step). In particular, it is done by using
random bits that are almost
independent, and the size of the resulting
-perfect family will be
.
The derandomization of color-coding method can be easily parallelized, yielding efficient NC
algorithms.
in protein-protein interaction
(PPI) networks. Another example is to discover and to count the number of motifs
in PPI networks. Studying both signaling pathways
and motifs
allows a deeper understanding of the similarities and differences of many biological functions, processes, and structures among organisms.
Due to the huge amount of gene data that can be collected, searching for pathways or motifs can be highly time consuming. However, by exploiting the color coding method, the motifs or signaling pathways with
vertices in a network
with
vertices can be found very efficiently in polynomial time. Thus, this enables us to explore more complex or larger structures in PPI networks. More details can be found in .
Computer science
Computer science or computing science is the study of the theoretical foundations of information and computation and of practical techniques for their implementation and application in computer systems...
and graph theory
Graph theory
In mathematics and computer science, graph theory is the study of graphs, mathematical structures used to model pairwise relations between objects from a certain collection. A "graph" in this context refers to a collection of vertices or 'nodes' and a collection of edges that connect pairs of...
, the method of color-coding efficiently finds k-vertex simple paths
Path (graph theory)
In graph theory, a path in a graph is a sequence of vertices such that from each of its vertices there is an edge to the next vertex in the sequence. A path may be infinite, but a finite path always has a first vertex, called its start vertex, and a last vertex, called its end vertex. Both of them...
, k-vertex cycles
Cycle (graph theory)
In graph theory, the term cycle may refer to a closed path. If repeated vertices are allowed, it is more often called a closed walk. If the path is a simple path, with no repeated vertices or edges other than the starting and ending vertices, it may also be called a simple cycle, circuit, circle,...
, and other small subgraphs within a given graph
Graph theory
In mathematics and computer science, graph theory is the study of graphs, mathematical structures used to model pairwise relations between objects from a certain collection. A "graph" in this context refers to a collection of vertices or 'nodes' and a collection of edges that connect pairs of...
using probabilistic algorithms, which can then be derandomized and turned into deterministic algorithm
Deterministic algorithm
In computer science, a deterministic algorithm is an algorithm which, in informal terms, behaves predictably. Given a particular input, it will always produce the same output, and the underlying machine will always pass through the same sequence of states...
s. This method shows that many subcases of the subgraph isomorphism problem (an NP-complete
NP-complete
In computational complexity theory, the complexity class NP-complete is a class of decision problems. A decision problem L is NP-complete if it is in the set of NP problems so that any given solution to the decision problem can be verified in polynomial time, and also in the set of NP-hard...
problem) can in fact be solved in polynomial time.
The theory and analysis of the color-coding method was proposed in 1994 by Noga Alon
Noga Alon
Noga Alon is an Israeli mathematician noted for his contributions to combinatorics and theoretical computer science, having authored hundreds of papers.- Academic background :...
, Raphael Yuster, and Uri Zwick.
Results
The following results can be obtained through the method of color-coding:- For every fixed constant
, if a graph
contains a simple cycle of size
, then such cycle can be found in:
- O(
) expected time, or
- O(
) worst-case time, where
is the exponent of matrix multiplication
Matrix multiplicationIn mathematics, matrix multiplication is a binary operation that takes a pair of matrices, and produces another matrix. If A is an n-by-m matrix and B is an m-by-p matrix, the result AB of their multiplication is an n-by-p matrix defined only if the number of columns m of the left matrix A is the...
.
- O(
- For every fixed constant
, and every graph
that is in any nontrivial minor-closed graph family (e.g., a planar graph
Planar graphIn graph theory, a planar graph is a graph that can be embedded in the plane, i.e., it can be drawn on the plane in such a way that its edges intersect only at their endpoints...
), ifcontains a simple cycle of size
, then such cycle can be found in:
- O(
) expected time, or
- O(
) worst-case time.
- O(
- If a graph
contains a subgraph isomorphic to a bounded treewidth graph which has
vertices, then such a subgraph can be found in polynomial time.
The method
To solve the problem of finding a subgraphdata:image/s3,"s3://crabby-images/0054c/0054c49acbc0887716ce9c2e33b0ae4b9f5e9403" alt=""
data:image/s3,"s3://crabby-images/1aaf2/1aaf2a3506fbd11e2bdfcd9e08e9966b1c87453f" alt=""
data:image/s3,"s3://crabby-images/53e63/53e63d2bf85ba5401d25e253cff2eaa31c12bbe0" alt=""
data:image/s3,"s3://crabby-images/cd707/cd7070adc159b4487c6e738ab6afaf47db88e48d" alt=""
data:image/s3,"s3://crabby-images/77104/77104b8669bb357d698d0b582cba4a24b036ea6e" alt=""
data:image/s3,"s3://crabby-images/92c65/92c65dace2b5fd1ecdfe003d235392ca7913562e" alt=""
data:image/s3,"s3://crabby-images/72230/7223052e1f6de9ddf80b06f9d1f0b4399de249c6" alt=""
data:image/s3,"s3://crabby-images/dfd0e/dfd0e43e40ed09a94a622193823be14b71ec87cc" alt=""
Suppose
data:image/s3,"s3://crabby-images/ad171/ad1710ec398cfeac4cc56de9cb335d338a78b378" alt=""
data:image/s3,"s3://crabby-images/e8971/e89714099917bb1d224744e18c8bcf9ad6e3fb6b" alt=""
data:image/s3,"s3://crabby-images/a003f/a003f3292b291b818e5498c6ce34261bf6d506a3" alt=""
data:image/s3,"s3://crabby-images/768ff/768ff82db7b27d9c8c98bc169e51d371a1f2fe4f" alt=""
data:image/s3,"s3://crabby-images/843a0/843a09a75f67ac339b783b9809497c2c2a319189" alt=""
data:image/s3,"s3://crabby-images/21d21/21d2117cc67cd88e1af9274891c2e6156df3a23b" alt=""
data:image/s3,"s3://crabby-images/7df3c/7df3c7334fb7af2510887c138b3a9f7388873416" alt=""
data:image/s3,"s3://crabby-images/ee922/ee92225d00274bbe420d0c5b762d5664d83a160e" alt=""
data:image/s3,"s3://crabby-images/23114/23114c971a2dfb1bca38df256f62b159668c235d" alt=""
data:image/s3,"s3://crabby-images/b3dd0/b3dd0a7d84760ca08a9bd37ce87896154944e440" alt=""
data:image/s3,"s3://crabby-images/420d4/420d4e56bcaa28574f1e581fcb75e19cf6a7a072" alt=""
data:image/s3,"s3://crabby-images/26752/2675281fbe992c2a3693beb3b7883c07b0ef2808" alt=""
data:image/s3,"s3://crabby-images/317d3/317d349642af46697ff4a83a8f51c1c99ef6ae6e" alt=""
data:image/s3,"s3://crabby-images/23092/230923bbe7faa10f8c5cbe87cbb05c12085afa82" alt=""
data:image/s3,"s3://crabby-images/4f277/4f277a256dcb8eecaeae2327dd713ff06cf88df5" alt=""
Sometimes it is also desirable to use a more restricted version of colorfulness. For example, in the context of finding cycles in planar graphs, it is possible to develop an algorithm that finds well-colored cycles. Here, a cycle is well-colored if its vertices are colored by consecutive colors.
Example
An example would be finding a simple cycle of lengthdata:image/s3,"s3://crabby-images/b82d5/b82d5dcef4a401278c79d851158c8ce686c75a26" alt=""
data:image/s3,"s3://crabby-images/89edc/89edcb24c08dcb17841c31c430b6f8638cf3b43f" alt=""
By applying random coloring method, each simple cycle has a probability of
data:image/s3,"s3://crabby-images/68b04/68b042f8d2f461f69bebe434089fd8ea2f4240d3" alt=""
data:image/s3,"s3://crabby-images/97513/97513e0be0c7d05e60913b6b47e83caa6690bbce" alt=""
data:image/s3,"s3://crabby-images/098b2/098b2041de10140a3db758d5de58829c3cd3f8b7" alt=""
data:image/s3,"s3://crabby-images/45761/457618b853844a86105295dc05740a41660e223f" alt=""
data:image/s3,"s3://crabby-images/d73bb/d73bbb55ad62a69db0fe950c8dcc73ba1c9c9756" alt=""
data:image/s3,"s3://crabby-images/9f541/9f541deeeb8755c18b0a5aa1d2468aebf6666e96" alt=""
data:image/s3,"s3://crabby-images/70095/70095e410a832ee9d393fc1fce7ae76866ece730" alt=""
data:image/s3,"s3://crabby-images/ebcd8/ebcd8cb6f6c9c2115c5527ceeefb18e2ea61e5f1" alt=""
data:image/s3,"s3://crabby-images/13e8f/13e8f063e13b32288656d935286557bac8e492a7" alt=""
The colorful cycle-finding algorithm works by first finding all pairs of vertices in V that are connected by a simple path of length k − 1, and then checking whether the two vertices in each pair are connected. Given a coloring function
data:image/s3,"s3://crabby-images/10d4f/10d4f0c7f152ad5559c4f069272eea66f0a297be" alt=""
data:image/s3,"s3://crabby-images/24ff7/24ff74b96cb2c2a102bb940088a6febb9c94e2ba" alt=""
data:image/s3,"s3://crabby-images/cfa16/cfa1686e4544825b4218914420ad7acea161fbaf" alt=""
data:image/s3,"s3://crabby-images/30cf9/30cf97265d394e312c0747e68a4665171270632e" alt=""
data:image/s3,"s3://crabby-images/d136c/d136cefe1cd43e672cb0797f3755fa6d521ab661" alt=""
data:image/s3,"s3://crabby-images/11a2b/11a2b32f20fa4ab47cb19c17b0655d50eb1d72cd" alt=""
data:image/s3,"s3://crabby-images/9d863/9d863c538f218b4debcc9daad215e7ca70da33d0" alt=""
data:image/s3,"s3://crabby-images/91d94/91d94eaaa5fd5e274ef682916340b60e7b6a42f9" alt=""
data:image/s3,"s3://crabby-images/caa2e/caa2e88f5edef1f3061ccb1d38555449d6581366" alt=""
data:image/s3,"s3://crabby-images/932a1/932a15eff956e4fb0f2407ce3842456f99c757ab" alt=""
data:image/s3,"s3://crabby-images/54574/5457424bb4303f6a3a17f10366ad56f680ac015b" alt=""
data:image/s3,"s3://crabby-images/201f1/201f1d2f34e44acaea9fb558291f95cb811dafc2" alt=""
data:image/s3,"s3://crabby-images/73b7c/73b7ce6568487430f1b3d1f1d8c875319e43c5a5" alt=""
data:image/s3,"s3://crabby-images/75478/75478549055014d3f0adb068a5752689b88fdb1a" alt=""
data:image/s3,"s3://crabby-images/16ed6/16ed6f610a19bcc79dd50e7888f05bce29403732" alt=""
data:image/s3,"s3://crabby-images/09e69/09e6954ba75b0cb0918fa17451d14acaab170773" alt=""
data:image/s3,"s3://crabby-images/9db3d/9db3dde3041dab52c52bbd54a3d5431e81bb4bb3" alt=""
data:image/s3,"s3://crabby-images/1a153/1a153dd6e3f6720a982d3c15be28da80c0e90057" alt=""
data:image/s3,"s3://crabby-images/8722c/8722cb8b0eb01f559833ee4a28f7b7123891a131" alt=""
data:image/s3,"s3://crabby-images/0f4e9/0f4e993a8386ebd27caccea3bce325c3e2c701e4" alt=""
data:image/s3,"s3://crabby-images/62640/62640211cd3dd7f61b7b3d85c597af3349501041" alt=""
data:image/s3,"s3://crabby-images/09b9c/09b9c17c4be343c0b61f929443156dfcf0c8399a" alt=""
data:image/s3,"s3://crabby-images/6d5f3/6d5f34fe047868987e5b83836dbb52a7d9b6457a" alt=""
data:image/s3,"s3://crabby-images/12552/125524cfa05e24bcaeb7ec532dec025364b68c1f" alt=""
data:image/s3,"s3://crabby-images/8020f/8020ffd34920db506309ee63a9b3b107ee262359" alt=""
data:image/s3,"s3://crabby-images/492bd/492bd419dbfa8156ef6fdb2460b642a75a12309f" alt=""
data:image/s3,"s3://crabby-images/c5158/c5158e1266ea3f8e0c83d61cf32c358402d14570" alt=""
data:image/s3,"s3://crabby-images/b9d82/b9d8230c04670215f0a0be6e7d6388b5e9fc6e24" alt=""
Derandomization
The derandomization of color-coding involves enumerating possible colorings of a graphdata:image/s3,"s3://crabby-images/11f59/11f59abc52ed263974253f3024a63079dab61efc" alt=""
data:image/s3,"s3://crabby-images/acf77/acf77b80912ae52a54644bdf136b8394ed380dd9" alt=""
data:image/s3,"s3://crabby-images/82e2c/82e2c455be2ca9ff6826b9f824d9ee4352d64029" alt=""
data:image/s3,"s3://crabby-images/f5b29/f5b29c8f3026957d6f42ea244c91a0d3c88a36e9" alt=""
data:image/s3,"s3://crabby-images/dace0/dace0f645a88ee91b613ba77c960f054799d3960" alt=""
data:image/s3,"s3://crabby-images/d0586/d058688e46386d1ecf07a45e67d398d084f08418" alt=""
data:image/s3,"s3://crabby-images/52fb1/52fb1cfa6b1396d99461ea50e807211ffc4831bb" alt=""
data:image/s3,"s3://crabby-images/b30fe/b30fe9f866667f84a2fa32bbc13cfac20f331ba6" alt=""
data:image/s3,"s3://crabby-images/13462/134623eb75ad9bcc1a1bc0b801ead66d7a99e1be" alt=""
data:image/s3,"s3://crabby-images/8b39f/8b39fa10fd1a5d5c3ce3431053624a6afb0d50d4" alt=""
data:image/s3,"s3://crabby-images/4b543/4b54302ccacdbf66a85156df81312a2f69571836" alt=""
data:image/s3,"s3://crabby-images/0d226/0d2261f571f4d283ec2258ba73975b9204989ab5" alt=""
data:image/s3,"s3://crabby-images/a60f0/a60f0b36527d84ba26dafeff7d54e4c45cda8ca4" alt=""
data:image/s3,"s3://crabby-images/519d8/519d8f96971f2c8555020424d175287a4e47f3e5" alt=""
data:image/s3,"s3://crabby-images/2ece2/2ece2a71acfeb4694d6aebdd28fea68a57b229f2" alt=""
data:image/s3,"s3://crabby-images/62e82/62e82c39788542657b7713a4335007d7578c0b7e" alt=""
data:image/s3,"s3://crabby-images/cea79/cea793e47a5c14b3822df9625ff5b24ee371674a" alt=""
data:image/s3,"s3://crabby-images/9e817/9e8176cc88897e3a18b7ded79a0bf07559b2c38e" alt=""
There are several approaches to construct such a
data:image/s3,"s3://crabby-images/abf1a/abf1ab04f5f397dfeff551ae8cc398355824db70" alt=""
- The best explicit construction is by Moni NaorMoni NaorMoni Naor is an Israeli computer scientist, currently a professor at the Weizmann Institute of Science. Naor received his Ph.D. in 1989 at the University of California, Berkeley. His adviser was Manuel Blum....
, Leonard J. Schulman, and Aravind Srinivasan, where a family of sizecan be obtained. This construction does not require the target subgraph to exist in the original subgraph finding problem.
- Another explicit construction by Jeanette P. Schmidt and Alan SiegelAlan SiegelAlan Siegel is founder and Chairman of Siegel+Gale.-Early life:Alan Siegel was born August 26, 1938 to Eugene and Ruth Siegel in New York. Siegel attended Long Beach High where he played basketball under Robert Gersten. His dream was always to go to college on a basketball scholarship...
yields a family of size.
- Another construction that appears in the original paper of Noga AlonNoga AlonNoga Alon is an Israeli mathematician noted for his contributions to combinatorics and theoretical computer science, having authored hundreds of papers.- Academic background :...
et al. can be obtained by first building a-perfect family that maps
to
, followed by building another
-perfect family that maps
to
. In the first step, it is possible to construct such a family with
random bits that are almost
-wise independent, and the sample space needed for generating those random bits can be as small as
. In the second step, it has been shown by Jeanette P. Schmidt and Alan Siegel that the size of such
-perfect family can be
. Consequently, by composing the
-perfect families from both steps, a
-perfect family of size
that maps from
to
can be obtained.
In the case of derandomizing well-coloring, where each vertex on the subgraph is colored consecutively, a
data:image/s3,"s3://crabby-images/110e3/110e315d28ad9f1a4cc5058e81fcb802ff9494ef" alt=""
data:image/s3,"s3://crabby-images/a1cbe/a1cbe69a2e1d16ebd4a3fb4d9d75f6091e19607b" alt=""
data:image/s3,"s3://crabby-images/19bbd/19bbd5f49ece5a2fefb1f913d7530ce297896d9c" alt=""
data:image/s3,"s3://crabby-images/3eb9d/3eb9de301e750e9883f34201f0548b9f1309db58" alt=""
data:image/s3,"s3://crabby-images/d2335/d233525ac78c76578a417d975e069583a2102e24" alt=""
data:image/s3,"s3://crabby-images/86d5a/86d5a7fe964cdc30f67340db105b2b6551486687" alt=""
data:image/s3,"s3://crabby-images/1e199/1e1990f251492cd0798040597bfcb1fa386ed552" alt=""
data:image/s3,"s3://crabby-images/9174f/9174f1ac8dac5d3ab7fbe1b03876c532d925b70b" alt=""
data:image/s3,"s3://crabby-images/9a834/9a8340ab8e43bd32bd95a98bbcb9f389a3047ddd" alt=""
data:image/s3,"s3://crabby-images/7c8de/7c8de983a95e4b461bbabd55de4e1d9941e0f67d" alt=""
The derandomization of color-coding method can be easily parallelized, yielding efficient NC
NC (complexity)
In complexity theory, the class NC is the set of decision problems decidable in polylogarithmic time on a parallel computer with a polynomial number of processors. In other words, a problem is in NC if there exist constants c and k such that it can be solved in time O using O parallel processors...
algorithms.
Applications
Recently, color coding has attracted much attention in the field of bioinformatics. One example is the detection of signaling pathwaysWnt signaling pathway
The Wnt signaling pathway is a network of proteins best known for their roles in embryogenesis and cancer, but also involved in normal physiological processes in adult animals.-Discovery:...
in protein-protein interaction
Protein-protein interaction
Protein–protein interactions occur when two or more proteins bind together, often to carry out their biological function. Many of the most important molecular processes in the cell such as DNA replication are carried out by large molecular machines that are built from a large number of protein...
(PPI) networks. Another example is to discover and to count the number of motifs
Structural motif
In a chain-like biological molecule, such as a protein or nucleic acid, a structural motif is a supersecondary structure, which appears also in a variety of other molecules...
in PPI networks. Studying both signaling pathways
Wnt signaling pathway
The Wnt signaling pathway is a network of proteins best known for their roles in embryogenesis and cancer, but also involved in normal physiological processes in adult animals.-Discovery:...
and motifs
Structural motif
In a chain-like biological molecule, such as a protein or nucleic acid, a structural motif is a supersecondary structure, which appears also in a variety of other molecules...
allows a deeper understanding of the similarities and differences of many biological functions, processes, and structures among organisms.
Due to the huge amount of gene data that can be collected, searching for pathways or motifs can be highly time consuming. However, by exploiting the color coding method, the motifs or signaling pathways with
data:image/s3,"s3://crabby-images/fb321/fb321d06ce5c51589a77b8d31b27e428c7f144bb" alt=""
data:image/s3,"s3://crabby-images/5ae3a/5ae3aad4269427c63a6cc34acd618eef70a52641" alt=""
data:image/s3,"s3://crabby-images/49f6a/49f6a3e02f6afcf595a186a9fc164228831c812a" alt=""