Code should execute sequentially if run in a Jupyter notebook

- See the set up page to install Jupyter, Julia and all necessary libraries
- Please direct feedback to contact@quantecon.org or the discourse forum

# Introduction to Asset Pricing¶

Contents

“A little knowledge of geometric series goes a long way” – Robert E. Lucas, Jr.

“Asset pricing is all about covariances” – Lars Peter Hansen

## Overview¶

An asset is a claim on one or more future payoffs

The spot price of an asset depends primarily on

- the anticipated dynamics for the stream of income accruing to the owners
- attitudes to risk
- rates of time preference

In this lecture we consider some standard pricing models and dividend stream specifications

We study how prices and dividend-price ratios respond in these different scenarios

We also look at creating and pricing *derivative* assets by repackaging income streams

Key tools for the lecture are

- formulas for predicting future values of functions of a Markov state
- a formula for predicting the discounted sum of future values of a Markov state

## Pricing Models¶

In what follows let \(\{d_t\}_{t \geq 0}\) be a stream of dividends

- A time-\(t\)
**cum-dividend**asset is a claim to the stream \(d_t, d_{t+1}, \ldots\) - A time-\(t\)
**ex-dividend**asset is a claim to the stream \(d_{t+1}, d_{t+2}, \ldots\)

Let’s look at some equations that we expect to hold for prices of assets under cum-dividend and ex-dividend contracts respectively

### Risk Neutral Pricing¶

Our first scenario is risk-neutral pricing

Let \(\beta = 1/(1+\rho)\) be an intertemporal discount factor, where \(\rho\) is the rate at which agents discount the future

The basic risk-neutral asset pricing equation for pricing one unit of a cum-dividend asset is

This is a simple “cost equals expected benefit” relationship

Here \({\mathbb E}_t [y]\) denotes the best forecast of \(y\), conditioned on information available at time \(t\)

For an ex-dividend asset, the basic risk-neutral asset pricing equation is

### Pricing with Random Discount Factor¶

What happens if for some reason traders discount payouts differently depending on the state of the world?

Michael Harrison and David Kreps [HK79] and Lars Peter Hansen and Scott Richard [HR87] showed that in quite general settings the price of an ex-dividend asset obeys

for some **stochastic discount factor** \(m_{t+1}\)

The fixed discount factor \(\beta\) in (2) has been replaced by the random variable \(m_{t+1}\)

The way anticipated future payoffs are evaluated can now depend on various random outcomes

One example of this idea is that assets that tend to have good payoffs in bad states of the world might be regarded as more valuable

This is because they pay well when the funds are more urgently needed

We give examples of how the stochastic discount factor has been modeled below

### Asset Pricing and Covariances¶

Recall that, from the definition of a conditional covariance \({\rm cov}_t (x_{t+1}, y_{t+1})\), we have

If we apply this definition to the asset pricing equation (3) we obtain

It is useful to regard equation (5) as a generalization of equation (2)

- In equation (2), the stochastic discount factor \(m_{t+1} = \beta\), a constant
- In equation (2), the covariance term \({\rm cov}_t (m_{t+1}, d_{t+1}+ p_{t+1})\) is zero because \(m_{t+1} = \beta\)

Equation (5) asserts that the covariance of the stochastic discount factor with the one period payout \(d_{t+1} + p_{t+1}\) is an important determinant of the price \(p_t\)

We give examples of some models of stochastic discount factors that have been proposed later in this lecture and also in a later lecture

### The Price-Dividend Ratio¶

Aside from prices, another quantity of interest is the **price-dividend ratio** \(v_t := p_t / d_t\)

Let’s write down some expressions that this ratio should satisfy

For the case of an ex-dividend contract, we can divide both sides of (3) by \(d_t\) to get

For the cum-dividend case, the corresponding expression is

Below we’ll discuss the implications of these equtions

## Prices in the Risk Neutral Case¶

What can we say about price dynamics on the basis of the models described above?

The answer to this question depends on

- the process we specify for dividends
- the stochastic discount factor and how it correlates with dividends

For now let’s focus on the risk neutral case, where the stochastic discount factor is constant, and study how prices depend on the dividend process

### Example 1: Constant dividends¶

The simplest case is risk neutral pricing in the face of a constant, non-random dividend stream \(d_t = d > 0\)

Removing the expectation from (1) and iterating forward gives

Unless prices explode in the future, this sequence converges to

This price is the equilibrium price in the constant dividend case

Indeed, simple algebra shows that setting \(p_t = \bar p\) for all \(t\) satisfies the equilibrium condition \(p_t = d + \beta p_{t+1}\)

The ex-dividend equilibrium price is \((1 -\beta)^{-1} \beta d\)

### Example 2: Dividends with deterministic growth paths¶

Consider a growing, non-random dividend process \(d_{t+1} = g d_t\) where \(0 < g \beta < 1\)

While prices are not usually constant when dividends grow over time, the price dividend-ratio might be

If we guess this, substituting \(v_t = v\) into (7) as well as our other assumptions, we get \(v = 1 + \beta g v\)

Since \(\beta g < 1\), we have a unique positive solution for the cum-dividend case:

The cum-dividend price is then

In view of (6), the ex-dividend formulas are

If, in this example, we take \(g = 1+\kappa\) and let \(\rho := 1/\beta - 1\), then the ex-dividend price becomes

This is called the *Gordon formula*

### Example 3: Markov growth, risk neutral pricing¶

Next we consider a dividend process

The stochastic growth factor \(\{g_t\}\) is given by

where

- \(\{X_t\}\) is a finite Markov chain with state space \(S\) and transition probabilities

- \(g\) is a given function on \(S\) taking positive values

You can think of

- \(S\) as \(n\) possible “states of the world” and \(X_t\) as the current state
- \(g\) as a function that maps a given state \(X_t\) into a growth factor \(g_t = g(X_t)\) for the endowment
- \(\ln g_t = \ln (d_{t+1} / d_t)\) is the growth rate of dividends

(For a refresher on notation and theory for finite Markov chains see this lecture)

The next figure shows a simulation, where

- \(\{X_t\}\) evolves as a discretized AR1 process produced using Tauchen’s method
- \(g_t = \exp(X_t)\), so that \(\ln g_t = X_t\) is the growth rate

The code can be found here

#### Pricing¶

To obtain asset prices in this setting, let’s adapt our analysis from the case of deterministic growth

In that case we found that \(v\) is constant

This encourages us to guess that, in the current case, \(v_t\) is constant given the state \(X_t\)

In other words, we are looking for a fixed function \(v\) such that the price-dividend ratio satisfies \(v_t = v(X_t)\)

Staring with the cum-dividend case, we can substitute this guess into (7) to get

If we condition on \(X_t = x\), this becomes

or

Suppose that there are \(n\) possible states \(x_1, \ldots, x_n\)

We can then think of (11) as \(n\) stacked equations, one for each state, and write it in matrix form as

Here

- \(v\) is understood to be the column vector \((v(x_1), \ldots, v(x_n))'\)
- \(K\) is the matrix \((K(x_i, x_j))_{1 \leq i, j \leq n}\)
- \({\mathbb 1}\) is a column vector of ones

When does (12) have a unique solution?

From the Neumann series lemma and Gelfand’s forumula, this will be the case if \(\beta K\) has spectral radius strictly less than one

In other words, we require that the eigenvalues of \(K\) be strictly less than \(\beta^{-1}\) in modulus

The solution is then

Similar reasoning in the ex-dividend case yields

### Code¶

Let’s calculate and plot the price-dividend ratio for the ex-dividend case at a set of parameters

As before, we’ll generate \(\{X_t\}\) as a discretized AR1 process and set \(g_t = \exp(X_t)\)

Here’s the code, including a test of the spectral radius condition

```
#=
Plot the price-dividend ratio in the risk neutral case, for the Markov asset pricing
lecture.
=#
using QuantEcon
using Plots
using LaTeXStrings
pyplot()
n = 25 # size of state space
beta = 0.9
mc = tauchen(n, 0.96, 0.02)
K = mc.p .* reshape(exp(mc.state_values), 1, n)
I = eye(n)
v = (I - beta * K) \ (beta * K * ones(n, 1))
plot(mc.state_values,
v,
lw=2,
ylabel="price-dividend ratio",
xlabel="state",
alpha=0.7,
label=L"$v$")
```

Here’s the figure it produces

Why does the price-dividend ratio increase with the state?

The reason is that this Markov process is positively correlated, so high current states suggest high future states

Moreover, dividend growth is increasing in the state

Anticipation of high future dividend growth leads to a high price-dividend ratio

## Asset Prices under Risk Aversion¶

Now let’s turn to the case where agents are risk averse

We’ll price several distinct assets, including

- The price of an endowment stream
- A consol (a type of bond issued by the UK government in the 19th century)
- Call options on a consol

### Pricing a Lucas tree¶

Let’s start with a version of the celebrated asset pricing model of Robert E. Lucas, Jr. [Luc78]

As in [Luc78], suppose that the stochastic discount factor takes the form

where \(u\) is a concave utility function and \(c_t\) is time \(t\) consumption of a representative consumer

(A derivation of this expression is given in a later lecture)

Assume the existence of an endowment that follows (10)

The asset being priced is a claim on the endowment process

Following [Luc78], suppose further that in equilibrium, consumption is equal to the endowment, so that \(d_t = c_t\) for all \(t\)

For utility, we’ll assume the **constant relative risk aversion** (CRRA)
specification

When \(\gamma =1\) we let \(u(c) = \ln c\)

Inserting the CRRA specification into (14) and using \(c_t = d_t\) gives

Substituting this into (6) gives the ex-dividend price-dividend ratio formula

Conditioning on \(X_t = x\), we can write this as

If we let

then we can rewrite in vector form as

Assuming that the spectral radius of \(J\) is strictly less than \(\beta^{-1}\), this equation has the unique solution

Here’s a plot of \(v\) as a function of the state for several values of \(\gamma\), with a positively correlated Markov process and \(g(x) = \exp(x)\)

The code with all details can be found here

Notice that \(v\) is decreasing in each case

This is because, with a positively correlated state process, higher states suggest higher future consumption growth

In the stochastic discount factor (16), higher growth decreases the discount factor, lowering the weight placed on future returns

#### Special cases¶

In the special case \(\gamma =1\), we have \(J = P\)

Recalling that \(P^i {\mathbb 1} = {\mathbb 1}\) for all \(i\) and applying Neumann’s geometric series lemma, we are led to

Thus, with log preferences, the price-dividend ratio for a Lucas tree is constant

Alternatively, if \(\gamma = 0\), then \(J = K\) and we recover the risk neutral solution (13)

This is as expected, since \(\gamma = 0\) implies \(u(c) = c\) (and hence agents are risk neutral)

### A Risk-Free Consol¶

Consider the same pure exchange representative agent economy

A risk-free consol promises to pay a constant amount \(\zeta> 0\) each period

Recycling notation, let \(p_t\) now be the price of an ex-coupon claim to the consol

An ex-coupon claim to the consol entitles the owner at the end of period \(t\) to

- \(\zeta\) in period \(t+1\), plus
- the right to sell the claim for \(p_{t+1}\) next period

The price satisfies (3) with \(d_t = \zeta\), or

We maintain the stochastic discount factor (16), so this becomes

Guessing a solution of the form \(p_t = p(X_t)\) and conditioning on \(X_t = x\), we get

Letting \(M(x, y) = P(x, y) g(y)^{-\gamma}\) and rewriting in vector notation yields the solution

### Pricing an Option to Purchase the Consol¶

Let’s now price options of varying maturity that give the right to purchase a consol at a price \(p_S\)

#### An infinite horizon call option¶

We want to price an infinite horizon option to purchase a consol at a price \(p_S\)

The option entitles the owner at the beginning of a period either to

- purchase the bond at price \(p_S\) now, or
- Not to exercise the option now but to retain the right to exercise it later

Thus, the owner either *exercises* the option now, or chooses *not to exercise* and wait until next period

This is termed an infinite-horizon *call option* with *strike price* \(p_S\)

The owner of the option is entitled to purchase the consol at the price \(p_S\) at the beginning of any period, after the coupon has been paid to the previous owner of the bond

The fundamentals of the economy are identical with the one above, including the stochastic discount factor and the process for consumption

Let \(w(X_t, p_S)\) be the value of the option when the time \(t\) growth state is known to be \(X_t\) but *before* the owner has decided whether or not to exercise the option
at time \(t\) (i.e., today)

Recalling that \(p(X_t)\) is the value of the consol when the initial growth state is \(X_t\), the value of the option satisfies

The first term on the right is the value of waiting, while the second is the value of exercising now

We can also write this as

With \(M(x, y) = P(x, y) g(y)^{-\gamma}\) and \(w\) as the vector of values \((w(x_i), p_S)_{i = 1}^n\), we can express (20) as the nonlinear vector equation

To solve (21), form the operator \(T\) mapping vector \(w\) into vector \(Tw\) via

Start at some initial \(w\) and iterate to convergence with \(T\)

Here’s a plot of \(w\) compared to the consol price when \(P_S = 40\)

The code with all details can be found here

In large states the value of the option is close to zero

This is despite the fact the Markov chain is irreducible and low states — where the consol prices is high — will eventually be visited

The reason is that \(\beta=0.9\), so the future is discounted relatively rapidly

### Risk Free Rates¶

Let’s look at risk free interest rates over different periods

#### The one-period risk-free interest rate¶

As before, the stochastic discount factor is \(m_{t+1} = \beta g_{t+1}^{-\gamma}\)

It follows that the reciprocal \(R_t^{-1}\) of the gross risk-free interest rate \(R_t\) in state \(x\) is

We can write this as

where the \(i\)-th element of \(m_1\) is the reciprocal of the one-period gross risk-free interest rate in state \(x_i\)

#### Other terms¶

Let \(m_j\) be an \(n \times 1\) vector whose \(i\) th component is the reciprocal of the \(j\) -period gross risk-free interest rate in state \(x_i\)

Then \(m_1 = \beta M\), and \(m_{j+1} = M m_j\) for \(j \geq 1\)

## Implementation¶

The file asset_pricing.py provides some functions for computing prices of the Lucas tree, consol and call option described above

Its contents are as follows

```
#=
Filename: asset_pricing.jl
@authors: Spencer Lyon, Tom Sargent, John Stachurski
Computes asset prices with a Lucas style discount factor when the endowment
obeys geometric growth driven by a finite state Markov chain. That is,
.. math::
d_{t+1} = g(X_{t+1}) d_t
where
* :math:`\{X_t\}` is a finite Markov chain with transition matrix P.
* :math:`g` is a given positive-valued function
References
----------
http://quant-econ.net/py/markov_asset.html
=#
using QuantEcon
# A default Markov chain for the state process
rho = 0.9
sigma = 0.02
n = 25
default_mc = tauchen(n, rho, sigma)
type AssetPriceModel
beta :: Float64 # Discount factor
gamma :: Float64 # Coefficient of risk aversion
mc :: MarkovChain # State process
n :: Int # Number of states
g :: Function # Function mapping states into growth rates
end
function AssetPriceModel(;beta=0.96, gamma=2.0, mc=default_mc, g=exp)
n = size(mc.p)[1]
return AssetPriceModel(beta, gamma, mc, n, g)
end
"""
Stability test for a given matrix Q.
"""
function test_stability(ap::AssetPriceModel, Q::Matrix)
sr = maximum(abs(eigvals(Q)))
if sr >= 1 / ap.beta
msg = "Spectral radius condition failed with radius = $sr"
throw(ArgumentError(msg))
end
end
"""
Computes the price-dividend ratio of the Lucas tree.
"""
function tree_price(ap::AssetPriceModel)
# == Simplify names, set up matrices == #
beta, gamma, P, y = ap.beta, ap.gamma, ap.mc.p, ap.mc.state_values
y = reshape(y, 1, ap.n)
J = P .* ap.g(y).^(1 - gamma)
# == Make sure that a unique solution exists == #
test_stability(ap, J)
# == Compute v == #
I = eye(ap.n)
Ones = ones(ap.n)
v = (I - beta * J) \ (beta * J * Ones)
return v
end
"""
Computes price of a consol bond with payoff zeta
"""
function consol_price(ap::AssetPriceModel, zeta::Float64)
# == Simplify names, set up matrices == #
beta, gamma, P, y = ap.beta, ap.gamma, ap.mc.p, ap.mc.state_values
y = reshape(y, 1, ap.n)
M = P .* ap.g(y).^(- gamma)
# == Make sure that a unique solution exists == #
test_stability(ap, M)
# == Compute price == #
I = eye(ap.n)
Ones = ones(ap.n)
p = (I - beta * M) \ ( beta * zeta * M * Ones)
return p
end
"""
Computes price of a perpetual call option on a consol bond.
"""
function call_option(ap::AssetPriceModel, zeta::Float64, p_s::Float64, epsilon=1e-7)
# == Simplify names, set up matrices == #
beta, gamma, P, y = ap.beta, ap.gamma, ap.mc.p, ap.mc.state_values
y = reshape(y, 1, ap.n)
M = P .* ap.g(y).^(- gamma)
# == Make sure that a unique console price exists == #
test_stability(ap, M)
# == Compute option price == #
p = consol_price(ap, zeta)
w = zeros(ap.n, 1)
error = epsilon + 1
while (error > epsilon)
# == Maximize across columns == #
w_new = max(beta * M * w, p - p_s)
# == Find maximal difference of each component and update == #
error = maximum(abs(w-w_new))
w = w_new
end
return w
end
```

Exercise 1 asks you to make use of this code

## Exercises¶

### Exercise 1¶

Consider the following primitives

```
n = 5
P = 0.0125 .* ones(n, n)
P .+= diagm(0.95 .- 0.0125 .* ones(5))
s = [1.05, 1.025, 1.0, 0.975, 0.95]
gamm = 2.0
bet = 0.94
zet = 1.0
```

Let \(g\) be defined by \(g(x) = x\) (that is, \(g\) is the identity map)

Compute the price of the Lucas tree

Do the same for

- the price of the risk-free consol when \(\zeta = 1\)
- the call option on the consol when \(\zeta = 1\) and \(p_S = 150.0\)

### Exercise 2¶

Let’s consider finite horizon call options, which are more common than the infinite horizon variety

Finite horizon options obey functional equations closely related to (20)

A \(k\) period option expires after \(k\) periods

If we view today as date zero, a \(k\) period option gives the owner the right to exercise the option to purchase the risk-free consol at the strike price \(p_S\) at dates \(0, 1, \ldots , k-1\)

The option expires at time \(k\)

Thus, for \(k=1, 2, \ldots\), let \(w(x, k)\) be the value of a \(k\)-period option

It obeys

where \(w(x, 0) = 0\) for all \(x\)

We can express the preceding as the sequence of nonlinear vector equations

Write a function that computes \(w_k\) for any given \(k\)

Compute the value of the option with `k = 5`

and `k=25`

using parameter values as in Exercise 1

Is one higher than the other? Can you give intuition?

## Solutions¶

### Exercise 1¶

```
n = 5
P = 0.0125 .* ones(n, n)
P = P .+ diagm(0.95 - 0.0125 .* ones(5))
s = [0.95, 0.975, 1.0, 1.025, 1.05] # state values
mc = MarkovChain(P, s)
gamma = 2.0
beta = 0.94
zeta = 1.0
p_s = 150.0
```

```
150.0
```

Next we’ll create an instance of AssetPriceModel to feed into the functions.

```
ap = AssetPriceModel(beta=beta, mc=mc, gamma=gamma, g=x -> x)
```

```
v = tree_price(ap)
println("Lucas Tree Prices: $v\n")
```

```
Lucas Tree Prices: [29.474,21.9357,17.5714,14.7252,12.7222]
```

```
v_consol = consol_price(ap, 1.0)
println("Consol Bond Prices: $(v_consol)\n")
```

```
Consol Bond Prices: [753.871,242.551,148.676,109.251,87.5686]
```

```
w = call_option(ap, zeta, p_s)
```

### Exercise 2¶

Here’s a suitable funciton:

```
function finite_horizon_call_option(ap::AssetPriceModel,
zeta::Float64,
p_s::Float64,
k::Int)
# == Simplify names, set up matrices == #
beta, gamma, P, y = ap.beta, ap.gamma, ap.mc.p, ap.mc.state_values
y = reshape(y, 1, ap.n)
M = P .* ap.g(y).^(- gamma)
# == Make sure that a unique console price exists == #
test_stability(ap, M)
# == Compute option price == #
p = consol_price(ap, zeta)
w = zeros(ap.n, 1)
for i in 1:k
# == Maximize across columns == #
w = max(beta * M * w, p - p_s)
end
return w
end
```

```
lines = []
labels = []
for k in [5, 25]
w = finite_horizon_call_option(ap, zeta, p_s, k)
push!(lines, w)
push!(labels, "k = $k")
end
plot(lines, labels=reshape(labels,1,length(labels)))
```

Not surprisingly, the option has greater value with larger \(k\). This is because the owner has a longer time horizon over which he or she may exercise the option.