data:image/s3,"s3://crabby-images/ca364/ca36463f9b82c90b6f3e27c6326cdcdc31617e4c" alt=""
Maximum coverage problem
Encyclopedia
The maximum coverage problem is a classical question in computer science
and computational complexity theory
.
It is a problem that is widely taught in approximation algorithms.
As input you are given several sets and a number
.
The sets may have some elements in common.
You must select at most
of these sets such that the maximum number of elements are covered,
i.e. the union of the selected sets has maximal size.
Formally, (unweighted) Maximum Coverage
The maximum coverage problem is NP-hard
, and cannot be approximated within
under standard assumptions.
This result essentially matches the approximation ratio achieved by the greedy algorithm.
for maximum coverage chooses sets according to one rule: at each stage, choose a set which contains the largest number of uncovered elements. It can be shown that this algorithm achieves an approximation ratio of
.
Inapproximability results show that the greedy algorithm is essentially the best-possible polynomial time approximation
algorithm for maximum coverage.
has a weight
. The task is to find a maximum coverage which has maximum weight. The basic version is a special case when all weights are
.
The greedy algorithm for the weighted maximum coverage at each stage chooses a set which contains the maximum weight of uncovered elements. This algorithm achieves an approximation ratio of
.
have a weight
, but also every set
has a cost
. Instead of
that limits the number of sets in the cover a budget
is given. This budget
limits the weight of the cover that can be chosen.
A greedy algorithm will no longer produce solutions with a performance guarantee. Namely, the worst case behavior of this algorithm might be very far from the optimal solution. The approximation algorithm is extended by the following way. First, after finding a solution using the greedy algorithm, return the better of the greedy algorithm's solution and the set of largest weight. Call this algorithm the modified greedy algorithm. Second, starting with all possible families of sets of sizes from one to (at least) three, augment these solutions with the modified greedy algorithm. Third, return the best out of all augmented solutions. This algorithm achieves an approximation ratio of
. This is the best possible approximation ratio unless
.
has a cost
,
element
has a different weight and cost depending on which set covers it.
Namely, if
is covered by set
the weight of data:image/s3,"s3://crabby-images/e46be/e46be0977a3e449a44e75dc0dd9866b1dc58f4a9" alt=""
is
and its cost is
.
A budget
is given for the total cost of the solution.
The algorithm has several stages. First, find a solution using greedy algorithm. In each iteration of the greedy algorithm the tentative solution is added the set which contains the maximum residual weight of elements divided by the residual cost of these elements along with the residual cost of the set. Second, compare the solution gained by the first step to the best solution which uses a small number of sets. Third, return the best out of all examined solutions. This algorithm achieves an approximation ratio of
.
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 computational complexity theory
Computational complexity theory
Computational complexity theory is a branch of the theory of computation in theoretical computer science and mathematics that focuses on classifying computational problems according to their inherent difficulty, and relating those classes to each other...
.
It is a problem that is widely taught in approximation algorithms.
As input you are given several sets and a number
data:image/s3,"s3://crabby-images/dd43e/dd43e2657c6982ffe892081a9629d1b64b4740d9" alt=""
The sets may have some elements in common.
You must select at most
data:image/s3,"s3://crabby-images/62cc3/62cc3dc161d5ab4e6dfa548b34d37b58e2cd6eec" alt=""
i.e. the union of the selected sets has maximal size.
Formally, (unweighted) Maximum Coverage
- Instance: A number
and a collection of sets
, where
.
- Objective: Find a subset
of sets, such that
and the number of covered elements
is maximized.
The maximum coverage problem is NP-hard
NP-hard
NP-hard , in computational complexity theory, is a class of problems that are, informally, "at least as hard as the hardest problems in NP". A problem H is NP-hard if and only if there is an NP-complete problem L that is polynomial time Turing-reducible to H...
, and cannot be approximated within
data:image/s3,"s3://crabby-images/832fd/832fd584e9b9795d671e9699084dcba61f8ead73" alt=""
This result essentially matches the approximation ratio achieved by the greedy algorithm.
ILP formulation
The maximum coverage problem can be formulated as the following integer linear program.- maximize
. (maximizing the sum of covered elements).
- subject to
; (no more than
sets are selected).
; (if
then at least one set
is selected).
; (if
then
is covered)
(if
then
is selected for the cover).
Greedy algorithm
The greedy algorithmGreedy algorithm
A greedy algorithm is any algorithm that follows the problem solving heuristic of making the locally optimal choice at each stagewith the hope of finding the global optimum....
for maximum coverage chooses sets according to one rule: at each stage, choose a set which contains the largest number of uncovered elements. It can be shown that this algorithm achieves an approximation ratio of
data:image/s3,"s3://crabby-images/c1b95/c1b953aa9877b8737aa9e653d90ea3654574d466" alt=""
Inapproximability results show that the greedy algorithm is essentially the best-possible polynomial time approximation
algorithm for maximum coverage.
Known extensions
The inapproximability results apply to all extension all maximum coverage since they hold maximum coverage as a special case.Weighted version
In the weighted version every elementdata:image/s3,"s3://crabby-images/7f3dd/7f3dd547537b74a9005db14e4aad48e841e37084" alt=""
data:image/s3,"s3://crabby-images/076ec/076ec5a8d49720dc09288ea6591094287ea1407a" alt=""
data:image/s3,"s3://crabby-images/cc1c3/cc1c3ea741a34e6f03adcfea920ea07de874994b" alt=""
- maximize
. (maximizing the weighted sum of covered elements).
- subject to
; (no more than
sets are selected).
; (if
then at least one set
is selected).
; (if
then
is covered)
(if
then
is selected for the cover).
The greedy algorithm for the weighted maximum coverage at each stage chooses a set which contains the maximum weight of uncovered elements. This algorithm achieves an approximation ratio of
data:image/s3,"s3://crabby-images/6bc8c/6bc8cd32eaac1c666e9b7cfab5e12ca14d632357" alt=""
Budgeted maximum coverage
In the budgeted maximum coverage version, not only does every elementdata:image/s3,"s3://crabby-images/c6078/c60780d1968b6f6ba634f36ed5d078934d333ae9" alt=""
data:image/s3,"s3://crabby-images/79e80/79e80a94d0606a90eb606554d6e3321e1e2645f1" alt=""
data:image/s3,"s3://crabby-images/81caf/81cafde37a59189f49d735f497bec78b0f1208a6" alt=""
data:image/s3,"s3://crabby-images/952c5/952c5bea206e5dc495025ed3aba60928494d073b" alt=""
data:image/s3,"s3://crabby-images/a8cbb/a8cbbaa7779be8bed83330de49d9415dd1b38352" alt=""
data:image/s3,"s3://crabby-images/9889e/9889efaf9b9e7db61e001e8bf3beb0384382c641" alt=""
data:image/s3,"s3://crabby-images/20208/20208bb397c579416c1710a5eb0ab8d27bdb2a54" alt=""
- maximize
. (maximizing the weighted sum of covered elements).
- subject to
; (the cost of the selected sets cannot exceed
).
; (if
then at least one set
is selected).
; (if
then
is covered)
(if
then
is selected for the cover).
A greedy algorithm will no longer produce solutions with a performance guarantee. Namely, the worst case behavior of this algorithm might be very far from the optimal solution. The approximation algorithm is extended by the following way. First, after finding a solution using the greedy algorithm, return the better of the greedy algorithm's solution and the set of largest weight. Call this algorithm the modified greedy algorithm. Second, starting with all possible families of sets of sizes from one to (at least) three, augment these solutions with the modified greedy algorithm. Third, return the best out of all augmented solutions. This algorithm achieves an approximation ratio of
data:image/s3,"s3://crabby-images/a76bc/a76bc66d4abfb8601c55e9f9c5099bec9446d46f" alt=""
data:image/s3,"s3://crabby-images/f2b2e/f2b2e8079b43879627eeef1d02ffaabc1dbca538" alt=""
Generalized maximum coverage
In the generalized maximum coverage version every setdata:image/s3,"s3://crabby-images/7136d/7136d06825eefe17ca29b0cde0c641234870bafd" alt=""
data:image/s3,"s3://crabby-images/e90c0/e90c0d90b4ce7e2d7ab8cf4f3825a156c71f7345" alt=""
element
data:image/s3,"s3://crabby-images/d65fa/d65fa9c38bb25d9b6a7a18b6580dc4b9c5e13aa8" alt=""
Namely, if
data:image/s3,"s3://crabby-images/8637a/8637a1df7a9eaa2e1a34282dea75a709c73f1920" alt=""
data:image/s3,"s3://crabby-images/0d9e3/0d9e3e6fed7a8beefe36e9cfe1392b2d64dc3bbc" alt=""
data:image/s3,"s3://crabby-images/e46be/e46be0977a3e449a44e75dc0dd9866b1dc58f4a9" alt=""
is
data:image/s3,"s3://crabby-images/5b3bc/5b3bcc1af614af944015fe6ed534c1270571af3d" alt=""
data:image/s3,"s3://crabby-images/03b83/03b83f4ef3c955cc8eee6388e807420b5eb7a4cc" alt=""
A budget
data:image/s3,"s3://crabby-images/c729e/c729e2b3b737425e78b884ebe7533c888de5aa5f" alt=""
- maximize
. (maximizing the weighted sum of covered elements in the sets in which they are covered).
- subject to
; (the cost of the selected sets cannot exceed
).
; (element
can only be covered by at most one set).
; (if
then at least one set
is selected).
; (if
then
is covered by set
)
(if
then
is selected for the cover).
Generalized maximum coverage algorithm
The algorithm uses the concept of residual cost/weight. The residual cost/weight is measured against a tentative solution and its the difference of the cost/weight from the cost/weight gained by a tentative solution.The algorithm has several stages. First, find a solution using greedy algorithm. In each iteration of the greedy algorithm the tentative solution is added the set which contains the maximum residual weight of elements divided by the residual cost of these elements along with the residual cost of the set. Second, compare the solution gained by the first step to the best solution which uses a small number of sets. Third, return the best out of all examined solutions. This algorithm achieves an approximation ratio of
data:image/s3,"s3://crabby-images/eae8e/eae8e857b971ff6ae98f14d4044c59af6dcde6a6" alt=""
Related problems
- Set cover problemSet cover problemThe set covering problem is a classical question in computer science and complexity theory.It is a problem "whose study has led to the development of fundamental techniques for the entire field" of approximation algorithms...
is to cover all elements with as few sets as possible.