Given a bipartite graph
data:image/s3,"s3://crabby-images/6548c/6548c80c3107ed44d77cb5c8fe58bd5fcebf5af2" alt=""
, find the maximum weighted bipartite matching.
This problem can be solved using Hungarian Algorithm with
data:image/s3,"s3://crabby-images/0bbb7/0bbb71b81aace75e4e4b24daa9bb66bb434d969b" alt=""
time complexity by iteratively finding the augmenting path.
There is also an algorithm called KM Algorithm which can also solve the maximum weighted bipartite matching.
Suppose the vertices are separated to two sets
data:image/s3,"s3://crabby-images/9e17e/9e17e2a39a2fecc5722e08e6a7c5a375f6c44470" alt=""
and
data:image/s3,"s3://crabby-images/f635e/f635edd4f592c843c23d550e3e8689ab8c7e5fb7" alt=""
. We give node weights to each of them, namely
data:image/s3,"s3://crabby-images/ed0f8/ed0f8e042c856e6ac574d2ed3c0a3ac73d4f2473" alt=""
and
data:image/s3,"s3://crabby-images/7849c/7849c1f04417343e5d8f2876d5cf8b7bcabe5259" alt=""
. KM algorithm states that if a subgraph
data:image/s3,"s3://crabby-images/0dc32/0dc32426b53151266a8c4f0e41b736b9b2363562" alt=""
of
data:image/s3,"s3://crabby-images/bb34c/bb34c680c52cb1c8111edc2a82ed2fdafcdfb85b" alt=""
that satisfies the following properties:
(1)
data:image/s3,"s3://crabby-images/49ed9/49ed9cbd754995c0e10ca95edfc59ad45759f430" alt=""
(2) For any edge
data:image/s3,"s3://crabby-images/095f7/095f7bef0ec5bc0371ad7c74d04326732c8b1935" alt=""
where
data:image/s3,"s3://crabby-images/f224b/f224b4f06936772f00745f852849e3f6e6140352" alt=""
and
data:image/s3,"s3://crabby-images/23aac/23aac8f535703da8725e9ad59b6313dcf94788c3" alt=""
,
data:image/s3,"s3://crabby-images/471d6/471d620d2e0a92f3f3098b12ed73ee16918051cc" alt=""
where
data:image/s3,"s3://crabby-images/40adf/40adff7c3c5e98e17a923b0efbc4297d8684bda4" alt=""
is the weight of the corresponding edge in
data:image/s3,"s3://crabby-images/bb34c/bb34c680c52cb1c8111edc2a82ed2fdafcdfb85b" alt=""
.
(3)
data:image/s3,"s3://crabby-images/0dc32/0dc32426b53151266a8c4f0e41b736b9b2363562" alt=""
contains a perfect matching.
Then
data:image/s3,"s3://crabby-images/0dc32/0dc32426b53151266a8c4f0e41b736b9b2363562" alt=""
is equivalent to the maximum weighted bipartite matching of
data:image/s3,"s3://crabby-images/bb34c/bb34c680c52cb1c8111edc2a82ed2fdafcdfb85b" alt=""
.
[Prove Start]
For any bipartite matching
data:image/s3,"s3://crabby-images/a6e31/a6e3167a9caf420d04881f9d2ff1442be46c76a9" alt=""
, if it is included in
data:image/s3,"s3://crabby-images/0dc32/0dc32426b53151266a8c4f0e41b736b9b2363562" alt=""
, the weight must be the sum of all the node weights. If there is a matched edge in
data:image/s3,"s3://crabby-images/a6e31/a6e3167a9caf420d04881f9d2ff1442be46c76a9" alt=""
but not in
data:image/s3,"s3://crabby-images/0dc32/0dc32426b53151266a8c4f0e41b736b9b2363562" alt=""
, then we can immediately conclude that it's weight sum must be smaller than the total node weights of
data:image/s3,"s3://crabby-images/0dc32/0dc32426b53151266a8c4f0e41b736b9b2363562" alt=""
(By properties (1) and (2)). Then we can see that if property (3) is satisfied, it is a maximum weighted bipartite matching. QED
[Prove Ends]
The algorithm is stated as follow:
(1) Assign
data:image/s3,"s3://crabby-images/451af/451af08ace32cfb903ec54c364a604eb729499bf" alt=""
and
data:image/s3,"s3://crabby-images/c02be/c02bee1840b8d3b4a313c7af22b1a82703e08842" alt=""
to ensure property (1) is satisfied.
(2) If
data:image/s3,"s3://crabby-images/0dc32/0dc32426b53151266a8c4f0e41b736b9b2363562" alt=""
has perfect matching, done
(3) If (2) does not hold, we can always find a path
data:image/s3,"s3://crabby-images/d8a4a/d8a4a6e36d01017121f00874b181bd64fb84a176" alt=""
from
data:image/s3,"s3://crabby-images/0dc32/0dc32426b53151266a8c4f0e41b736b9b2363562" alt=""
such that it both starts and ends with nodes in
data:image/s3,"s3://crabby-images/9e17e/9e17e2a39a2fecc5722e08e6a7c5a375f6c44470" alt=""
.
(4) For any path
data:image/s3,"s3://crabby-images/d8a4a/d8a4a6e36d01017121f00874b181bd64fb84a176" alt=""
described in (3), we decrease node weights
data:image/s3,"s3://crabby-images/9fd75/9fd755d4cd6f6655a968e606923f4e69a6cf481e" alt=""
with the nodes in
data:image/s3,"s3://crabby-images/9e17e/9e17e2a39a2fecc5722e08e6a7c5a375f6c44470" alt=""
and increase
data:image/s3,"s3://crabby-images/9fd75/9fd755d4cd6f6655a968e606923f4e69a6cf481e" alt=""
with nodes in
data:image/s3,"s3://crabby-images/f635e/f635edd4f592c843c23d550e3e8689ab8c7e5fb7" alt=""
.
data:image/s3,"s3://crabby-images/0dc32/0dc32426b53151266a8c4f0e41b736b9b2363562" alt=""
can be said to be "augmented".
[Prove]
Consider two vertices
data:image/s3,"s3://crabby-images/af3a9/af3a9eb2b405b8d0d8fef27ecac040fe8bdffa02" alt=""
and
data:image/s3,"s3://crabby-images/5f252/5f252e5bd1425d1958196d8b50cdbc9ec1f9ca48" alt=""
,
Case 1:
data:image/s3,"s3://crabby-images/d34df/d34df014cf223506cffa54e789320687a2ae89a4" alt=""
data:image/s3,"s3://crabby-images/0dc32/0dc32426b53151266a8c4f0e41b736b9b2363562" alt=""
unchanged
Case 2:
data:image/s3,"s3://crabby-images/55149/55149dcf4a926270b23bd86964d1beff351b026c" alt=""
data:image/s3,"s3://crabby-images/fbde5/fbde5764773bf9c3865f34db0882fbf17b6f2f8d" alt=""
data:image/s3,"s3://crabby-images/d8a4a/d8a4a6e36d01017121f00874b181bd64fb84a176" alt=""
data:image/s3,"s3://crabby-images/0dc32/0dc32426b53151266a8c4f0e41b736b9b2363562" alt=""
is unchanged
Case 3:
data:image/s3,"s3://crabby-images/69604/69604a60ae7e14b7ad0b05b2f8f2a18f1f4036ea" alt=""
while
data:image/s3,"s3://crabby-images/e234b/e234bd6b2b5dc108a4b83a7e9f476acdaf312d6b" alt=""
is not
Note that
data:image/s3,"s3://crabby-images/51908/51908e2bf059e85b3a8d47d19f477c4d9d744c09" alt=""
is decreased. the edge
data:image/s3,"s3://crabby-images/e17ba/e17baf32e02499e55948a54d815985556ef70865" alt=""
is more likely to be included in
data:image/s3,"s3://crabby-images/0dc32/0dc32426b53151266a8c4f0e41b736b9b2363562" alt=""
to have prefect matching
Case 4:
data:image/s3,"s3://crabby-images/8d00a/8d00a5531885084326f1871a5e706069e90ffedf" alt=""
is not in
data:image/s3,"s3://crabby-images/d8a4a/d8a4a6e36d01017121f00874b181bd64fb84a176" alt=""
while
data:image/s3,"s3://crabby-images/e234b/e234bd6b2b5dc108a4b83a7e9f476acdaf312d6b" alt=""
is
Note that
data:image/s3,"s3://crabby-images/51908/51908e2bf059e85b3a8d47d19f477c4d9d744c09" alt=""
is increased. By property (1) the edge
data:image/s3,"s3://crabby-images/e17ba/e17baf32e02499e55948a54d815985556ef70865" alt=""
will not be included in
data:image/s3,"s3://crabby-images/0dc32/0dc32426b53151266a8c4f0e41b736b9b2363562" alt=""
to have prefect matching
[/Prove]
(5) Reconstruct
data:image/s3,"s3://crabby-images/0dc32/0dc32426b53151266a8c4f0e41b736b9b2363562" alt=""
and repeat from (1) again.
How to find
data:image/s3,"s3://crabby-images/9fd75/9fd755d4cd6f6655a968e606923f4e69a6cf481e" alt=""
remains the last problem. We want to make sure the followings are satisfied after (4):
(i) Property 1 holds
(ii) At least one edge is included in
data:image/s3,"s3://crabby-images/0dc32/0dc32426b53151266a8c4f0e41b736b9b2363562" alt=""
Therefore we would like to decrease an amount such that Case 3 is satisfied. We then choose
data:image/s3,"s3://crabby-images/6df70/6df70fe63295d635813eb3ceb310ec409295c1bb" alt=""
to proceed the algorithm.
Obviously the algorithm runs in
data:image/s3,"s3://crabby-images/5d86f/5d86f0360da25ec73e85a54ac9f452a3661f3892" alt=""
time. By memorizing the candidates for
data:image/s3,"s3://crabby-images/9fd75/9fd755d4cd6f6655a968e606923f4e69a6cf481e" alt=""
(we call them "slack"), we can speed it up in
data:image/s3,"s3://crabby-images/86e40/86e405010667b327c73cee6c14f9b266e877f5b4" alt=""
time.