Author: Eric Marsden [email protected]
This notebook contains an exploration of the Saint Petersberg paradox, first proposed by Daniel Bernoulli around 1738. See the associated lecture slides for some background on the economic theory of risk aversion and decision-making. The notebook explains why stochastic simulation methods such as Monte Carlo are not suitable for situations where a very unlikely event has a significant impact on the output of interest in your simulations.
You flip a coin repeatedly until a tail first appears. The pot starts at 1€ and doubles every time a head appears. You win whatever is in the pot the first time you throw tails and the game ends.
Which would you prefer?
The probability of throwing a tail on a given round:
How much can you expect to win on average?
The expected value of the game is infinite, yet few people would be willing to pay more than 20€ to play: this is what's known as “the St. Petersburg Paradox”.
Let's try to estimate the expected value of this game using a stochastic simulation.
import numpy, matplotlib.pyplot as plt import seaborn as sns %matplotlib inline %config InlineBackend.figure_formats=['svg'] def petersburg(): payoff = 1 while numpy.random.uniform() > 0.5: payoff *= 2 return payoff N = 1000000 games = numpy.zeros(N) for i in range(N): games[i] = petersburg()
This game illustrates a situation where very unlikely events have an extremely high impact on the mean outcome: Monte Carlo simulation will not allow us to obtain a good estimation of the true (theoretical) expected value.
Bernoulli suggested in 1738 that the “value” of a gamble is not its monetary value, but that people attach some subjective value, or utility, to monetary outcomes. Bernoulli's suggestion: people do not seek to maximize expected values, but instead maximize expected utility.
marginal utility declines as wealth increases (poor people value increments in wealth more than rich people do)
an individual is not necessarily twice as happy getting 200€ compared to 100€
people are “risk averse”
This is a possible explanation for why very few people are willing to pay anything close to the theoretical value of playing this game.
Casinos are rich, but their riches are limited. Once you break their bank, they can't pay out any more, and thus the expected return is finite. Let's consider the case where the bank has a limit to their resources. We keep doubling the pot and halving the probability of winning the amount in the pot (half because you get the pot on a tail but not a head), until we reach the limit.
(This section was inspired by Peter Norvig's notebook on probabilities and paradoxes.)
def petersburg_finite(limit): payoff = 1 while numpy.random.uniform() > 0.5: payoff *= 2 if payoff > limit: payoff = limit break return payoff
We can calculate the expected value of playing the Saint Petersburg game against a casino which has a finite limit to their bankroll. The expected value is the sum of the possible payoffs multiplied by their probabilities.
def expectation_petersburg_finite(limit): expectation = 0 payoff = 1 probability = 1 while payoff < limit: payoff *= 2 probability *= 0.5 expectation += payoff * probability return expectation
So even with a fairly large casino backroll of 100 million euros, the expected value of this limited game is only moderate. Would you pay 27€ to have the possibility to play this game? If not, perhaps the risk aversion explanation above remains relevant…