data:image/s3,"s3://crabby-images/ca364/ca36463f9b82c90b6f3e27c6326cdcdc31617e4c" alt=""
Generalized assignment problem
Encyclopedia
In applied mathematics
, the maximum generalized assignment problem is a problem in combinatorial optimization
. This problem is a generalization
of the assignment problem
in which both tasks and agents have a size. Moreover, the size of each task might vary from one agent to the other.
This problem in its most general form is as follows:
There are a number of agents and a number of tasks. Any agent can be assigned to perform any task, incurring some cost and profit that may vary depending on the agent-task assignment. Moreover, each agent has a budget and the sum of the costs of tasks assigned to it cannot exceed this budget. It is required to find an assignment in which all agents do not exceed their budget and total profit of the assignment is maximized.
.
through
and m kinds of bins
through
. Each bin
is associated with a budget
. For a bin
, each item
has a profit
and a weight
. A solution is subset of items U and an assignment from U to the bins. A feasible solution is a solution in which for each bin
the weights sum of assigned items is at most
. The solution's profit is the sum of profits for each item-bin assignment. The goal is to find a maximum profit feasible solution.
Mathematically the generalized assignment problem can be formulated as:
The generalized assignment problem is NP-hard
, and it is even APX-hard to approximate it. Recently it was shown that an extension of it is (
) hard to approximate for every
.
-approximation algorithm for the knapsack problem, it is possible to construct a (
)-approximation for the generalized assignment problem in a greedy manner using a residual profit concept.
The algorithm constructs a schedule in iterations, where during iteration
a tentative selection of items to bin
is selected.
The selection for bin
might change as items might be reselected in a later iteration for other bins.
The residual profit of an item
for bin
is
if
is not selected for any other bin or
–
if
is selected for bin
.
Formally: We use a vector
to indicate the tentative schedule during the algorithm. Specifically,
means the item
is scheduled on bin
and
means that item
is not scheduled. The residual profit in iteration
is denoted by
, where
if item
is not scheduled (i.e.
) and
if item
is scheduled on bin
(i.e.
).
Formally:
Applied mathematics
Applied mathematics is a branch of mathematics that concerns itself with mathematical methods that are typically used in science, engineering, business, and industry. Thus, "applied mathematics" is a mathematical science with specialized knowledge...
, the maximum generalized assignment problem is a problem in combinatorial optimization
Combinatorial optimization
In applied mathematics and theoretical computer science, combinatorial optimization is a topic that consists of finding an optimal object from a finite set of objects. In many such problems, exhaustive search is not feasible...
. This problem is a generalization
Generalization
A generalization of a concept is an extension of the concept to less-specific criteria. It is a foundational element of logic and human reasoning. Generalizations posit the existence of a domain or set of elements, as well as one or more common characteristics shared by those elements. As such, it...
of the assignment problem
Assignment problem
The assignment problem is one of the fundamental combinatorial optimization problems in the branch of optimization or operations research in mathematics...
in which both tasks and agents have a size. Moreover, the size of each task might vary from one agent to the other.
This problem in its most general form is as follows:
There are a number of agents and a number of tasks. Any agent can be assigned to perform any task, incurring some cost and profit that may vary depending on the agent-task assignment. Moreover, each agent has a budget and the sum of the costs of tasks assigned to it cannot exceed this budget. It is required to find an assignment in which all agents do not exceed their budget and total profit of the assignment is maximized.
Special cases
In the special case in which all the agents' budgets and all tasks' costs are equal to 1, this problem reduces to the maximum assignment problem. When the costs and profits of all agents-task assignment are equal, this problem reduces to the multiple knapsack problem. If there is a single agent, then, this problem reduces to the Knapsack problemKnapsack problem
The knapsack problem or rucksack problem is a problem in combinatorial optimization: Given a set of items, each with a weight and a value, determine the count of each item to include in a collection so that the total weight is less than or equal to a given limit and the total value is as large as...
.
Definition
In the following, we have n kinds of items,data:image/s3,"s3://crabby-images/06724/06724e54e70d69482b2a258858ea057d2702a967" alt=""
data:image/s3,"s3://crabby-images/1a450/1a450bed1949d85b96274819f0c4e4768b1f98d7" alt=""
data:image/s3,"s3://crabby-images/f8873/f887320c49cc63be6ccab8982f3218ea07b4d347" alt=""
data:image/s3,"s3://crabby-images/44f40/44f4087d4de90d2a265e0933daf8ecc160d4896e" alt=""
data:image/s3,"s3://crabby-images/d9b0b/d9b0bee3964b5d38ea2658ac0f6d60f1de17aa73" alt=""
data:image/s3,"s3://crabby-images/f186b/f186bc39a3523ccc7d5ad1d5d5dbd40012eb125d" alt=""
data:image/s3,"s3://crabby-images/582df/582df0e12dc4dacb98e7faad8e55075856d8cee7" alt=""
data:image/s3,"s3://crabby-images/129f6/129f6ff891dd2ba96d981262a65601ebf163b72a" alt=""
data:image/s3,"s3://crabby-images/73cb7/73cb7bcc17177d43b9c4e1466b70dbdcb85bbf4e" alt=""
data:image/s3,"s3://crabby-images/91ab2/91ab29fb74f4f568cd31889e28237c65d5669d1e" alt=""
data:image/s3,"s3://crabby-images/e2f97/e2f97a4f04493e1294e90a52926d4415c09474ff" alt=""
data:image/s3,"s3://crabby-images/0f568/0f5682621c4a0c40dcad818589081a0fee50ef62" alt=""
Mathematically the generalized assignment problem can be formulated as:
- maximize
- subject to
;
;
;
The generalized assignment 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 it is even APX-hard to approximate it. Recently it was shown that an extension of it is (
data:image/s3,"s3://crabby-images/3e99d/3e99dc9bedc14796321f4df15ef27a09f3c92d1f" alt=""
data:image/s3,"s3://crabby-images/2009c/2009c0b650ec6386dbb8f6fe2b448f2e2d946121" alt=""
Greedy approximation algorithm
Using any algorithm ALGdata:image/s3,"s3://crabby-images/cf6a6/cf6a66c0c6e4f0b2b159cbd87f3e804d2d78578d" alt=""
data:image/s3,"s3://crabby-images/24b61/24b611b21fd126f59af925bde486e2a042033e13" alt=""
The algorithm constructs a schedule in iterations, where during iteration
data:image/s3,"s3://crabby-images/c1859/c18595755c126d4fd72214e86e882737af6835f3" alt=""
data:image/s3,"s3://crabby-images/c81cc/c81cccb52198150f4ea8733c60673d56d5462608" alt=""
The selection for bin
data:image/s3,"s3://crabby-images/1c0ca/1c0ca7704e01e96ca0995b4d1954e9634f821ca1" alt=""
The residual profit of an item
data:image/s3,"s3://crabby-images/292f7/292f72f6de642d83886d25e7b246d53ce6c80513" alt=""
data:image/s3,"s3://crabby-images/756cf/756cf9939a442822dfb05542902f3b9063a4bebf" alt=""
data:image/s3,"s3://crabby-images/291c4/291c4e5276d8b73ff4954259059c3534d142b208" alt=""
data:image/s3,"s3://crabby-images/d3581/d35810be1658bd51b77d824921316bbaa5595a6b" alt=""
data:image/s3,"s3://crabby-images/45e4c/45e4ce2dec6bcb5c8fa6e8844fc85a8c6d2d2df8" alt=""
data:image/s3,"s3://crabby-images/8fe27/8fe277dfec9aee342430f16f9eb6fd15b442b7c3" alt=""
data:image/s3,"s3://crabby-images/12703/12703a87b7da47111d28ae079917ebb839dd8381" alt=""
data:image/s3,"s3://crabby-images/fe518/fe518a1161e807cce9518f120c5dd98c88d89614" alt=""
Formally: We use a vector
data:image/s3,"s3://crabby-images/94385/9438536bebf50449c5be9dcce0eea0a610bd1bce" alt=""
data:image/s3,"s3://crabby-images/e396d/e396d4829840e3b037420cbfe31cfc9c2bd11166" alt=""
data:image/s3,"s3://crabby-images/f32d3/f32d32d51b1f64668f8f376d5d3d9699ce296b5c" alt=""
data:image/s3,"s3://crabby-images/7ddce/7ddce23e88f89679c0927118ddaa77fd2e35b515" alt=""
data:image/s3,"s3://crabby-images/74755/74755fd55e0c8ed61cdc15df3a5338768ef35ab3" alt=""
data:image/s3,"s3://crabby-images/7f5ba/7f5ba3dacf058341824c95b4a4cd1afae04f367d" alt=""
data:image/s3,"s3://crabby-images/6659a/6659a0f6f0e8787016b525100df050747f39c825" alt=""
data:image/s3,"s3://crabby-images/e760c/e760cd74151a447eba4fb24f9c04f06f170ac170" alt=""
data:image/s3,"s3://crabby-images/cb51b/cb51b4d5c8d8f1141b289911b9d9210b72c04590" alt=""
data:image/s3,"s3://crabby-images/c5d56/c5d567e2ed4cf19243b6f5aaf9bf8933513a837f" alt=""
data:image/s3,"s3://crabby-images/83ffc/83ffcda9734a7121d0ddbcd345ac6d2778660c07" alt=""
data:image/s3,"s3://crabby-images/6c3c9/6c3c974da66e032e9c688d7b687716d83be8f78e" alt=""
data:image/s3,"s3://crabby-images/5c116/5c11643b2bf9e10120a4e28fb8bc13f28f1bd70a" alt=""
data:image/s3,"s3://crabby-images/c282a/c282ae6ec7bd0df01e5565ba69737777b07ceaa7" alt=""
data:image/s3,"s3://crabby-images/39f79/39f793bed0bfd977f94a386c90485bbdfe699f41" alt=""
Formally:
- Set
for all
- For
do:
- Call ALG to find a solution to bin
using the residual profit function
. Denote the selected items by
.
- Update
using
, i.e.,
for all
.
- Call ALG to find a solution to bin