forked from briatte/ida
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path083_practice.Rmd
94 lines (67 loc) · 6.88 KB
/
083_practice.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
<style>@import url(style.css);</style>
[Introduction to Data Analysis](index.html "Course index")
# 8.3. Practice
[ft-giles-1]: http://www.ft.com/intl/cms/s/0/85a0c6c2-1476-11e2-8cf2-00144feabdc0.html
[ft-giles-2]: http://blogs.ft.com/money-supply/2012/10/12/has-the-imf-proved-multipliers-are-really-large-wonkish/
[ft-giles-3]: http://blogs.ft.com/money-supply/2013/01/07/the-imf-and-multipliers-again/
[ft-fm]: http://ftalphaville.ft.com/2012/10/09/1199151/its-austerity-multiplier-failure/
[hanretty]: https://gist.github.com/chrishanretty/3885712
[imf-weo]: http://www.imf.org/external/pubs/ft/weo/2012/02/pdf/text.pdf
[imf-data]: https://raw.github.com/briatte/ida/master/data/imf.weo.2012.csv
<p class="info"><strong>Instructions:</strong> this week's exercise is called <code><a href="8_imf.R">8_imf.R</a></code>. Download or copy-paste that file into a new R script, then open it and run it with the working directory set as the <code>IDA</code> folder. If you download the script, make sure that your browser preserved its <code>.R</code> file extension.</p>
```{r imf-exercise, include = FALSE, message = FALSE}
source("code/8_imf.R")
```
This week's exercise is based on an article published by Chris Giles in the *Financial Times*. In "[Robustness of IMF data scrutinised][ft-giles-1]" (October 12, 2012), Giles raises an issue with recent IMF data on the relationship between fiscal consolidation (i.e. austerity politics) and growth forecasts. The graphs below express the gist of the problem:
[data:image/s3,"s3://crabby-images/97d71/97d712f3365c652dc4dcbfe7766b2ec89b4f3527" alt="FT graphs, by Chris Giles auto "http://www.ft.com/intl/cms/s/0/85a0c6c2-1476-11e2-8cf2-00144feabdc0.html""][ft-giles-1]
The main theme here is the size of the (Keynesian) [fiscal multipliers][ft-fm] applied by governments in reaction to the current economic crisis. Giles further documented the issue in a blog post, "[Has the IMF proved multipliers are really large? (wonkish)][ft-giles-2]", in which he explains being puzzled by the following graph, taken from the last [IMF World Economic Outlook report][imf-weo] (p. 43):
[data:image/s3,"s3://crabby-images/a3b97/a3b97416be4b1481966250a7c4a5c2ac74d8f987" alt="WEO plot, from the IMF report "http://www.imf.org/external/pubs/ft/weo/2012/02/pdf/text.pdf""][ft-giles-2]
In a later post, "[The IMF and multipliers, again][ft-giles-3]" (January 7, 2013), Giles explains that the controversy over that graph led to additional analysis that put the original diagnostic of the World Economic Outlook report into question. Let's run our own analysis, which uses the IMF data provided by Giles and draws on the [replication code by Chris Hanretty][hanretty].
## Step 1: Preparation
Start by reading all references cited above, then create the `imf` dataset by downloading the [`8_imf.R`](8_imf.R) script: install any missing packages and run the first segment of the code (alternately, just download the [`imf.weo.2012.csv`][imf-data] dataset). The segment ends with a scatterplot called `imf.plot` that replicates the base structure of the IMF graph:
```{r imf-plot-auto, fig.width = 8, fig.height = 6, echo = FALSE}
imf.plot +
geom_smooth(method = "lm", fill = "steelblue", alpha = .2) +
geom_rug() +
theme_bw()
```
The simple linear equation that is being run here is of the form $Y = \alpha + \beta X + \epsilon$, where $Y = \delta_{\text{growth forecast error}}$, $X = \delta_{\text{structural balance}}$ and $\beta$ is the estimated average size of the fiscal multiplier. Chris Giles' argument is that the estimation of $\beta$ by the IMF is not robust to the inclusion of additional data and/or to the exclusion of outliers.
## Step 2: Replication
Turn now to the simple linear regression component of the script and execute the model. The results will be stored into the `imf.lm` object. The regression coefficient for the $\delta_{\text{structural balance}}$ should be, as reported by Chris Giles, somewhere near `r round(coef(imf.lm)[2], 2)`. Take some time to analyze that result substantively, using the sources mentioned above.
```{r ols, echo = FALSE}
summary(imf.lm)
```
The script offers a few more graphs at that stage, including one that overlays a simple regression line and a 95% confidence interval to the raw data. The plot below also shows the residuals of the regression model, and at that stage, you should be able to intuitively detect which countries are going to be outliers:
```{r ols-plot-auto, fig.width = 8, fig.height = 6, echo = FALSE}
imf.plot +
geom_smooth(method = "lm", fill = "steelblue", alpha = .2) +
geom_segment(x = imf$D_struct_bal, xend = imf$D_struct_bal,
y = imf$D_growth, yend = fitted.values(imf.lm),
linetype = "dashed", color = "orangered") +
geom_rug() +
theme_bw()
```
## Step 3: Diagnostics
The debate between Chris Giles and the IMF revolves in large part around the presence of outliers in the data. We will instead focus on the results of the simple linear regression model and diagnose which countries are outliers to the overall trend from there. Run the third component of the script until you reach that residuals-versus-fitted-values plot:
```{r rvf-plot-auto, fig.width = 8, fig.height = 6, echo = FALSE}
imf.rvfplot +
geom_point(aes(color = rdist), size = 18, alpha = .3) +
scale_colour_gradient2(name = "Residual\ndistance",
low = "green", mid = "orange", high = "red",
midpoint = mean(imf.rvf$rdist)) +
geom_rug() +
theme_bw()
```
Finally, take a closer look at some outliers. The IMF uses Cook's distance to detect them, so we have included Cook's $D$ in the script, and as Chris Giles notes, New Zealand, which was originally excluded from the IMF analysis, is among the outliers. Sweden will also show up if you use standardized residuals instead of Cook's $D$:
```{r outliers-plot-auto, fig.width = 8, fig.height = 6, echo = FALSE}
imf.rvfplot + aes(y = rsta) + labs(y = "Standardized residuals") +
geom_hline(y = c(-2, 2), linetype = "dotted") +
geom_point(data = subset(imf.rvf, outlier1 == TRUE),
color = "red", size = 18, alpha = .4) +
geom_rug() +
theme_bw()
```
## Coursework
Form a group with one or two other classmates, and run again through the code in order to replicate the plots and model results together. The script concludes by looking at the normality of the outliers: to finish the exercise, write the code to run the original model without them, in order to get your own battery of results and make up your mind about the original IMF analysis
To report on your work, write a _one-page_ report on your analysis, in which you explain what you have learnt from reading the initial IMF results, what you coded to complement that analysis, and what you can finally conclude about __whether the IMF was correct in its estimation of the average size of the fiscal multiplier__.
> __Next week__: [Visualization in time: Time series](090_ts.html).