data:image/s3,"s3://crabby-images/ca364/ca36463f9b82c90b6f3e27c6326cdcdc31617e4c" alt=""
Edmonds's algorithm
Encyclopedia
In graph theory
, a branch of mathematics, Edmonds' algorithm or Chu–Liu/Edmonds' algorithm is an algorithm
for finding a maximum or minimum optimum branchings. When nodes are connected by weighted edges that are directed
, a minimum spanning tree
algorithm cannot be used. Instead an optimum branching algorithm should be applied using the algorithm proposed independently first by Yoeng-jin Chu and Tseng-hong Liu (1965) and then by Edmonds
(1967). To find a maximum path length, the largest edge value is found and connected between the two nodes, then the next largest value, and so on. If an edge creates a loop, it is erased. A minimum path length is found by starting from the smallest value.
. There is a faster implementation of the algorithm by Robert Tarjan
. The order is
for a sparse graph and
for a dense graph. This is as fast as Prim's algorithm
for an undirected minimum spanning tree. In 1986, Gabow, Galil, Spencer, and Tarjan made a faster implementation, and its order is
.
the function which, given a weighted directed graph
with a distinguished vertex
called the root, returns a spanning tree rooted at
of minimal cost.
The precise description is as follows. Given a weighted directed graph
with root
we first replace any set of parallel edges (edges between the same pair of vertices in the same direction) by a single edge with weight equal to the minimum of the weights of these parallel edges.
Now, for each node
other than the root, mark an (arbitrarily chosen) incoming edge of lowest cost. Denote the other endpoint of this edge by
. If the marked edges form an SRT,
is defined to be this SRT. Otherwise, the set of marked edges form at least one cycle. Call (an arbitrarily chosen) one of these cycles
. We now define a weighted directed graph
having a root
as follows. The nodes of
are the nodes of
not in
plus a new node denoted
.
If
is an edge in
with
, include the edge
described below, in
.
If
,
, and
.
Otherwise, if
, let
, and
.
We include no other edges in
.
The root
of
is simply the root
in
.
Using a call to
, find an SRT in
. Suppose in this SRT, the (unique) incoming edge at
is
. This edge comes from some pair
with
and
. Unmark
and mark
. Now the set of marked edges do form an SRT, which we define to be the value of
.
Observe that
is defined in terms of
for weigthed directed rooted graphs
having strictly fewer vertices than
, and finding
for a single-vertex graph is trivial.
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...
, a branch of mathematics, Edmonds' algorithm or Chu–Liu/Edmonds' algorithm is an algorithm
Algorithm
In mathematics and computer science, an algorithm is an effective method expressed as a finite list of well-defined instructions for calculating a function. Algorithms are used for calculation, data processing, and automated reasoning...
for finding a maximum or minimum optimum branchings. When nodes are connected by weighted edges that are directed
Directed graph
A directed graph or digraph is a pair G= of:* a set V, whose elements are called vertices or nodes,...
, a minimum spanning tree
Minimum spanning tree
Given a connected, undirected graph, a spanning tree of that graph is a subgraph that is a tree and connects all the vertices together. A single graph can have many different spanning trees...
algorithm cannot be used. Instead an optimum branching algorithm should be applied using the algorithm proposed independently first by Yoeng-jin Chu and Tseng-hong Liu (1965) and then by Edmonds
Jack Edmonds
Jack R. Edmonds is a mathematician, regarded as one of the most important contributors to the field of combinatorial optimization...
(1967). To find a maximum path length, the largest edge value is found and connected between the two nodes, then the next largest value, and so on. If an edge creates a loop, it is erased. A minimum path length is found by starting from the smallest value.
Order
The order of this algorithm isdata:image/s3,"s3://crabby-images/b135b/b135b62acd7d40c8be28f18a81ac7310eea5bb70" alt=""
Robert Tarjan
Robert Endre Tarjan is a renowned American computer scientist. He is the discoverer of several important graph algorithms, including Tarjan's off-line least common ancestors algorithm, and co-inventor of both splay trees and Fibonacci heaps. Tarjan is currently the James S...
. The order is
data:image/s3,"s3://crabby-images/ddf6d/ddf6dd03457e7968187f492823ac1dfe43dba59c" alt=""
data:image/s3,"s3://crabby-images/046bf/046bf5d69e185cd78e2c9e6a0fe4b0c771038284" alt=""
Prim's algorithm
In computer science, Prim's algorithm is a greedy algorithm that finds a minimum spanning tree for a connected weighted undirected graph. This means it finds a subset of the edges that forms a tree that includes every vertex, where the total weight of all the edges in the tree is minimized...
for an undirected minimum spanning tree. In 1986, Gabow, Galil, Spencer, and Tarjan made a faster implementation, and its order is
data:image/s3,"s3://crabby-images/9f0d7/9f0d7378d1553baabe5626ffc275504fa08612d4" alt=""
Description
The algorithm has a conceptual recursive description. We will denote bydata:image/s3,"s3://crabby-images/7a460/7a46005d283d34b0ccb079ae6395fc59cb0dc631" alt=""
data:image/s3,"s3://crabby-images/18d76/18d762a6c99670ecae8b56a1ef108b9c5cd2a77c" alt=""
data:image/s3,"s3://crabby-images/06b61/06b61a164ad7a98e7d7917174bf37b6e58a0a234" alt=""
data:image/s3,"s3://crabby-images/cbe68/cbe6805834b91f06d4eaea10893f90f21971b622" alt=""
The precise description is as follows. Given a weighted directed graph
data:image/s3,"s3://crabby-images/6e5c1/6e5c1e9951de6ff0ef1fbf2ceb0ca16721e14e57" alt=""
data:image/s3,"s3://crabby-images/0ece3/0ece3353427c5a970495c3d922364de6f2fb442b" alt=""
Now, for each node
data:image/s3,"s3://crabby-images/d06d4/d06d474cde6cbd781d441dfea93dd84dc367c451" alt=""
data:image/s3,"s3://crabby-images/08bd9/08bd9bbdc832b7bb3ab86223ee2c867c886e611a" alt=""
data:image/s3,"s3://crabby-images/dae0c/dae0c1a60f8c8226d08cf401f15d7796fef0a4f1" alt=""
data:image/s3,"s3://crabby-images/5f8b7/5f8b7feb3501d2852401b54310afe6f2101adb34" alt=""
data:image/s3,"s3://crabby-images/85401/8540127bf1b359e6bd08e7c9b29b7cea335660d1" alt=""
data:image/s3,"s3://crabby-images/683c8/683c8ca2357f06fc9c09f01dd663d6a856635679" alt=""
data:image/s3,"s3://crabby-images/1f33a/1f33a783ee972da665eeca192257fb2501a3c87a" alt=""
data:image/s3,"s3://crabby-images/872f8/872f84aacd91ba51f16f048ae39ffecaaaf5873d" alt=""
data:image/s3,"s3://crabby-images/85901/85901671b2b849b8dc8e448714f5675f15f26d80" alt=""
data:image/s3,"s3://crabby-images/3d153/3d1538d791b56cbfd1d67cf534a72b63bcc2c47c" alt=""
If
data:image/s3,"s3://crabby-images/f9bd1/f9bd12f32cb77e89ef7b98418c62d2873aadad43" alt=""
data:image/s3,"s3://crabby-images/0b570/0b570407a114a4ed02ad3ff2f717d3cf6d6364d2" alt=""
data:image/s3,"s3://crabby-images/fe878/fe878c3bc4d0eaab40873c6736754670a5d478cd" alt=""
data:image/s3,"s3://crabby-images/eecf9/eecf933cdb87a7e72765663f7b0d0af0f6f824c3" alt=""
data:image/s3,"s3://crabby-images/4ded5/4ded578eb1f0df12422844877e42b7961132a31f" alt=""
If
data:image/s3,"s3://crabby-images/fbffc/fbffcc8c7af2987f00b03fff6401aded86f395a2" alt=""
data:image/s3,"s3://crabby-images/91ef3/91ef34ecdd627f5d95800a189d378e904645764e" alt=""
data:image/s3,"s3://crabby-images/b8551/b85514a5b6ec961b75f63a6ece54d39894085816" alt=""
Otherwise, if
data:image/s3,"s3://crabby-images/c4eb4/c4eb4e7ce098de415c537a8ec8ca4f691b71a1a6" alt=""
data:image/s3,"s3://crabby-images/38ef9/38ef9990e5ff3fa89160a56e13a35e1bdd5a17e0" alt=""
data:image/s3,"s3://crabby-images/e353f/e353f48672267ef3e88ed5dd4e2a5f1ac78e886d" alt=""
We include no other edges in
data:image/s3,"s3://crabby-images/7f7e4/7f7e4c2a04fbf15ae3db52b6ee702dc2ecb3fd89" alt=""
The root
data:image/s3,"s3://crabby-images/74b6c/74b6cc846780d3fa24a0b073c5d178c230775a2b" alt=""
data:image/s3,"s3://crabby-images/4d26c/4d26c48fdfaa46d443c01a7518cacf78d02efa37" alt=""
data:image/s3,"s3://crabby-images/8c147/8c147ec590fcacfb092bcc9361f3e9ff34dbc93e" alt=""
data:image/s3,"s3://crabby-images/e6ee9/e6ee95afb7d262d7e2f14a5caa7955c7b0edd038" alt=""
Using a call to
data:image/s3,"s3://crabby-images/f35ae/f35ae152ecab3742fec44985b3ae4919643f28d6" alt=""
data:image/s3,"s3://crabby-images/40aa5/40aa5a78e28a7db4ebf06da6530584a22cbe26ce" alt=""
data:image/s3,"s3://crabby-images/b3e43/b3e43310154304e55c90990a6546229e8bf06914" alt=""
data:image/s3,"s3://crabby-images/a9152/a91528e796cd89aa0354f579dcea345c18514489" alt=""
data:image/s3,"s3://crabby-images/38021/3802125e6e860a9680b090cf4fea5fc88ccc94b9" alt=""
data:image/s3,"s3://crabby-images/2f2f5/2f2f564c4122660e7bb5fac047610487db010bf9" alt=""
data:image/s3,"s3://crabby-images/04abe/04abe160d67af1a6c3a4851d9b1329fbdd409d9d" alt=""
data:image/s3,"s3://crabby-images/8c263/8c263fb7ae2b94fcd703682f78e30b346b4ab906" alt=""
data:image/s3,"s3://crabby-images/53e04/53e049f39b2a01ebf3953b91613aefaade3626ac" alt=""
data:image/s3,"s3://crabby-images/fa910/fa9109276878b09e831b73764173ab488ff4b69d" alt=""
Observe that
data:image/s3,"s3://crabby-images/83d87/83d87cfff817acdf6cc034c340a171715c40cdd2" alt=""
data:image/s3,"s3://crabby-images/e8c45/e8c45973983c23ec8c1fcdf2847e9a5624046263" alt=""
data:image/s3,"s3://crabby-images/023d8/023d895653269d8ca19818e4539ba41b553b167b" alt=""
data:image/s3,"s3://crabby-images/32d11/32d1139ce4c71877a7cef95e88f827e65bcea6d4" alt=""
data:image/s3,"s3://crabby-images/2d45a/2d45a703706c16319382cf540f9b369fd3b399bf" alt=""
Implementation
Let BV be a vertex bucket and BE be an edge bucket. Let v be a vertex and e be an edge of maximum positive weight that is incident to v. Ci is a circuit. G0 = (V0,E0) is the original digraph. ui is a replacement vertex for Ci.
data:image/s3,"s3://crabby-images/b6273/b6273216001e5fa254eb98f24ccae31684d1954c" alt=""
i=0
A:
if
then goto B
for some vertex
and
{
data:image/s3,"s3://crabby-images/39ec7/39ec72cfcfea3ffaea0dfae0aad0235ee2aa2d6b" alt=""
find an edge
such that w(e) = max{ w(y,v)|(y,v)
Ei}
if w(e) ≤ 0 then goto A
}
if
contains a circuit {
i=i+1
construct
by shrinking
to data:image/s3,"s3://crabby-images/138c3/138c35e59a5d455f6c153160911e7d12cbf5990a" alt=""
modify BE, BV and some edge weights
}
data:image/s3,"s3://crabby-images/8d38b/8d38b5027c719ece34bb0aafac42fc7c32429ad4" alt=""
goto A
B:
while i ≠ 0 {
reconstruct
and rename some edges in BE
if
was a root of an out-tree in BE {
and data:image/s3,"s3://crabby-images/a02ea/a02ea8c5cf49a9c0a6e1bb0439331ada2d600cbd" alt=""
}else{
and data:image/s3,"s3://crabby-images/d76ee/d76ee89502d0fdfe39464049640507b32158ab93" alt=""
}
i=i-1
}
Maximum branching weight = data:image/s3,"s3://crabby-images/0d737/0d737363fcca979182901a7bd396e689cd35f732" alt=""
External links
- The Directed Minimum Spanning Tree Problem Description of the algorithm summarized by Shanchieh Jay Yang, May 2000.
- Edmonds's algorithm ( edmonds-alg ) – An open sourceOpen sourceThe term open source describes practices in production and development that promote access to the end product's source materials. Some consider open source a philosophy, others consider it a pragmatic methodology...
implementation of Edmonds's algorithm written in C++C++C++ is a statically typed, free-form, multi-paradigm, compiled, general-purpose programming language. It is regarded as an intermediate-level language, as it comprises a combination of both high-level and low-level language features. It was developed by Bjarne Stroustrup starting in 1979 at Bell...
and licensed under the MIT LicenseMIT LicenseThe MIT License is a free software license originating at the Massachusetts Institute of Technology . It is a permissive license, meaning that it permits reuse within proprietary software provided all copies of the licensed software include a copy of the MIT License terms...
. This source is using Tarjan's implementation for the dense graph. - AlgoWiki – Edmonds's algorithm - A public-domain implementation of Edmonds's algorithm written in JavaJava (programming language)Java is a programming language originally developed by James Gosling at Sun Microsystems and released in 1995 as a core component of Sun Microsystems' Java platform. The language derives much of its syntax from C and C++ but has a simpler object model and fewer low-level facilities...
.