Misplaced Pages

Knapsack problem

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
(Redirected from Binary knapsack problem) Problem in combinatorial optimization
Example of a one-dimensional (constraint) knapsack problem: which books should be chosen to maximize the amount of money while still keeping the overall weight under or equal to 15 kg? A multiple constrained problem could consider both the weight and volume of the books.
(Solution: if any number of each book is available, then three yellow books and three grey books; if only the shown books are available, then all except for the green book.)

The knapsack problem is the following problem in combinatorial optimization:

Given a set of items, each with a weight and a value, determine which items to include in the collection so that the total weight is less than or equal to a given limit and the total value is as large as possible.

It derives its name from the problem faced by someone who is constrained by a fixed-size knapsack and must fill it with the most valuable items. The problem often arises in resource allocation where the decision-makers have to choose from a set of non-divisible projects or tasks under a fixed budget or time constraint, respectively.

The knapsack problem has been studied for more than a century, with early works dating as far back as 1897.

The subset sum problem is a special case of the decision and 0-1 problems where each kind of item, the weight equals the value: w i = v i {\displaystyle w_{i}=v_{i}} . In the field of cryptography, the term knapsack problem is often used to refer specifically to the subset sum problem. The subset sum problem is one of Karp's 21 NP-complete problems.

Applications

Knapsack problems appear in real-world decision-making processes in a wide variety of fields, such as finding the least wasteful way to cut raw materials, selection of investments and portfolios, selection of assets for asset-backed securitization, and generating keys for the Merkle–Hellman and other knapsack cryptosystems.

One early application of knapsack algorithms was in the construction and scoring of tests in which the test-takers have a choice as to which questions they answer. For small examples, it is a fairly simple process to provide the test-takers with such a choice. For example, if an exam contains 12 questions each worth 10 points, the test-taker need only answer 10 questions to achieve a maximum possible score of 100 points. However, on tests with a heterogeneous distribution of point values, it is more difficult to provide choices. Feuerman and Weiss proposed a system in which students are given a heterogeneous test with a total of 125 possible points. The students are asked to answer all of the questions to the best of their abilities. Of the possible subsets of problems whose total point values add up to 100, a knapsack algorithm would determine which subset gives each student the highest possible score.

A 1999 study of the Stony Brook University Algorithm Repository showed that, out of 75 algorithmic problems related to the field of combinatorial algorithms and algorithm engineering, the knapsack problem was the 19th most popular and the third most needed after suffix trees and the bin packing problem.

Definition

The most common problem being solved is the 0-1 knapsack problem, which restricts the number x i {\displaystyle x_{i}} of copies of each kind of item to zero or one. Given a set of n {\displaystyle n} items numbered from 1 up to n {\displaystyle n} , each with a weight w i {\displaystyle w_{i}} and a value v i {\displaystyle v_{i}} , along with a maximum weight capacity W {\displaystyle W} ,

maximize i = 1 n v i x i {\displaystyle \sum _{i=1}^{n}v_{i}x_{i}}
subject to i = 1 n w i x i W {\displaystyle \sum _{i=1}^{n}w_{i}x_{i}\leq W} and x i { 0 , 1 } {\displaystyle x_{i}\in \{0,1\}} .

Here x i {\displaystyle x_{i}} represents the number of instances of item i {\displaystyle i} to include in the knapsack. Informally, the problem is to maximize the sum of the values of the items in the knapsack so that the sum of the weights is less than or equal to the knapsack's capacity.

The bounded knapsack problem (BKP) removes the restriction that there is only one of each item, but restricts the number x i {\displaystyle x_{i}} of copies of each kind of item to a maximum non-negative integer value c {\displaystyle c} :

maximize i = 1 n v i x i {\displaystyle \sum _{i=1}^{n}v_{i}x_{i}}
subject to i = 1 n w i x i W {\displaystyle \sum _{i=1}^{n}w_{i}x_{i}\leq W} and x i { 0 , 1 , 2 , , c } . {\displaystyle x_{i}\in \{0,1,2,\dots ,c\}.}

The unbounded knapsack problem (UKP) places no upper bound on the number of copies of each kind of item and can be formulated as above except that the only restriction on x i {\displaystyle x_{i}} is that it is a non-negative integer.

maximize i = 1 n v i x i {\displaystyle \sum _{i=1}^{n}v_{i}x_{i}}
subject to i = 1 n w i x i W {\displaystyle \sum _{i=1}^{n}w_{i}x_{i}\leq W} and x i N . {\displaystyle x_{i}\in \mathbb {N} .}

One example of the unbounded knapsack problem is given using the figure shown at the beginning of this article and the text "if any number of each book is available" in the caption of that figure.

Computational complexity

The knapsack problem is interesting from the perspective of computer science for many reasons:

  • The decision problem form of the knapsack problem (Can a value of at least V be achieved without exceeding the weight W?) is NP-complete, thus there is no known algorithm that is both correct and fast (polynomial-time) in all cases.
  • There is no known polynomial algorithm which can tell, given a solution, whether it is optimal (which would mean that there is no solution with a larger V). This problem is co-NP-complete.
  • There is a pseudo-polynomial time algorithm using dynamic programming.
  • There is a fully polynomial-time approximation scheme, which uses the pseudo-polynomial time algorithm as a subroutine, described below.
  • Many cases that arise in practice, and "random instances" from some distributions, can nonetheless be solved exactly.

There is a link between the "decision" and "optimization" problems in that if there exists a polynomial algorithm that solves the "decision" problem, then one can find the maximum value for the optimization problem in polynomial time by applying this algorithm iteratively while increasing the value of k. On the other hand, if an algorithm finds the optimal value of the optimization problem in polynomial time, then the decision problem can be solved in polynomial time by comparing the value of the solution output by this algorithm with the value of k. Thus, both versions of the problem are of similar difficulty.

One theme in research literature is to identify what the "hard" instances of the knapsack problem look like, or viewed another way, to identify what properties of instances in practice might make them more amenable than their worst-case NP-complete behaviour suggests. The goal in finding these "hard" instances is for their use in public-key cryptography systems, such as the Merkle–Hellman knapsack cryptosystem. More generally, better understanding of the structure of the space of instances of an optimization problem helps to advance the study of the particular problem and can improve algorithm selection.

Furthermore, notable is the fact that the hardness of the knapsack problem depends on the form of the input. If the weights and profits are given as integers, it is weakly NP-complete, while it is strongly NP-complete if the weights and profits are given as rational numbers. However, in the case of rational weights and profits it still admits a fully polynomial-time approximation scheme.

Unit-cost models

The NP-hardness of the Knapsack problem relates to computational models in which the size of integers matters (such as the Turing machine). In contrast, decision trees count each decision as a single step. Dobkin and Lipton show an 1 2 n 2 {\displaystyle {1 \over 2}n^{2}} lower bound on linear decision trees for the knapsack problem, that is, trees where decision nodes test the sign of affine functions. This was generalized to algebraic decision trees by Steele and Yao. If the elements in the problem are real numbers or rationals, the decision-tree lower bound extends to the real random-access machine model with an instruction set that includes addition, subtraction and multiplication of real numbers, as well as comparison and either division or remaindering ("floor"). This model covers more algorithms than the algebraic decision-tree model, as it encompasses algorithms that use indexing into tables. However, in this model all program steps are counted, not just decisions. An upper bound for a decision-tree model was given by Meyer auf der Heide who showed that for every n there exists an O(n)-deep linear decision tree that solves the subset-sum problem with n items. Note that this does not imply any upper bound for an algorithm that should solve the problem for any given n.

Solving

Several algorithms are available to solve knapsack problems, based on the dynamic programming approach, the branch and bound approach or hybridizations of both approaches.

Dynamic programming in-advance algorithm

The unbounded knapsack problem (UKP) places no restriction on the number of copies of each kind of item. Besides, here we assume that x i > 0 {\displaystyle x_{i}>0}

m [ w ] = max ( i = 1 n v i x i ) {\displaystyle m=\max \left(\sum _{i=1}^{n}v_{i}x_{i}\right)}
subject to i = 1 n w i x i w {\displaystyle \sum _{i=1}^{n}w_{i}x_{i}\leq w'} and x i > 0 {\displaystyle x_{i}>0}

Observe that m [ w ] {\displaystyle m} has the following properties:

1. m [ 0 ] = 0 {\displaystyle m=0\,\!} (the sum of zero items, i.e., the summation of the empty set).

2. m [ w ] = max ( v 1 + m [ w w 1 ] , v 2 + m [ w w 2 ] , . . . , v n + m [ w w n ] ) {\displaystyle m=\max(v_{1}+m,v_{2}+m,...,v_{n}+m)} , w i w {\displaystyle w_{i}\leq w} , where v i {\displaystyle v_{i}} is the value of the i {\displaystyle i} -th kind of item.

The second property needs to be explained in detail. During the process of the running of this method, how do we get the weight w {\displaystyle w} ? There are only i {\displaystyle i} ways and the previous weights are w w 1 , w w 2 , . . . , w w i {\displaystyle w-w_{1},w-w_{2},...,w-w_{i}} where there are total i {\displaystyle i} kinds of different item (by saying different, we mean that the weight and the value are not completely the same). If we know each value of these i {\displaystyle i} items and the related maximum value previously, we just compare them to each other and get the maximum value ultimately and we are done.

Here the maximum of the empty set is taken to be zero. Tabulating the results from m [ 0 ] {\displaystyle m} up through m [ W ] {\displaystyle m} gives the solution. Since the calculation of each m [ w ] {\displaystyle m} involves examining at most n {\displaystyle n} items, and there are at most W {\displaystyle W} values of m [ w ] {\displaystyle m} to calculate, the running time of the dynamic programming solution is O ( n W ) {\displaystyle O(nW)} . Dividing w 1 , w 2 , , w n , W {\displaystyle w_{1},\,w_{2},\,\ldots ,\,w_{n},\,W} by their greatest common divisor is a way to improve the running time.

Even if P≠NP, the O ( n W ) {\displaystyle O(nW)} complexity does not contradict the fact that the knapsack problem is NP-complete, since W {\displaystyle W} , unlike n {\displaystyle n} , is not polynomial in the length of the input to the problem. The length of the W {\displaystyle W} input to the problem is proportional to the number of bits in W {\displaystyle W} , log W {\displaystyle \log W} , not to W {\displaystyle W} itself. However, since this runtime is pseudopolynomial, this makes the (decision version of the) knapsack problem a weakly NP-complete problem.

0-1 knapsack problem

A demonstration of the dynamic programming approach.
A demonstration of the dynamic programming approach.

A similar dynamic programming solution for the 0-1 knapsack problem also runs in pseudo-polynomial time. Assume w 1 , w 2 , , w n , W {\displaystyle w_{1},\,w_{2},\,\ldots ,\,w_{n},\,W} are strictly positive integers. Define m [ i , w ] {\displaystyle m} to be the maximum value that can be attained with weight less than or equal to w {\displaystyle w} using items up to i {\displaystyle i} (first i {\displaystyle i} items).

We can define m [ i , w ] {\displaystyle m} recursively as follows: (Definition A)

  • m [ 0 , w ] = 0 {\displaystyle m=0}
  • m [ i , w ] = m [ i 1 , w ] {\displaystyle m=m} if w i > w {\displaystyle w_{i}>w\,\!} (the new item is more than the current weight limit)
  • m [ i , w ] = max ( m [ i 1 , w ] , m [ i 1 , w w i ] + v i ) {\displaystyle m=\max(m,\,m+v_{i})} if w i w {\displaystyle w_{i}\leqslant w} .

The solution can then be found by calculating m [ n , W ] {\displaystyle m} . To do this efficiently, we can use a table to store previous computations.

The following is pseudocode for the dynamic program:

// Input:
// Values (stored in array v)
// Weights (stored in array w)
// Number of distinct items (n)
// Knapsack capacity (W)
// NOTE: The array "v" and array "w" are assumed to store all relevant values starting at index 1.
array m;
for j from 0 to W do:
    m := 0
for i from 1 to n do:
    m := 0
for i from 1 to n do:
    for j from 1 to W do:
        if w > j then:
            m := m
        else:
            m := max(m, m] + v)

This solution will therefore run in O ( n W ) {\displaystyle O(nW)} time and O ( n W ) {\displaystyle O(nW)} space. (If we only need the value m, we can modify the code so that the amount of memory required is O(W) which stores the recent two lines of the array "m".)

However, if we take it a step or two further, we should know that the method will run in the time between O ( n W ) {\displaystyle O(nW)} and O ( 2 n ) {\displaystyle O(2^{n})} . From Definition A, we know that there is no need to compute all the weights when the number of items and the items themselves that we chose are fixed. That is to say, the program above computes more than necessary because the weight changes from 0 to W often. From this perspective, we can program this method so that it runs recursively.

// Input:
// Values (stored in array v)
// Weights (stored in array w)
// Number of distinct items (n)
// Knapsack capacity (W)
// NOTE: The array "v" and array "w" are assumed to store all relevant values starting at index 1.
Define value
Initialize all value = -1
Define m:=(i,j)         // Define function m so that it represents the maximum value we can get under the condition: use first i items, total weight limit is j
{
    if i == 0 or j <= 0 then:
        value = 0
        return
    if (value == -1) then:     // m has not been calculated, we have to call function m
        m(i-1, j)
    if w > j then:                      // item cannot fit in the bag
        value = value
    else: 
        if (value] == -1) then:     // m] has not been calculated, we have to call function m
            m(i-1, j-w)
        value = max(value, value] + v)
}
Run m(n, W)

For example, there are 10 different items and the weight limit is 67. So, w [ 1 ] = 23 , w [ 2 ] = 26 , w [ 3 ] = 20 , w [ 4 ] = 18 , w [ 5 ] = 32 , w [ 6 ] = 27 , w [ 7 ] = 29 , w [ 8 ] = 26 , w [ 9 ] = 30 , w [ 10 ] = 27 v [ 1 ] = 505 , v [ 2 ] = 352 , v [ 3 ] = 458 , v [ 4 ] = 220 , v [ 5 ] = 354 , v [ 6 ] = 414 , v [ 7 ] = 498 , v [ 8 ] = 545 , v [ 9 ] = 473 , v [ 10 ] = 543 {\displaystyle {\begin{aligned}&w=23,w=26,w=20,w=18,w=32,w=27,w=29,w=26,w=30,w=27\\&v=505,v=352,v=458,v=220,v=354,v=414,v=498,v=545,v=473,v=543\\\end{aligned}}} If you use above method to compute for m ( 10 , 67 ) {\displaystyle m(10,67)} , you will get this, excluding calls that produce m ( i , j ) = 0 {\displaystyle m(i,j)=0} : m ( 10 , 67 ) = 1270 m ( 9 , 67 ) = 1270 , m ( 9 , 40 ) = 678 m ( 8 , 67 ) = 1270 , m ( 8 , 40 ) = 678 , m ( 8 , 37 ) = 545 m ( 7 , 67 ) = 1183 , m ( 7 , 41 ) = 725 , m ( 7 , 40 ) = 678 , m ( 7 , 37 ) = 505 m ( 6 , 67 ) = 1183 , m ( 6 , 41 ) = 725 , m ( 6 , 40 ) = 678 , m ( 6 , 38 ) = 678 , m ( 6 , 37 ) = 505 m ( 5 , 67 ) = 1183 , m ( 5 , 41 ) = 725 , m ( 5 , 40 ) = 678 , m ( 5 , 38 ) = 678 , m ( 5 , 37 ) = 505 m ( 4 , 67 ) = 1183 , m ( 4 , 41 ) = 725 , m ( 4 , 40 ) = 678 , m ( 4 , 38 ) = 678 , m ( 4 , 37 ) = 505 , m ( 4 , 35 ) = 505 m ( 3 , 67 ) = 963 , m ( 3 , 49 ) = 963 , m ( 3 , 41 ) = 505 , m ( 3 , 40 ) = 505 , m ( 3 , 38 ) = 505 , m ( 3 , 37 ) = 505 , m ( 3 , 35 ) = 505 , m ( 3 , 23 ) = 505 , m ( 3 , 22 ) = 458 , m ( 3 , 20 ) = 458 m ( 2 , 67 ) = 857 , m ( 2 , 49 ) = 857 , m ( 2 , 47 ) = 505 , m ( 2 , 41 ) = 505 , m ( 2 , 40 ) = 505 , m ( 2 , 38 ) = 505 , m ( 2 , 37 ) = 505 , m ( 2 , 35 ) = 505 , m ( 2 , 29 ) = 505 , m ( 2 , 23 ) = 505 m ( 1 , 67 ) = 505 , m ( 1 , 49 ) = 505 , m ( 1 , 47 ) = 505 , m ( 1 , 41 ) = 505 , m ( 1 , 40 ) = 505 , m ( 1 , 38 ) = 505 , m ( 1 , 37 ) = 505 , m ( 1 , 35 ) = 505 , m ( 1 , 29 ) = 505 , m ( 1 , 23 ) = 505 {\displaystyle {\begin{aligned}&m(10,67)=1270\\&m(9,67)=1270,m(9,40)=678\\&m(8,67)=1270,m(8,40)=678,m(8,37)=545\\&m(7,67)=1183,m(7,41)=725,m(7,40)=678,m(7,37)=505\\&m(6,67)=1183,m(6,41)=725,m(6,40)=678,m(6,38)=678,m(6,37)=505\\&m(5,67)=1183,m(5,41)=725,m(5,40)=678,m(5,38)=678,m(5,37)=505\\&m(4,67)=1183,m(4,41)=725,m(4,40)=678,m(4,38)=678,m(4,37)=505,m(4,35)=505\\&m(3,67)=963,m(3,49)=963,m(3,41)=505,m(3,40)=505,m(3,38)=505,m(3,37)=505,m(3,35)=505,m(3,23)=505,m(3,22)=458,m(3,20)=458\\&m(2,67)=857,m(2,49)=857,m(2,47)=505,m(2,41)=505,m(2,40)=505,m(2,38)=505,m(2,37)=505,m(2,35)=505,m(2,29)=505,m(2,23)=505\\&m(1,67)=505,m(1,49)=505,m(1,47)=505,m(1,41)=505,m(1,40)=505,m(1,38)=505,m(1,37)=505,m(1,35)=505,m(1,29)=505,m(1,23)=505\\\end{aligned}}}

Besides, we can break the recursion and convert it into a tree. Then we can cut some leaves and use parallel computing to expedite the running of this method.

To find the actual subset of items, rather than just their total value, we can run this after running the function above:

/**
 * Returns the indices of the items of the optimal knapsack.
 * i: We can include items 1 through i in the knapsack
 * j: maximum weight of the knapsack
 */
function knapsack(i: int, j: int): Set<int> {
    if i == 0 then:
        return {}
    if m > m then:
        return {i} ∪ knapsack(i-1, j-w)
    else:
        return knapsack(i-1, j)
}
knapsack(n, W)

Meet-in-the-middle

Another algorithm for 0-1 knapsack, discovered in 1974 and sometimes called "meet-in-the-middle" due to parallels to a similarly named algorithm in cryptography, is exponential in the number of different items but may be preferable to the DP algorithm when W {\displaystyle W} is large compared to n. In particular, if the w i {\displaystyle w_{i}} are nonnegative but not integers, we could still use the dynamic programming algorithm by scaling and rounding (i.e. using fixed-point arithmetic), but if the problem requires d {\displaystyle d} fractional digits of precision to arrive at the correct answer, W {\displaystyle W} will need to be scaled by 10 d {\displaystyle 10^{d}} , and the DP algorithm will require O ( W 10 d ) {\displaystyle O(W10^{d})} space and O ( n W 10 d ) {\displaystyle O(nW10^{d})} time.

algorithm Meet-in-the-middle is
    input: A set of items with weights and values.
    output: The greatest combined value of a subset.
    partition the set {1...n} into two sets A and B of approximately equal size
    compute the weights and values of all subsets of each set
    for each subset of A do
        find the subset of B of greatest value such that the combined weight is less than W
    keep track of the greatest combined value seen so far

The algorithm takes O ( 2 n / 2 ) {\displaystyle O(2^{n/2})} space, and efficient implementations of step 3 (for instance, sorting the subsets of B by weight, discarding subsets of B which weigh more than other subsets of B of greater or equal value, and using binary search to find the best match) result in a runtime of O ( n 2 n / 2 ) {\displaystyle O(n2^{n/2})} . As with the meet in the middle attack in cryptography, this improves on the O ( n 2 n ) {\displaystyle O(n2^{n})} runtime of a naive brute force approach (examining all subsets of { 1... n } {\displaystyle \{1...n\}} ), at the cost of using exponential rather than constant space (see also baby-step giant-step). The current state of the art improvement to the meet-in-the-middle algorithm, using insights from Schroeppel and Shamir's Algorithm for Subset Sum, provides as a corollary a randomized algorithm for Knapsack which preserves the O ( 2 n / 2 ) {\displaystyle O^{*}(2^{n/2})} (up to polynomial factors) running time and reduces the space requirements to O ( 2 0.249999 n ) {\displaystyle O^{*}(2^{0.249999n})} (see Corollary 1.4). In contrast, the best known deterministic algorithm runs in O ( 2 n / 2 ) {\displaystyle O^{*}(2^{n/2})} time with a slightly worse space complexity of O ( 2 n / 4 ) {\displaystyle O^{*}(2^{n/4})} .

Approximation Algorithms

As for most NP-complete problems, it may be enough to find workable solutions even if they are not optimal. Preferably, however, the approximation comes with a guarantee of the difference between the value of the solution found and the value of the optimal solution.

As with many useful but computationally complex algorithms, there has been substantial research on creating and analyzing algorithms that approximate a solution. The knapsack problem, though NP-Hard, is one of a collection of algorithms that can still be approximated to any specified degree. This means that the problem has a polynomial time approximation scheme. To be exact, the knapsack problem has a fully polynomial time approximation scheme (FPTAS).

Greedy approximation algorithm

George Dantzig proposed a greedy approximation algorithm to solve the unbounded knapsack problem. His version sorts the items in decreasing order of value per unit of weight, v 1 / w 1 v n / w n {\displaystyle v_{1}/w_{1}\geq \cdots \geq v_{n}/w_{n}} . It then proceeds to insert them into the sack, starting with as many copies as possible of the first kind of item until there is no longer space in the sack for more. Provided that there is an unlimited supply of each kind of item, if m {\displaystyle m} is the maximum value of items that fit into the sack, then the greedy algorithm is guaranteed to achieve at least a value of m / 2 {\displaystyle m/2} .

For the bounded problem, where the supply of each kind of item is limited, the above algorithm may be far from optimal. Nevertheless, a simple modification allows us to solve this case: Assume for simplicity that all items individually fit in the sack ( w i W {\displaystyle w_{i}\leq W} for all i {\displaystyle i} ). Construct a solution S 1 {\displaystyle S_{1}} by packing items greedily as long as possible, i.e. S 1 = { 1 , , k } {\displaystyle S_{1}=\left\{1,\ldots ,k\right\}} where k = max 1 k n i = 1 k w i W {\displaystyle k=\textstyle \max _{1\leq k'\leq n}\textstyle \sum _{i=1}^{k'}w_{i}\leq W} . Furthermore, construct a second solution S 2 = { k + 1 } {\displaystyle S_{2}=\left\{k+1\right\}} containing the first item that did not fit. Since S 1 S 2 {\displaystyle S_{1}\cup S_{2}} provides an upper bound for the LP relaxation of the problem, one of the sets must have value at least m / 2 {\displaystyle m/2} ; we thus return whichever of S 1 {\displaystyle S_{1}} and S 2 {\displaystyle S_{2}} has better value to obtain a 1 / 2 {\displaystyle 1/2} -approximation.

It can be shown that the average performance converges to the optimal solution in distribution at the error rate n 1 / 2 {\displaystyle n^{-1/2}}

Fully polynomial time approximation scheme

The fully polynomial time approximation scheme (FPTAS) for the knapsack problem takes advantage of the fact that the reason the problem has no known polynomial time solutions is because the profits associated with the items are not restricted. If one rounds off some of the least significant digits of the profit values then they will be bounded by a polynomial and 1/ε where ε is a bound on the correctness of the solution. This restriction then means that an algorithm can find a solution in polynomial time that is correct within a factor of (1-ε) of the optimal solution.

algorithm FPTAS is 
    input: ε ∈ (0,1]
           a list A of n items, specified by their values, 
  
    
      
        
          v
          
            i
          
        
      
    
    {\displaystyle v_{i}}
  
, and weights
    output: S' the FPTAS solution
    P := max 
  
    
      
        {
        
          v
          
            i
          
        
        
        1
        
        i
        
        n
        }
      
    
    {\displaystyle \{v_{i}\mid 1\leq i\leq n\}}
  
  // the highest item value
    K := ε 
  
    
      
        
          
            P
            n
          
        
      
    
    {\displaystyle {\frac {P}{n}}}
  

    for i from 1 to n do
        
  
    
      
        
          v
          
            i
          
          
        
      
    
    {\displaystyle v'_{i}}
  
 := 
  
    
      
        
          
          
            
              
                v
                
                  i
                
              
              K
            
          
          
        
      
    
    {\displaystyle \left\lfloor {\frac {v_{i}}{K}}\right\rfloor }
  

    end for
    return the solution, S', using the 
  
    
      
        
          v
          
            i
          
          
        
      
    
    {\displaystyle v'_{i}}
  
 values in the dynamic program outlined above

Theorem: The set S {\displaystyle S'} computed by the algorithm above satisfies p r o f i t ( S ) ( 1 ε ) p r o f i t ( S ) {\displaystyle \mathrm {profit} (S')\geq (1-\varepsilon )\cdot \mathrm {profit} (S^{*})} , where S {\displaystyle S^{*}} is an optimal solution.

Quantum approximate optimization

Quantum approximate optimization algorithm (QAOA) can be employed to solve Knapsack problem using quantum computation by minimizing the Hamiltonian of the problem. The Knapsack Hamiltonian is constructed via embedding the constraint condition to the cost function of the problem with a penalty term. H = i = 1 n v i x i + P ( i = 1 n w i x i W ) 2 , {\displaystyle {H}=-\sum _{i=1}^{n}v_{i}x_{i}+P\left(\sum _{i=1}^{n}w_{i}x_{i}-W\right)^{2},} where P {\displaystyle P} is the penalty constant which is determined by case-specific fine-tuning.

Dominance relations

Solving the unbounded knapsack problem can be made easier by throwing away items which will never be needed. For a given item i {\displaystyle i} , suppose we could find a set of items J {\displaystyle J} such that their total weight is less than the weight of i {\displaystyle i} , and their total value is greater than the value of i {\displaystyle i} . Then i {\displaystyle i} cannot appear in the optimal solution, because we could always improve any potential solution containing i {\displaystyle i} by replacing i {\displaystyle i} with the set J {\displaystyle J} . Therefore, we can disregard the i {\displaystyle i} -th item altogether. In such cases, J {\displaystyle J} is said to dominate i {\displaystyle i} . (Note that this does not apply to bounded knapsack problems, since we may have already used up the items in J {\displaystyle J} .)

Finding dominance relations allows us to significantly reduce the size of the search space. There are several different types of dominance relations, which all satisfy an inequality of the form:

j J w j x j   α w i {\displaystyle \qquad \sum _{j\in J}w_{j}\,x_{j}\ \leq \alpha \,w_{i}} , and j J v j x j   α v i {\displaystyle \sum _{j\in J}v_{j}\,x_{j}\ \geq \alpha \,v_{i}\,} for some x Z + n {\displaystyle x\in Z_{+}^{n}}

where α Z + , J N {\displaystyle \alpha \in Z_{+}\,,J\subsetneq N} and i J {\displaystyle i\not \in J} . The vector x {\displaystyle x} denotes the number of copies of each member of J {\displaystyle J} .

Collective dominance
The i {\displaystyle i} -th item is collectively dominated by J {\displaystyle J} , written as i J {\displaystyle i\ll J} , if the total weight of some combination of items in J {\displaystyle J} is less than wi and their total value is greater than vi. Formally, j J w j x j   w i {\displaystyle \sum _{j\in J}w_{j}\,x_{j}\ \leq w_{i}} and j J v j x j   v i {\displaystyle \sum _{j\in J}v_{j}\,x_{j}\ \geq v_{i}} for some x Z + n {\displaystyle x\in Z_{+}^{n}} , i.e. α = 1 {\displaystyle \alpha =1} . Verifying this dominance is computationally hard, so it can only be used with a dynamic programming approach. In fact, this is equivalent to solving a smaller knapsack decision problem where V = v i {\displaystyle V=v_{i}} , W = w i {\displaystyle W=w_{i}} , and the items are restricted to J {\displaystyle J} .
Threshold dominance
The i {\displaystyle i} -th item is threshold dominated by J {\displaystyle J} , written as i ≺ ≺ J {\displaystyle i\prec \prec J} , if some number of copies of i {\displaystyle i} are dominated by J {\displaystyle J} . Formally, j J w j x j   α w i {\displaystyle \sum _{j\in J}w_{j}\,x_{j}\ \leq \alpha \,w_{i}} , and j J v j x j   α v i {\displaystyle \sum _{j\in J}v_{j}\,x_{j}\ \geq \alpha \,v_{i}\,} for some x Z + n {\displaystyle x\in Z_{+}^{n}} and α 1 {\displaystyle \alpha \geq 1} . This is a generalization of collective dominance, first introduced in and used in the EDUK algorithm. The smallest such α {\displaystyle \alpha } defines the threshold of the item i {\displaystyle i} , written t i = ( α 1 ) w i {\displaystyle t_{i}=(\alpha -1)w_{i}} . In this case, the optimal solution could contain at most α 1 {\displaystyle \alpha -1} copies of i {\displaystyle i} .
Multiple dominance
The i {\displaystyle i} -th item is multiply dominated by a single item j {\displaystyle j} , written as i m j {\displaystyle i\ll _{m}j} , if i {\displaystyle i} is dominated by some number of copies of j {\displaystyle j} . Formally, w j x j   w i {\displaystyle w_{j}\,x_{j}\ \leq w_{i}} , and v j x j   v i {\displaystyle v_{j}\,x_{j}\ \geq v_{i}} for some x j Z + {\displaystyle x_{j}\in Z_{+}} i.e. J = { j } , α = 1 , x j = w i w j {\displaystyle J=\{j\},\alpha =1,x_{j}=\lfloor {\frac {w_{i}}{w_{j}}}\rfloor } . This dominance could be efficiently used during preprocessing because it can be detected relatively easily.
Modular dominance
Let b {\displaystyle b} be the best item, i.e. v b w b v i w i {\displaystyle {\frac {v_{b}}{w_{b}}}\geq {\frac {v_{i}}{w_{i}}}\,} for all i {\displaystyle i} . This is the item with the greatest density of value. The i {\displaystyle i} -th item is modularly dominated by a single item j {\displaystyle j} , written as i j {\displaystyle i\ll _{\equiv }j} , if i {\displaystyle i} is dominated by j {\displaystyle j} plus several copies of b {\displaystyle b} . Formally, w j + t w b w i {\displaystyle w_{j}+tw_{b}\leq w_{i}} , and v j + t v b v i {\displaystyle v_{j}+tv_{b}\geq v_{i}} i.e. J = { b , j } , α = 1 , x b = t , x j = 1 {\displaystyle J=\{b,j\},\alpha =1,x_{b}=t,x_{j}=1} .

Variations

Main article: List of knapsack problems

There are many variations of the knapsack problem that have arisen from the vast number of applications of the basic problem. The main variations occur by changing the number of some problem parameter such as the number of items, number of objectives, or even the number of knapsacks.

Multi-dimensional objective

Here, instead of a single objective (e.g. maximizing the monetary profit from the items in the knapsack), there can be several objectives. For example, there could be environmental or social concerns as well as economic goals. Problems frequently addressed include portfolio and transportation logistics optimizations.

As an example, suppose you run a cruise ship. You have to decide how many famous comedians to hire. This boat can handle no more than one ton of passengers and the entertainers must weigh less than 1000 lbs. Each comedian has a weight, brings in business based on their popularity and asks for a specific salary. In this example, you have multiple objectives. You want, of course, to maximize the popularity of your entertainers while minimizing their salaries. Also, you want to have as many entertainers as possible.

Multi-dimensional weight

Here, the weight of knapsack item i {\displaystyle i} is given by a D-dimensional vector w i ¯ = ( w i 1 , , w i D ) {\displaystyle {\overline {w_{i}}}=(w_{i1},\ldots ,w_{iD})} and the knapsack has a D-dimensional capacity vector ( W 1 , , W D ) {\displaystyle (W_{1},\ldots ,W_{D})} . The target is to maximize the sum of the values of the items in the knapsack so that the sum of weights in each dimension d {\displaystyle d} does not exceed W d {\displaystyle W_{d}} .

Multi-dimensional knapsack is computationally harder than knapsack; even for D = 2 {\displaystyle D=2} , the problem does not have EPTAS unless P = {\displaystyle =} NP. However, the algorithm in is shown to solve sparse instances efficiently. An instance of multi-dimensional knapsack is sparse if there is a set J = { 1 , 2 , , m } {\displaystyle J=\{1,2,\ldots ,m\}} for m < D {\displaystyle m<D} such that for every knapsack item i {\displaystyle i} , z > m {\displaystyle \exists z>m} such that j J { z } ,   w i j 0 {\displaystyle \forall j\in J\cup \{z\},\ w_{ij}\geq 0} and y J { z } , w i y = 0 {\displaystyle \forall y\notin J\cup \{z\},w_{iy}=0} . Such instances occur, for example, when scheduling packets in a wireless network with relay nodes. The algorithm from also solves sparse instances of the multiple choice variant, multiple-choice multi-dimensional knapsack.

The IHS (Increasing Height Shelf) algorithm is optimal for 2D knapsack (packing squares into a two-dimensional unit size square): when there are at most five squares in an optimal packing.

Multiple knapsacks

Main article: Multiple knapsack problem

Here, there are multiple knapsacks. This may seem like a trivial change, but it is not equivalent to adding to the capacity of the initial knapsack, as each knapsack has its own capacity constraint. This variation is used in many loading and scheduling problems in Operations Research and has a Polynomial-time approximation scheme. This variation is similar to the Bin Packing Problem. It differs from the Bin Packing Problem in that a subset of items can be selected, whereas, in the Bin Packing Problem, all items have to be packed to certain bins.

Quadratic

The quadratic knapsack problem maximizes a quadratic objective function subject to binary and linear capacity constraints. The problem was introduced by Gallo, Hammer, and Simeone in 1980, however the first treatment of the problem dates back to Witzgall in 1975.

Geometric

In the geometric knapsack problem, there is a set of rectangles with different values, and a rectangular knapsack. The goal is to pack the largest possible value into the knapsack.

Online

In the online knapsack problem, the items come one by one. Whenever an item arrives, we must decide immediately whether to put it in the knapsack or discard it. There are two variants: (a) non-removable - an inserted item remains in the knapsack forever; (b) removable - an inserted item may be removed later, to make room for a new item.

Han, Kawase and Makino present a randomized algorithm for the unweighted non-removable setting. It is 2-competitive, which is the best possible. For the weighted removable setting, they give a 2-competitive algorithm, prove a lower bound of ~1.368 for randomized algorithms, and prove that no deterministic algorithm can have a constant competitive ratio. For the unweighted removable setting, they give an 10/7-competitive-ratio algorithm, and prove a lower bound of 1.25.

There are several other papers on the online knapsack problem.

See also

Notes

  1. Mathews, G. B. (25 June 1897). "On the partition of numbers" (PDF). Proceedings of the London Mathematical Society. 28: 486–490. doi:10.1112/plms/s1-28.1.486.
  2. Richard M. Karp (1972). "Reducibility Among Combinatorial Problems". In R. E. Miller and J. W. Thatcher (editors). Complexity of Computer Computations. New York: Plenum. pp. 85–103
  3. Kellerer, Hans; Pferschy, Ulrich; Pisinger, David (2004). Knapsack problems. Berlin: Springer. p. 449. ISBN 978-3-540-40286-2. Retrieved 5 May 2022.
  4. Kellerer, Hans; Pferschy, Ulrich; Pisinger, David (2004). Knapsack problems. Berlin: Springer. p. 461. ISBN 978-3-540-40286-2. Retrieved 5 May 2022.
  5. Kellerer, Hans; Pferschy, Ulrich; Pisinger, David (2004). Knapsack problems. Berlin: Springer. p. 465. ISBN 978-3-540-40286-2. Retrieved 5 May 2022.
  6. Kellerer, Hans; Pferschy, Ulrich; Pisinger, David (2004). Knapsack problems. Berlin: Springer. p. 472. ISBN 978-3-540-40286-2. Retrieved 5 May 2022.
  7. Feuerman, Martin; Weiss, Harvey (April 1973). "A Mathematical Programming Model for Test Construction and Scoring". Management Science. 19 (8): 961–966. doi:10.1287/mnsc.19.8.961. JSTOR 2629127.
  8. Skiena, S. S. (September 1999). "Who is Interested in Algorithms and Why? Lessons from the Stony Brook Algorithm Repository". ACM SIGACT News. 30 (3): 65–74. CiteSeerX 10.1.1.41.8357. doi:10.1145/333623.333627. ISSN 0163-5700. S2CID 15619060.
  9. Pisinger, D. 2003. Where are the hard knapsack problems? Technical Report 2003/08, Department of Computer Science, University of Copenhagen, Copenhagen, Denmark.
  10. Caccetta, L.; Kulanoot, A. (2001). "Computational Aspects of Hard Knapsack Problems". Nonlinear Analysis. 47 (8): 5547–5558. doi:10.1016/s0362-546x(01)00658-7.
  11. ^ Poirriez, Vincent; Yanev, Nicola; Andonov, Rumen (2009). "A hybrid algorithm for the unbounded knapsack problem". Discrete Optimization. 6 (1): 110–124. doi:10.1016/j.disopt.2008.09.004. ISSN 1572-5286. S2CID 8820628.
  12. Wojtczak, Dominik (2018). "On Strong NP-Completeness of Rational Problems". Computer Science – Theory and Applications. Lecture Notes in Computer Science. Vol. 10846. pp. 308–320. arXiv:1802.09465. doi:10.1007/978-3-319-90530-3_26. ISBN 978-3-319-90529-7. S2CID 3637366.
  13. Dobkin, David; Lipton, Richard J. (1978). "A lower bound of ½n on linear search programs for the Knapsack problem". Journal of Computer and System Sciences. 16 (3): 413–417. doi:10.1016/0022-0000(78)90026-0.
  14. In fact, the lower bound applies to the subset sum problem, which is a special case of Knapsack.
  15. Michael Steele, J; Yao, Andrew C (1 March 1982). "Lower bounds for algebraic decision trees". Journal of Algorithms. 3 (1): 1–8. doi:10.1016/0196-6774(82)90002-5. ISSN 0196-6774.
  16. Ben-Amram, Amir M.; Galil, Zvi (2001), "Topological Lower Bounds on Algebraic Random Access Machines", SIAM Journal on Computing, 31 (3): 722–761, doi:10.1137/S0097539797329397.
  17. auf der Heide, Meyer (1984), "A Polynomial Linear Search Algorithm for the n-Dimensional Knapsack Problem", Journal of the ACM, 31 (3): 668–676, doi:10.1145/828.322450
  18. ^ Andonov, Rumen; Poirriez, Vincent; Rajopadhye, Sanjay (2000). "Unbounded Knapsack Problem : dynamic programming revisited". European Journal of Operational Research. 123 (2): 168–181. CiteSeerX 10.1.1.41.2135. doi:10.1016/S0377-2217(99)00265-9.
  19. S. Martello, P. Toth, Knapsack Problems: Algorithms and Computer Implementations, John Wiley and Sons, 1990
  20. S. Martello, D. Pisinger, P. Toth, Dynamic programming and strong bounds for the 0-1 knapsack problem, Manag. Sci., 45:414–424, 1999.
  21. Plateau, G.; Elkihel, M. (1985). "A hybrid algorithm for the 0-1 knapsack problem". Methods of Oper. Res. 49: 277–293.
  22. Martello, S.; Toth, P. (1984). "A mixture of dynamic programming and branch-and-bound for the subset-sum problem". Manag. Sci. 30 (6): 765–771. doi:10.1287/mnsc.30.6.765.
  23. Horowitz, Ellis; Sahni, Sartaj (1974), "Computing partitions with applications to the knapsack problem", Journal of the Association for Computing Machinery, 21 (2): 277–292, doi:10.1145/321812.321823, hdl:1813/5989, MR 0354006, S2CID 16866858
  24. Nederlof, Jesper; Węgrzycki, Karol (12 April 2021). "Improving Schroeppel and Shamir's Algorithm for Subset Sum via Orthogonal Vectors". arXiv:2010.08576 .
  25. Schroeppel, Richard; Shamir, Adi (August 1981). "A $T = O(2^{n/2} )$, $S = O(2^{n/4} )$ Algorithm for Certain NP-Complete Problems". SIAM Journal on Computing. 10 (3): 456–464. doi:10.1137/0210033. ISSN 0097-5397.
  26. ^ Vazirani, Vijay. Approximation Algorithms. Springer-Verlag Berlin Heidelberg, 2003.
  27. Dantzig, George B. (1957). "Discrete-Variable Extremum Problems". Operations Research. 5 (2): 266–288. doi:10.1287/opre.5.2.266.
  28. Calvin, James M.; Leung, Joseph Y. -T. (1 May 2003). "Average-case analysis of a greedy algorithm for the 0/1 knapsack problem". Operations Research Letters. 31 (3): 202–210. doi:10.1016/S0167-6377(02)00222-5.
  29. Lucas, Andrew (2014). "Ising formulations of many NP problems". Frontiers in Physics. 2: 5. arXiv:1302.5843. Bibcode:2014FrP.....2....5L. doi:10.3389/fphy.2014.00005. ISSN 2296-424X.
  30. Chang, T. J., et al. Heuristics for Cardinality Constrained Portfolio Optimization. Technical Report, London SW7 2AZ, England: The Management School, Imperial College, May 1998
  31. Chang, C. S., et al. "Genetic Algorithm Based Bicriterion Optimization for Traction Substations in DC Railway System." In Fogel , 11-16.
  32. Kulik, A.; Shachnai, H. (2010). "There is no EPTAS for two dimensional knapsack" (PDF). Inf. Process. Lett. 110 (16): 707–712. CiteSeerX 10.1.1.161.5838. doi:10.1016/j.ipl.2010.05.031.
  33. ^ Cohen, R. and Grebla, G. 2014. "Multi-Dimensional OFDMA Scheduling in a Wireless Network with Relay Nodes". in Proc. IEEE INFOCOM'14, 2427–2435.
  34. Yan Lan, György Dósa, Xin Han, Chenyang Zhou, Attila Benkő : 2D knapsack: Packing squares, Theoretical Computer Science Vol. 508, pp. 35–40.
  35. Chandra Chekuri and Sanjeev Khanna (2005). "A PTAS for the multiple knapsack problem". SIAM Journal on Computing. 35 (3): 713–728. CiteSeerX 10.1.1.226.3387. doi:10.1137/s0097539700382820.
  36. Wu, Z. Y.; Yang, Y. J.; Bai, F. S.; Mammadov, M. (2011). "Global Optimality Conditions and Optimization Methods for Quadratic Knapsack Problems". J Optim Theory Appl. 151 (2): 241–259. doi:10.1007/s10957-011-9885-4. S2CID 31208118.
  37. Gallo, G.; Hammer, P. L.; Simeone, B. (1980). "Quadratic knapsack problems". Combinatorial Optimization. Mathematical Programming Studies. Vol. 12. pp. 132–149. doi:10.1007/BFb0120892. ISBN 978-3-642-00801-6.
  38. Witzgall, C. (1975). "Mathematical methods of site selection for Electronic Message Systems (EMS)". NASA Sti/Recon Technical Report N. 76. NBS Internal report: 18321. Bibcode:1975STIN...7618321W.
  39. Galvez, Waldo; Grandoni, Fabrizio; Ingala, Salvatore; Heydrich, Sandy; Khan, Arindam; Wiese, Andreas (2021). "Approximating Geometric Knapsack via L-packings". ACM Trans. Algorithms. 17 (4): 33:1–33:67. arXiv:1711.07710. doi:10.1145/3473713.
  40. Han, Xin; Kawase, Yasushi; Makino, Kazuhisa (11 January 2015). "Randomized algorithms for online knapsack problems". Theoretical Computer Science. 562: 395–405. doi:10.1016/j.tcs.2014.10.017. ISSN 0304-3975.
  41. Han, Xin; Kawase, Yasushi; Makino, Kazuhisa (1 September 2014). "Online Unweighted Knapsack Problem with Removal Cost". Algorithmica. 70 (1): 76–91. doi:10.1007/s00453-013-9822-z. ISSN 1432-0541.
  42. Han, Xin; Kawase, Yasushi; Makino, Kazuhisa; Guo, He (26 June 2014). "Online removable knapsack problem under convex function". Theoretical Computer Science. Combinatorial Optimization: Theory of algorithms and Complexity. 540–541: 62–69. doi:10.1016/j.tcs.2013.09.013. ISSN 0304-3975.
  43. Han, Xin; Kawase, Yasushi; Makino, Kazuhisa; Yokomaku, Haruki (22 September 2019), Online Knapsack Problems with a Resource Buffer, doi:10.48550/arXiv.1909.10016, retrieved 3 December 2024

References

External links

Categories: