Congestion games are a class of games in game theory first proposed by Rosenthal in 1973. In a Congestion game we define players and resources, where the payoff of each player depends on the resources it chooses and the number of players choosing the same resource. Congestion games are a special case of potential games. Rosenthal proved that any congestion game is a potential game and Monderer and Shapley (1996) proved the converse: for any potential game, there is a congestion game with the same potential function.
Consider a traffic net where two players originate at point O and need to get to point T. Suppose that node O is connected to node T via connection points A and B, where A is a little closer than B (i.e. A is more likely to be chosen by each player). However, both connection points get easily congested, meaning the more players pass through a point the greater the delay of each player becomes, so having both players go through the same connection point causes extra delay. Good outcome in this game will be for the two players to "coordinate" and pass through different connection points. Can such outcome be achieved? And if so, what will the cost be for each player?
Discrete congestion games are games with the following components.
- A base set of congestible elements ;
- A finite set of strategies for each player, where each strategy is a subset of ;
- For each element and a vector of strategies , a load ;
- For each element , a delay function ;
- Given a strategy , player experiences delay . Assume that each is positive and monotone increasing.
Let's consider the following directed graph where each player has two available strategies - going though A or going through B - leading to a total of four possibilities. The following matrix expresses the costs of the players in terms of delays depending on their choices:
Both (A,B) and (B,A) are pure Nash equilibria in this game.
Existence of Nash equilibria
The existence of Nash equilibria can be shown by constructing a potential function that assigns a value to each outcome. Moreover, this construction will also show that iterated best response finds a Nash equilibrium. Define . Note that this function is not the social welfare , but rather a discrete integral of sorts. The critical property of a potential function for a congestion game is that if one player switches strategy, the change in his delay is equal to the change in the potential function.
Consider the case when player switches from to . Elements that are in both of the strategies remain unaffected, elements that the player leaves (i.e. ) decrease the potential by , and the elements the player joins (i.e. ) increase the potential by . This change in potential is precisely the change in delay for player , so is in fact a potential function.
Now observe that any minimum of is a pure Nash equilibrium. Fixing all but one player, any improvement in strategy by that player corresponds to decreasing , which cannot happen at a minimum. Now since there are a finite number of configurations and each is monotone, there exists an equilibrium.
Continuous congestion games
Continuous congestion games are the limiting case as . In this setup, we consider players as "infinitesimally small." We keep a finite set of congestible elements. Instead of recognizing players, as in the discrete case, we have types of players, where each type is associated with a number , representing the rate of traffic for that type. Each type picks a strategy from a strategy set , which we assume are disjoint. As before, assume that the are monotone and positive, but add the assumption that they are continuous as well. Finally, we allow players in a type to distribute fractionally over their strategy set. That is, for , let denote the fraction of players in type using strategy . Assume that .
Existence of equilibria in the continuous case
Note that strategies are now collections of strategy profiles . For a strategy set of size , the collection of all valid profiles is a compact subset of . As before, define the potential function as , replacing the discrete integral with the standard one.
As a function of the strategy, is continuous: is continuous, and is a continuous function of the strategy. Then by the extreme value theorem, attains its global minimum.
The final step is to show that a minimum of is indeed a Nash equilibrium. Assume for contradiction that there exists a collection of that minimize but are not a Nash equilibrium. Then for some type , there exists some improvement over the current choice . That is, . The idea now is to take a small amount of players using strategy and move them to strategy . Now for any , we have increased its load by , so its term in is now . Differentiating the integral, this change is approximately , with error . The equivalent analysis of the change holds when we look at edges in .
Therefore, the change in potential is approximately , which is less than zero. This is a contradiction, as then was not minimized. Therefore, a minimum of must be a Nash equilibrium.
Quality of solutions and Price of anarchy
Since there exist Nash equilibria in continuous congestion games, the next natural topic is to analyze their quality. We will derive bounds on the ratio between the delay at Nash and the optimal delay, otherwise known as the Price of Anarchy. First, we begin with a technical condition on the delay functions.
Definition The delay is smooth if for all , .
Now if the delay is smooth, is a Nash equilibrium, and is an optimal allocation, then . In other words, the price of anarchy is . See these lecture notes for a proof.
- Vazirani, Vijay V.; Nisan, Noam; Roughgarden, Tim; Tardos, Éva (2007), Algorithmic Game Theory, Cambridge, UK: Cambridge University Press, pp. 28, 62, & 519, ISBN 0-521-87282-0.
- Lecture notes of Michal Feldman and Noam Nisan about Potential and congestion games
- Rosenthal, Robert W. (1973), "A class of games possessing pure-strategy Nash equilibria", International Journal of Game Theory 2: 65–67, doi:10.1007/BF01737559, MR 0319584.
- Lecture notes of Yishay Mansour about Potential and congestion games