In cooperative game theory, the nucleolus of a cooperative game is the solution (i.e., allocation of payments to players) that maximizes the smallest excess of a coalition (where the excess is the difference between the payment given to the coalition and the value the coalition could get by deviating). Subject to that, the nucleolus satisfies the second-smallest excess; and so on, in the leximin order. The nucleolus was introduced by David Schmeidler.
In a cooperative game, there is a set N of players, who can cooperate and form coalitions. Each coalition S (subset of players) has a value, which is the profit that S can make if they coopereate on their own, ignoring the other players in N. The players opt to form the grand coalition - a coalition containing all players in N. The question then arises, how should the value of the grand coalition be allocated among the players? Each such allocation of value is called a solution or a payoff vector.
The excess of any coalition S from a given payoff-vector x is the difference between the total payoff to members of S under x, and the value of S. Note that the excess can be positive, negative or zero. Intuitively, a solution in which all coalitions have a higher excess is more stable, since coalitions are less incentivized to deviate from the grand-coalition.
The nucleolus is a single solution, for which the vector of excesses of all coalitions is largest in the leximin order. Intuitively, the nucleolus maximizes the stability of the solution by minimizing the incentives of coalitions to deviate.
A cooperative game is represented by a value function
v:2N\toR
x\inRN
The excess of a payoff-vector
x
S\subseteqN
excess(x,S):=\sumxi-v(S)
S
N
Let
\theta(x)\in
2N | |
R |
x
\thetai(x)\leq\thetaj(x),\forall~i<j
x,y
\theta(x)
\theta(y)
k
\thetai(x)=\thetai(y),\forall~i<k
\thetak(x)<\thetak(y)
v
A general cooperative game among n players is characterized by 2n values - one value for each possible coalition. The nucleolus of a general game can be computed by any algorithm for lexicographic max-min optimization. These algorithms usually require to solve linear programs with one constraint for each objective value, plus some additional constraints. Therefore, the number of constraints is O(2n). The number of iterations required by the more efficient algorithms is at most n, so the run-time is O(n 2n).
If the cooperative game is given by enumerating all coalitions' values, then the input size is 2n, and so the above algorithms run in time polynomial in the input size. But when n is large, even representing such a game is computationally intensive, and there is more interest in classes of cooperative games that have a compact representation.
In a weighted voting game, each player has a weight. The weight of a coalition is the sum of weights of its members. A coalition can force a decision if its total weight is above a certain threshold. Therefore, the value of a coalition is 1 if its value is above the threshold, and 0 if its value is below the threshold. A weighted voting game can be represented by only n+1 values: a weight for each player, and the threshold.
In a weighted voting game, the core can be computed in time polynomial in n. In contrast, the least-core is NP-hard, but has a pseudopolynomial time algorithm - an algorithm polynomial in n and the maximum weight W.[1] Similarly, the nucleolus is NP-hard, but has a pseudopolynomial time algorithm.[2] The proof relies on solving successive exponential-sized linear programs, by constructing dynamic-programming based separation oracles.
In a minimum-cost spanning-tree game, each player is a node in a complete graph. The graph contains an additional node s (the supply node). Each edge in the graph has a cost. The cost of each coalition S is the minimum cost of a spanning tree connecting all nodes in S to the supply node s. The value of S is minus the cost of S. Thus, a MCST game can be represented by O(n2) values.[3]
Computing the nucleolus on general MCST games is NP-hard,[4] but it can be computed in polynomial time if the underlying network is a tree.[5] [6]
In weighted cooperative matching games, the nucleolus can be computed in polynomial time.[7]
In some games, the value of each coalition is not given explicitly, but it can be computed by solving a set of mathematical programming problems. Using a constraint generation approach, it is possible to compute only the values of coalitions that are required for the nucleolus. This allows to compute the nucleolus efficiently in practice, when there are at most 20 players.[8]
Potters, Reijnierse and Ansing[9] present a fast algorithm for computing the nucleolus using the prolonged simplex algorithm.
If the prekernel of a cooperative game contains exactly one core vector, then the nucleolus can be computed efficiently.[10] The algorithm is based on the ellipsoid method and on a scheme of Maschler for approximating the prekernel.
Guajardo and Jornsten[11] have found mistakes in the application of linear programming and duality to computing the nucleolus.