A “Simple” 3-period-lived agent OG model#
Why this “simple” theory?#
Almost every module of the OG-Core model is straightforward on its own in terms of theory, mathematics, and intuition. Most undergraduate students with basic economics and mathematical training are able to understand them quickly. Examples include:
The
household.py
module that has all the functions that come from the theory of household decision making in the “Households” chapter of the OG-Core documentation,The
firm.py
module that has all the functions that come from the theory of firms’ decisions about how much capital to rent and how much labor to hire as described in the “Firms” chapter of the OG-Core documentation, andThe
demographics.py
module that has the functions that generate the population distribution and how it changes over time as described in the “Demographics” chapter of the OG-Core documentation.
In contrast, users of the country calibrations of the OG-Core macroeconomic model often struggle to understand the difference and relationship between the steady-state equilibrium solution and the transition path equilibrium solution and why those algorithms in SS.py
and TPI.py
are so complex. Indeed, understanding the transition path solution algorithm often requires more in-depth theoretical and mathematical training.
The text of this chapter is almost exactly Chapter 2 of [DeBacker and Evans, 2024].[1] The model presented in this chapter is nearly the simplest version of the OG model. It is “nearly” the simplest because we start with overlapping generations of agents who live for three periods. The simplest overlapping generations model is a two-period-lived agent model as described in Chapter 1 of [DeBacker and Evans, 2024]. Although the two-period-lived agent model seems like the natural starting place, that model is fundamentally different from any OG model in which agents live for three periods or more.[2] We start with the three-period-lived agent model because its solution method and results are similar for all life spans \(S\geq 3\).
The model presented here is a perfect foresight, three-period-lived agent OG model. The model in this chapter has trivial demographics in that a unit measure of agents are born each period, and each generation of agents lives for three periods. There is no population growth because the population in each period equals 3 (young, middle-aged, and old), and the mortality rate is zero in every period except the last period in which it is one. And the agents inelastically supply labor. We also characterize “nearly” the simplest production sector with a unit measure of infinitely lived, perfectly competitive firms that rent capital and hire labor from households.[3] There is no government sector in that agents and firms in the model pay no taxes nor receive any transfers.
Households#
A unit measure of identical individuals are born each period and live for three periods. Let the age of an individual be indexed by \(s = \{1,2,3\}\). In general, an age-\(s\) individual faces a budget constraint each period that looks like the following,
where \(c_{s,t}\) is consumption and \(n_{s,t}\) is labor supply by age-\(s\) individuals in period \(t\). The variable \(b_{s+1,t+1}\) is savings by age-\(s\) individuals in period \(t\) to be returned to them with interest in the next period, and \(b_{s,t}\) is the savings with which the age-\(s\) agent entered period \(t\) that was chosen in the previous period. The current period wage \(w_t\) and interest rate \(r_t\) are the same for all agents (no age \(s\) subscript).
We assume the individuals supply a unit of labor inelastically in the first two periods of life and are retired in the last period of life.
We also assume that individuals are born with no savings \(b_{1,t} = 0\) and that they save no income in the last period of their lives \(b_{4,t}=0\) for all periods \(t\).
These assumptions give rise to the three age-specific budget constraints derived from the general version Equation (18).[4]
We assume that consumption must be nonnegative \(c_{s,t}\geq 0\) for all \(s\) and \(t\).[5] And we assume that \(b_{2,t} + b_{3,t}>0\) because the aggregate capital stock must be strictly positive.
Let the utility of consumption in each period be defined by a function \(u(c_{s,t})\), such that \(u'>0\), \(u''<0\), and \(\lim_{c\rightarrow 0}u(c) = -\infty\). We will use the constant relative risk aversion (CRRA) utility function that takes the following form,
where the parameter \(\sigma\geq 1\) represents the coefficient of relative risk aversion.
Individuals choose lifetime consumption \(\{c_{s,t+s-1}\}_{s=1}^3\), savings \(\{b_{s+1,t+s}\}_{s=1}^2\) to maximize lifetime utility, subject to the budget constraints and non negativity constraints.
The number of variables to choose in the household’s optimization problem can be reduced by substituting the budget constraints into the optimization problem Equation (24) and assuming that the non-negativity constraints on the two capital stocks do not bind.[6]
The optimal choice of how much to save in the second period of life \(b_{3,t+2}\) is given by taking the derivative of the Lagrangian Equation (25) with respect to \(b_{3,t+2}\) and setting it equal to zero.
Equation (26) implies that the optimal savings for age-2 individuals is a function \(\psi_{2,t+1}\) of the wage and interest rate in that period, the interest rate in the next period, and how much capital the individual saved in the previous period.
The optimal choice of how much to save in the first period of life \(b_{2,t+1}\) is a little more involved. The first order condition of the Lagrangian includes derivatives of \(b_{3,t+2}\) with respect to \(b_{2,t+1}\) because Equations (26) and (27) show that optimal middle-aged savings \(b_{3,t+2}\) is a function of savings when young \(b_{2,t+1}\).
Notice that the term in the brackets on the third line of Equation (28) equals zero because of the optimality condition Equation (26) for \(b_{3,t+1}\). This is the envelope condition or the principle of optimality. The intuition is that I don’t need to worry about the effect of my choice today on my choice tomorrow because I will optimize tomorrow given today. So the first order condition for optimal savings when young \(b_{2,t+1}\) simplifies to the following expression.
Equation (29) implies that the optimal savings for age-1 individuals is a function of the wages in that period and the next period and the interest rate in the next period and in the period after that.[7]
Instead of looking at the age-1 and age-2 savings decisions of a particular individual, which happen in consecutive periods, we could look at the age-1 savings decisions of the young in period \(t\) as characterized in Equation (29) and the age-2 savings decisions of the middle-aged in period \(t\). This savings \(b_{3,t+1}\) is characterized by the following first order condition, which is simply Equation (26) iterated backward in time one period,
which implies that the period-\(t\) savings decision of the middle aged is a function of the wage and interest rate in period-\(t\), the interest rate in the period \(t+1\), and how much capital the individual saved in the previous period.
Define \(\Gamma_t\) as the distribution of household savings across households at time \(t\).
As will be shown in Section Equilibrium, the state as defined in Definition 2 in every period \(t\) for the entire equilibrium system described in the non-steady-state equilibrium characterized in Definition 4 is the current distribution of individual savings \(\Gamma_t\) from Equation (33). Because individuals must forecast wages and interest rates in every period in order to solve their optimal lifetime decisions and because each of those future variables depends on the entire distribution of savings in the future, we must assume some individual beliefs about how the entire distribution will evolve over time. Let general beliefs about the future distribution of capital in period \(t+u\) be characterized by the operator \(\Omega(\cdot)\) such that:
where the \(e\) superscript signifies that \(\Gamma^e_{t+u}\) is the expected distribution of wealth at time \(t+u\) based on general beliefs \(\Omega(\cdot)\) that are not constrained to be correct.[8]
Firms#
The economy also includes a unit measure of identical, perfectly competitive firms that rent investment capital from individuals for real return \(r_t\) and hire labor for real wage \(w_t\). Firms use their total capital \(K_t\) and labor \(L_t\) to produce output \(Y_t\) every period according to a Cobb-Douglas production technology.
We assume that the price of the output in every period \(P_t=1\).[9] The representative firm chooses how much capital to rent and how much labor to hire to maximize profits,
where \(\delta\in[0,1]\) is the rate of capital depreciation.[10] The two first order conditions that characterize firm optimization are the following.
Market clearing#
Three markets must clear in this model: the labor market, the capital market, and the goods market. Each of these equations amounts to a statement of supply equals demand.
The goods market clearing equation (41) is redundant by Walras’ Law.
Equilibrium#
Before providing exact definitions of the functional equilibrium concepts, we give a rough sketch of the equilibrium, so you can see what the functions look like and understand the exact equilibrium definition more clearly. A rough description of the equilibrium solution to the problem above is the following three points.
Markets clear according to Equations (39) and (40). These equations characterize the equilibrium and constitute a system of nonlinear difference equations.
The easiest way to understand the equilibrium solution is to substitute the market clearing conditions (39) and (40) into the firm’s optimal conditions (37) and (38) and solve for the equilibrium wage and interest rate as functions of the distribution of capital.
Now Equations (42) and (43) can be substituted into household Euler equations (29) and (31) to get the following two-equation system that completely characterizes the equilibrium.
The system of two dynamic equations (44) and (45) characterizing the decisions for \(b_{2,t+1}\) and \(b_{3,t+1}\) in every period \(t\) is not identified. These households know the current distribution of capital \(b_{2,t}\) and \(b_{3,t}\). However, we need to solve for policy functions for \(b_{2,t+1}\), \(b_{3,t+1}\), and \(b_{3,t+2}\) from these two equations. It looks like this system is unidentified. But the solution is a fixed point of stationary functions.
We first define the steady-state equilibrium, which is exactly identified. Let the steady state of endogenous variable \(x_t\) be characterized by \(x_{t+1}=x_t=\bar{x}\) in which the endogenous variables are constant over time. Then we can define the steady-state equilibrium as follows.
Definition 1 (Steady-state equilibrium)
A non-autarkic steady-state equilibrium in the perfect foresight overlapping generations model with \(3\)-period lived agents is defined as constant allocations of consumption \(\{\bar{c}_s\}_{s=1}^3\), capital \(\{\bar{b}_s\}_{s=2}^3\), and prices \(\bar{w}\) and \(\bar{r}\) such that:
As we saw earlier in this section, the characterizing equations in Definition 1 reduce to (44) and (45) in every period. These two equations are exactly identified in the steady state. That is, they are two equations and two unknowns (\(\bar{b}_2,\bar{b}_3\)).
We can solve for steady-state \(\bar{b}_2\) and \(\bar{b}_3\) by using a unconstrained optimization solver. Then we solve for \(\bar{w}\), \(\bar{r}\), \(\bar{c}_1\), \(\bar{c}_2\), and \(\bar{c}_3\) by substituting \(\bar{b}_2\) and \(\bar{b}_3\) into the equilibrium firm first order conditions and into the household budget constraints.
Now we can get ready to define the non-steady-state equilibrium. To do this, we need to define two other important concepts.
Definition 2 (State of a dynamical system)
The state of a dynamical system—sometimes called the state vector—is the smallest set of variables that completely summarizes all the information necessary for determining the future of the system at a given point in time.
In the 3-period-lived agent, perfect foresight, OG model described in this section, the state vector can be seen in equations (44) and (45). What is the smallest set of variables that completely summarize all the information necessary for the three generations of all three generations living at time \(t\) to make their consumption and saving decisions? What information do they have at time \(t\) that will allow them to make their savings decisions? The state vector of this model in each period is the distribution of capital \((b_{2,t},b_{3,t})\).
Definition 3 (Stationary function)
We define a stationary function to be a function that only depends upon its arguments and does not depend upon time.
The relevant examples of stationary functions in this model are the policy functions for saving and investment. We defined the functions \(\psi_{1,t}\) and \(\psi_{2,t}\) generally in equations (30) and (32). But they were indexed by time as evidenced by the \(t\) in \(\psi_{1,t}\) and \(\psi_{2,t}\). The stationary versions of those functions would be \(\psi_{1}\) and \(\psi_2\), which do not depend upon time. The arguments of the functions (the state) may change overtime causing the savings levels to change over time, but the function of the arguments is constant across time.
With the concept of the state of a dynamical system and a stationary function, we are ready to define a functional non-steady-state equilibrium of the model.
Definition 4 (Non-steady-state functional equilibrium)
A non-steady-state functional equilibrium in the perfect foresight overlapping generations model with \(3\)-period lived agents is defined as stationary allocation functions of the state \(\psi_{1}\bigl(b_{2,t},b_{3,t}\bigr)\) and \(\psi_{2}\bigl(b_{2,t},b_{3,t}\bigr)\) and stationary price functions \(w(b_{2,t},b_{3,t})\) and \(r(b_{2,t},b_{3,t})\) such that:
households have symmetric beliefs \(\Omega(\cdot)\) about the evolution of the distribution of savings as characterized in Equation (34), and those beliefs about the future distribution of savings equal the realized outcome (rational expectations): \(\Gamma_{t+u} = \Gamma^e_{t+u} = \Omega^u\left(\Gamma_t\right) \quad\forall t,\quad u\geq 1\)
We have already shown how to boil down the characterizing equations in Definition 4 to two equations (44) and (45). But we have also seen that those two equations are not identified. So how do we solve for these equilibrium functions? The solution to the non-steady-state equilibrium in Definition 4 is a fixed point in function space. Choose two functions \(\psi_1\) and \(\psi_2\) and verify that they satisfy the Euler equations for all points in the state space (all possible values of the state).
Solution method: time path iteration (TPI)#
The benchmark conventional solution method for the non-steady-state rational expectations equilibrium transition path in OG models was originally outlined in a series of papers between 1981 and 1985,[11] in chapter 4 of the seminal book [Auerbach and Kotlikoff, 1987] for the perfect foresight case, and in Appendix II of [Nishiyama and Smetters, 2007] and Section 3.1 of [Evans and Phillips, 2014] for the stochastic case. We call this method time path iteration (TPI). The idea is that the economy is infinitely lived, even though the agents that make up the economy are not. Rather than recursively solving for equilibrium policy functions by iterating on individual value functions, one must recursively solve for the policy functions by iterating on the entire transition path of the endogenous objects in the economy (see Chapter 17 of [Stokey et al., 1989]). [Evans and Phillips, 2014] give a good description of how to implement this method.
The key assumption is that the economy will reach the steady-state equilibrium \((\bar{b}_2,\bar{b}_3)\) described in Definition 1 in a finite number of periods \(T<\infty\) regardless of the initial state \((b_{2,1},b_{3,1})\). The first step is to assume a transition path for aggregate capital \(K^i = \left\{K_1^i,K_2^i,...K_T^i\right\}\) such that \(T\) is sufficiently large to ensure that \((b_{2,T},b_{3,T}) = (\bar{b}_2,\bar{b}_3)\). The superscript \(i\) is an index for the iteration number. The transition path for aggregate capital determines the transition path for both the real wage \(w^i = \left\{w_1^i,w_2^i,...w_T^i\right\}\) and the real return on investment \(r^i = \left\{r_1^i,r_2^i,...r_T^i\right\}\). The exact initial distribution of capital in the first period \((b_{2,1},b_{3,1})\) can be arbitrarily chosen as long as it satisfies \(K_1^i = b_{2,1} + b_{3,1}\) according to market clearing condition (40). One could also first choose the initial distribution of capital \((b_{2,1},b_{3,1})\) and then choose an initial aggregate capital stock \(K_1^i\) that corresponds to that distribution. As mentioned earlier, the only other restriction on the initial transition path for aggregate capital is that it equal the steady-state level \(K_T^i = \bar{K} = \bar{b}_2 + \bar{b}_3\) by period \(T\). But the aggregate capital stocks \(K_t^j\) for periods \(1<t<T\) can be any level.
Given the initial capital distribution \((b_{2,1},b_{3,1})\) and the transition paths of aggregate capital \(K^i = \left\{K_1^i,K_2^i,...K_T^i\right\}\), the real wage \(w^i = \left\{w_1^i,w_2^i,...w_T^i\right\}\), and the real return to investment \(r^i = \left\{r_1^i,r_2^i,...r_T^i\right\}\), one can solve for the optimal savings decision for the initial middle-aged \(s=2\) individual for the last period of his life \(b_{3,2}\) using his intertemporal Euler equation (45).
Notice that everything in equation (48) is known except for the savings decision \(b_{3,2}\). This is one equation and one unknown.
The next step is to solve for \(b_{2,2}\) and \(b_{3,3}\) for the initial young \(s=1\) agent at period \(1\) using the appropriately timed versions of Equations (29) and (26) with the conjectured interest rates and real wages.
Everything is known in these two equations except for \(b_{2,2}\) and \(b_{3,3}\). So we can solve for those with a standard unconstrained solver. We next solve for \(b_{2,t}\) and \(b_{3,t+1}\) for the remaining \(t\in\{3,4,...T+m\}\), where \(T\) represents the period in the future at which the economy should have converged to the steady-state and \(m\) represents some number of periods past that.[12]
At this point, we have solved for the distribution of capital \((b_{2,t},b_{3,t})\) over the entire time period \(t\in\{1,2,...T\}\). In each period \(t\), the distribution of capital implies an aggregate capital stock \(K_t^{i'} = b_{2,t} + b_{3,t}\). We put a ``\(\, ' \,\)’’ on this aggregate capital stock because, in general, \(K_t^{i'}\neq K_t^i\). That is, the conjectured path of the aggregate capital stock is not equal to the optimally chosen path of the aggregate capital stock given \(K^i\).[13]
Let \(\left\lVert\cdot\right\rVert\) be a norm on the space of time paths for the aggregate capital stock. Common norms to use are the \(L^2\) and the \(L^\infty\) norms. Then the fixed point necessary for the equilibrium transition path from Definition 4 has been found when the distance between \(K^{i'}\) and \(K^{i}\) is arbitrarily close to zero.
If the fixed point has not been found \(\left\lVert K^{i'} - K^{i}\right\rVert > \varepsilon\), then a new transition path for the aggregate capital stock is generated as a convex combination of \(K^{i'}\) and \(K^{i}\).
This process is repeated until the initial transition path for the aggregate capital stock is consistent with the transition path implied by those beliefs and household and firm optimization. TPI solves for the equilibrium transition path from Definition 4 by finding a fixed point in the time path of the economy.
Calibration#
Use the following parameterization of the model for the problems below. Because agents live for only three periods, assume that each period of life is 20 years. If the annual discount factor is estimated to be 0.96, then the 20-year discount factor is \(\beta = 0.96^{20} = 0.442\). Let the annual depreciation rate of capital be 0.05. Then the 20-year depreciation rate is \(\delta = 1-(1-0.05)^{20} = 0.6415\). Let the coefficient of relative risk aversion be \(\sigma = 3\), let the productivity scale parameter of firms be \(A=1\), and let the capital share of income be \(\alpha = 0.35\).
Exercises#
Exercise 1 (Checking feasibility of guesses for b_vec)
Using the calibration from Section Calibration of this chapter, write a Python function named feasible()
that has the following form,
b_cnstr, c_cnstr, K_cnstr = feasible(f_params, bvec_guess)
where the inputs are a tuple f_params = (nvec, A, alpha, delta)
, and a guess for the steady-state savings vector bvec_guess = np.array([scalar, scalar])
. The outputs should be Boolean (True
or False
, 1
or 0
) vectors of lengths 2, 3, and 1, respectively. K_cnstr
should be a singleton Boolean that equals True
if \(K\leq 0\) for the given f_params
and bvec_guess
. The object c_cnstr
should be a length-3 Boolean vector in which the \(s\)th element equals True
if \(c_s\leq 0\) given f_params
and bvec_guess
. And b_cnstr
is a length-2 Boolean vector that denotes which element of bvec_guess
is likely responsible for any of the consumption nonnegativity constraint violations identified in c_cnstr
. If the first element of c_cnstr
is True
, then the first element of b_cnstr
is True
. If the second element of c_cnstr
is True
, then both elements of b_cnstr
are True
. And if the last element of c_cnstr
is True
, then the last element of b_cnstr
is True
.
Which, if any, of the constraints is violated if you choose an initial guess for steady-state savings of
bvec_guess = np.array([1.0, 1.2])
?Which, if any, of the constraints is violated if you choose an initial guess for steady-state savings of
bvec_guess = np.array([0.06, -0.001])
?Which, if any, of the constraints is violated if you choose an initial guess for steady-state savings of
bvec_guess = np.array([0.1, 0.1])
?
Exercise 2 (Computing the steady-state equilibrium)
Use the calibration from Section Calibration and the steady-state equilibrium Definition 1. Write a function named get_SS()
that has the following form,
ss_output = get_SS(params, bvec_guess, SS_graphs)
where the inputs are a tuple of the parameters for the model params = (beta, sigma, nvec, L, A, alpha, delta, SS_tol)
, an initial guess of the steady-state savings bvec_guess
, and a Boolean SS_graphs
that generates a figure of the steady-state distribution of consumption and savings if it is set to True
. The output object ss_output
is a Python dictionary with the steady-state solution values for the following endogenous objects.
ss_output = {
'b_ss': b_ss, 'c_ss': c_ss, 'w_ss': w_ss, 'r_ss': r_ss,
'K_ss': K_ss, 'I_ss': I_ss, 'Y_ss': Y_ss, 'C_ss': C_ss,
'EulErr_ss': EulErr_ss, 'RCerr_ss': RCerr_ss,
'ss_time': ss_time
}
Let ss_time
be the number of seconds it takes to run your steady-state program. You can time your program by importing the time
library.
import time
...
start_time = time.time() # Place at beginning of get_SS()
...
ss_time = time.time() - start_time # Place at end of get_SS()
And let the object EulErr_ss
be a length-2 vector of the two Euler errors from the resulting steady-state solution given in difference form \(\beta(1+\bar{r})u'(\bar{c}_{s+1}) - u'(\bar{c}_s)\). The object RCerr_ss
is a resource constraint error which should be close to zero. It is given by \(\bar{Y}-\bar{C} - \delta\bar{K}\).
Solve numerically for the steady-state equilibrium values of \(\{\bar{c}_s\}_{s=1}^3\), \(\{\bar{b}_s\}_{s=2}^3\), \(\bar{w}\), \(\bar{r}\), \(\bar{K}\), \(\bar{Y}\), \(\bar{C}\), the two Euler errors and the resource constraint error. List those values. Time your function. How long did it take to compute the steady-state?
Generate a figure that shows the steady-state distribution of consumption and savings by age \(\{\bar{c}_s\}_{s=1}^3\) and \(\{\bar{b}_s\}_{s=2}^3\).
What happens to each of these steady-state values if all households become more patient \(\beta\uparrow\) (an example would be \(\beta = 0.55\))? That is, in what direction does \(\beta\uparrow\) move each steady-state value \(\{\bar{c}_s\}_{s=1}^3\), \(\{\bar{b}_s\}_{s=2}^3\), \(\bar{w}\), and \(\bar{r}\)? What is the intuition?
Exercise 3 (Computing the transition path equilibrium)
Use the calibration from Section Calibration and the steady-state solution from part 1 of Exercise 2. Use time path iteration (TPI) to solve for the non-steady state equilibrium transition path of the economy from \((b_{2,1},b_{3,1})=(0.8\bar{b}_2,1.1\bar{b}_3)\) to the steady-state \((\bar{b}_2,\bar{b}_3)\). You’ll have to choose a guess for \(T\) and a time path updating parameter \(\xi\in(0,1)\), but you can know that \(T<50\). Use an \(L^2\) norm for your distance measure (sum of squared percent deviations), and use a convergence parameter of \(\varepsilon = 10^{-9}\). Use a linear initial guess for the time path of the aggregate capital stock from the initial state \(K_1^1\) to the steady state \(K_T^1\) at time \(T\).
Report the maximum of the absolute values of all the Euler errors across the entire time path. Also report the maximum of the absolute value of all the aggregate resource constraint errors \(Y_t - C_t - K_{t+1} + (1 - \delta)K_t\) across the entire time path.
Plot the equilibrium time paths of the aggregate capital stock \(\{K_t\}_{t=1}^{T+5}\), wage \(\{w_t\}_{t=1}^{T+5}\), and interest rate \(\{r_t\}_{t=1}^{T+5}\).
How many periods did it take for the economy to get within 0.00001 of the steady-state aggregate capital stock \(\bar{K}\)? What is the period after which the aggregate capital stock never is again farther than 0.00001 away from the steady-state?
Footnotes#
This section contains the footnotes for this chapter.