-
-
Notifications
You must be signed in to change notification settings - Fork 22
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. Weโll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Update made to Markov Chains: Basic Concepts lecture #479
Open
Jiarui-ZH
wants to merge
10
commits into
main
Choose a base branch
from
update_markov_chain_I
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from all commits
Commits
Show all changes
10 commits
Select commit
Hold shift + click to select a range
e6f125b
Update made to Markov Chains: Basic Concepts lecture
Jiarui-ZH 2917279
update to markov chain I lecture
Jiarui-ZH eabdb46
Merge branch 'main' into update_markov_chain_I
Jiarui-ZH 03d6f37
cross-sectional frequency explaination added
Jiarui-ZH 6a0f2e2
change prf to ref
Jiarui-ZH 060bb8a
[markov_chain_I] Move example subsections to sphinx-proof examples
Jiarui-ZH 112e3c5
minor update
Jiarui-ZH 088d92b
fix syntax for example
mmcky ab23359
final update to usage of syntax for example
Jiarui-ZH 7420047
Merge branch 'main' into update_markov_chain_I
Jiarui-ZH File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,7 +4,7 @@ jupytext: | |
extension: .md | ||
format_name: myst | ||
format_version: 0.13 | ||
jupytext_version: 1.14.4 | ||
jupytext_version: 1.16.1 | ||
kernelspec: | ||
display_name: Python 3 (ipykernel) | ||
language: python | ||
|
@@ -78,7 +78,7 @@ nonnegative $n$-vector $p$ that sums to one. | |
For example, $p = (0.2, 0.2, 0.6)$ is a probability mass function over $3$ outcomes. | ||
|
||
A **stochastic matrix** (or **Markov matrix**) is an $n \times n$ square matrix $P$ | ||
such that each row of $P$ is a probability mass function over $n$ outcomes. | ||
such that each row of $P$ is a probability mass function. | ||
|
||
In other words, | ||
|
||
|
@@ -98,7 +98,7 @@ Before defining a Markov chain rigorously, we'll give some examples. | |
|
||
|
||
(mc_eg2)= | ||
#### Example 1 | ||
#### Example 1: Economic states | ||
|
||
From US unemployment data, Hamilton {cite}`Hamilton2005` estimated the following dynamics. | ||
|
||
|
@@ -174,7 +174,7 @@ In particular, $P(i,j)$ is the | |
|
||
|
||
(mc_eg1)= | ||
#### Example 2 | ||
#### Example 2: Unemployment | ||
|
||
Consider a worker who, at any given time $t$, is either unemployed (state 0) | ||
or employed (state 1). | ||
|
@@ -222,7 +222,7 @@ Then we can address a range of questions, such as | |
We'll cover some of these applications below. | ||
|
||
(mc_eg3)= | ||
#### Example 3 | ||
#### Example 3: Political transition dynamics | ||
|
||
Imam and Temple {cite}`imampolitical` categorize political institutions into | ||
three types: democracy $\text{(D)}$, autocracy $\text{(A)}$, and an intermediate | ||
|
@@ -233,17 +233,17 @@ Each institution can have two potential development regimes: collapse $\text{(C) | |
Imam and Temple {cite}`imampolitical` estimate the following transition | ||
probabilities: | ||
|
||
|
||
$$ | ||
P := | ||
\begin{bmatrix} | ||
0.86 & 0.11 & 0.03 & 0.00 & 0.00 & 0.00 \\ | ||
0.52 & 0.33 & 0.13 & 0.02 & 0.00 & 0.00 \\ | ||
0.12 & 0.03 & 0.70 & 0.11 & 0.03 & 0.01 \\ | ||
0.13 & 0.02 & 0.35 & 0.36 & 0.10 & 0.04 \\ | ||
0.00 & 0.00 & 0.09 & 0.11 & 0.55 & 0.25 \\ | ||
0.00 & 0.00 & 0.09 & 0.15 & 0.26 & 0.50 | ||
\end{bmatrix} | ||
\begin{array}{c|cccccc} | ||
& \text{DG} & \text{DC} & \text{NG} & \text{NC} & \text{AG} & \text{AC} \\ | ||
\hline | ||
\text{DG} & 0.86 & 0.11 & 0.03 & 0.00 & 0.00 & 0.00 \\ | ||
\text{DC} & 0.52 & 0.33 & 0.13 & 0.02 & 0.00 & 0.00 \\ | ||
\text{NG} & 0.12 & 0.03 & 0.70 & 0.11 & 0.03 & 0.01 \\ | ||
\text{NC} & 0.13 & 0.02 & 0.35 & 0.36 & 0.10 & 0.04 \\ | ||
\text{AG} & 0.00 & 0.00 & 0.09 & 0.11 & 0.55 & 0.25 \\ | ||
\text{AC} & 0.00 & 0.00 & 0.09 & 0.15 & 0.26 & 0.50 \\ | ||
\end{array} | ||
$$ | ||
|
||
```{code-cell} ipython3 | ||
|
@@ -287,6 +287,20 @@ plt.colorbar(pc, ax=ax) | |
plt.show() | ||
``` | ||
|
||
The probabilities can be represented in matrix form as follows | ||
|
||
$$ | ||
P := | ||
\begin{bmatrix} | ||
0.86 & 0.11 & 0.03 & 0.00 & 0.00 & 0.00 \\ | ||
0.52 & 0.33 & 0.13 & 0.02 & 0.00 & 0.00 \\ | ||
0.12 & 0.03 & 0.70 & 0.11 & 0.03 & 0.01 \\ | ||
0.13 & 0.02 & 0.35 & 0.36 & 0.10 & 0.04 \\ | ||
0.00 & 0.00 & 0.09 & 0.11 & 0.55 & 0.25 \\ | ||
0.00 & 0.00 & 0.09 & 0.15 & 0.26 & 0.50 | ||
\end{bmatrix} | ||
$$ | ||
|
||
Looking at the data, we see that democracies tend to have longer-lasting growth | ||
regimes compared to autocracies (as indicated by the lower probability of | ||
transitioning from growth to growth in autocracies). | ||
|
@@ -310,7 +324,7 @@ A **distribution** $\psi$ on $S$ is a probability mass function of length $n$, w | |
A **Markov chain** $\{X_t\}$ on $S$ is a sequence of random variables taking values in $S$ | ||
that have the **Markov property**. | ||
|
||
This means that, for any date $t$ and any state $y \in S$, | ||
This means that, for any time $t$ and any state $y \in S$, | ||
|
||
```{math} | ||
:label: fin_markov_mp | ||
|
@@ -333,7 +347,7 @@ P(x, y) := \mathbb P \{ X_{t+1} = y \,|\, X_t = x \} | |
By construction, | ||
|
||
* $P(x, y)$ is the probability of going from $x$ to $y$ in one unit of time (one step) | ||
* $P(x, \cdot)$ is the conditional distribution of $X_{t+1}$ given $X_t = x$ | ||
* $P(x, \cdot)$ is the conditional distribution(probability mass function) of $X_{t+1}$ given $X_t = x$ | ||
|
||
We can view $P$ as a stochastic matrix where | ||
|
||
|
@@ -439,7 +453,7 @@ Here's a short time series. | |
mc_sample_path(P, ฯ_0=(1.0, 0.0), ts_length=10) | ||
``` | ||
|
||
It can be shown that for a long series drawn from `P`, the fraction of the | ||
It can be proven that for a long series drawn from `P`, the fraction of the | ||
sample that takes value 0 will be about 0.25. | ||
|
||
(We will explain why {ref}`later <ergodicity>`.) | ||
|
@@ -607,39 +621,40 @@ $$ | |
$$ | ||
|
||
|
||
### Example: probability of recession | ||
|
||
```{index} single: Markov Chains; Future Probabilities | ||
``` | ||
|
||
Recall the stochastic matrix $P$ for recession and growth {ref}`considered above <mc_eg2>`. | ||
```{prf:example} Probability of Recession | ||
:label: prob-recesession | ||
|
||
Suppose that the current state is unknown --- perhaps statistics are available only at the *end* of the current month. | ||
Recall the stochastic matrix $P$ for recession and growth considered in {ref}`Example 1: Economic states <mc_eg2>`. | ||
|
||
We guess that the probability that the economy is in state $x$ is $\psi_t(x)$ at time t. | ||
Suppose that the current state is unknown โ perhaps statistics are available only at the *end* of the current month. | ||
|
||
The probability of being in recession (either mild or severe) in 6 months time is given by | ||
We guess that the probability that the economy is in state $x$ is $\psi_t(x)$ at time $t$. | ||
|
||
The probability of being in recession (either mild or severe) in 6 months' time is given by | ||
|
||
$$ | ||
(\psi_t P^6)(1) + (\psi_t P^6)(2) | ||
$$ | ||
|
||
``` | ||
|
||
```{index} single: Markov Chains; Cross-Sectional Distributions | ||
``` | ||
|
||
(mc_eg1-1)= | ||
### Example 2: cross-sectional distributions | ||
````{prf:example} Cross-Sectional Distributions | ||
:label: cross-sectional-distributions | ||
|
||
The distributions we have been studying can be viewed either | ||
|
||
1. as probabilities or | ||
1. as cross-sectional frequencies that the law of large numbers leads us to anticipate for large samples. | ||
2. as cross-sectional frequencies that the law of large numbers leads us to anticipate for large samples. | ||
|
||
To illustrate, recall our model of employment/unemployment dynamics for a given worker {ref}`discussed above <mc_eg1>`. | ||
To illustrate, recall our model of employment/unemployment dynamics for a given worker discussed in {ref}`Example 2: Unemployment <mc_eg1>`. | ||
Jiarui-ZH marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
Consider a large population of workers, each of whose lifetime experience is | ||
described by the specified dynamics, with each worker's outcomes being | ||
realizations of processes that are statistically independent of all other | ||
workers' processes. | ||
Consider a large population of workers, each of whose lifetime experience is described by the specified dynamics, with each worker's outcomes being realizations of processes that are statistically independent of all other workers' processes. | ||
|
||
Let $\psi_t$ be the current *cross-sectional* distribution over $\{ 0, 1 \}$. | ||
|
||
|
@@ -649,26 +664,25 @@ The cross-sectional distribution records fractions of workers employed and unemp | |
|
||
What will the cross-sectional distribution be in 10 periods hence? | ||
|
||
The answer is $\psi_t P^{10}$, where $P$ is the stochastic matrix in | ||
{eq}`p_unempemp`. | ||
The answer is $\psi_t P^{10}$, where $P$ is the stochastic matrix in {eq}`p_unempemp`. | ||
|
||
This is because each worker's state evolves according to $P$, so | ||
$\psi_t P^{10}$ is a [marginal distribution](https://en.wikipedia.org/wiki/Marginal_distribution) for a single randomly selected | ||
worker. | ||
This is because each worker's state evolves according to $P$, so $\psi_t P^{10}$ is a [marginal distribution](https://en.wikipedia.org/wiki/Marginal_distribution) for a single randomly selected worker. | ||
|
||
But when the sample is large, outcomes and probabilities are roughly equal (by an application of the law | ||
of large numbers). | ||
But when the sample is large, outcomes and probabilities are roughly equal (by an application of the law of large numbers). | ||
|
||
So for a very large (tending to infinite) population, | ||
$\psi_t P^{10}$ also represents fractions of workers in | ||
each state. | ||
So for a very large (tending to infinite) population, $\psi_t P^{10}$ also represents fractions of workers in each state. | ||
|
||
This is exactly the cross-sectional distribution. | ||
|
||
```{note} | ||
A cross-sectional frequency measures how a particular variable (e.g., employment status) is distributed across a population at a specific time, providing information on the proportions of individuals in each possible state of that variable. | ||
``` | ||
|
||
```` | ||
|
||
(stationary)= | ||
## Stationary distributions | ||
|
||
|
||
As seen in {eq}`fin_mc_fr`, we can shift a distribution forward one | ||
unit of time via postmultiplication by $P$. | ||
|
||
|
@@ -683,8 +697,6 @@ P = np.array([[0.4, 0.6], | |
|
||
Notice that `ฯ @ P` is the same as `ฯ`. | ||
|
||
|
||
|
||
Such distributions are called **stationary** or **invariant**. | ||
|
||
(mc_stat_dd)= | ||
|
@@ -725,10 +737,8 @@ distribution. | |
We will come back to this when we introduce irreducibility in the {doc}`next lecture <markov_chains_II>` on Markov chains. | ||
|
||
|
||
|
||
### Example | ||
|
||
Recall our model of the employment/unemployment dynamics of a particular worker {ref}`discussed above <mc_eg1>`. | ||
```{prf:example} Steady-State Unemployment Probability | ||
Recall our model of the employment/unemployment dynamics of a particular worker discussed in {ref}`Example 2: Unemployment <mc_eg1>`. | ||
Jiarui-ZH marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
If $\alpha \in (0,1)$ and $\beta \in (0,1)$, then the transition matrix is everywhere positive. | ||
|
||
|
@@ -738,12 +748,13 @@ corresponds to unemployment (state 0). | |
Using $\psi^* = \psi^* P$ and a bit of algebra yields | ||
|
||
$$ | ||
p = \frac{\beta}{\alpha + \beta} | ||
p = \frac{\beta}{\alpha + \beta} | ||
$$ | ||
|
||
This is, in some sense, a steady state probability of unemployment. | ||
|
||
Not surprisingly it tends to zero as $\beta \to 0$, and to one as $\alpha \to 0$. | ||
``` | ||
|
||
|
||
|
||
|
@@ -878,11 +889,11 @@ HTML(anim.to_jshtml()) | |
``` | ||
|
||
Here | ||
|
||
* $P$ is the stochastic matrix for recession and growth {ref}`considered above <mc_eg2>`. | ||
* The red, blue and green dots are initial marginal probability distributions $\psi_1, \psi_2, \psi_3$, each of which is represented as a vector in $\mathbb R^3$. | ||
* The transparent dots are the marginal distributions $\psi_i P^t$ for $t = 1, 2, \ldots$, for $i=1,2,3.$. | ||
* The yellow dot is $\psi^*$. | ||
\update_markov_chain_I | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @Jiarui-ZH is this meant to be a link? |
||
* $P$ is the stochastic matrix for recession and growth considered in {ref}`Example 1: Economic states <mc_eg2>`. | ||
* The highest red dot is an arbitrarily chosen initial marginal probability distribution $\psi_0$, represented as a vector in $\mathbb R^3$. | ||
* The other red dots are the marginal distributions $\psi_0 P^t$ for $t = 1, 2, \ldots$. | ||
* The black dot is $\psi^*$. | ||
|
||
You might like to try experimenting with different initial conditions. | ||
|
||
|
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
thanks @Jiarui-ZH for opening #502. We can deal with that separately.