The purpose of this in-class lab17 is to use R to practice with difference-in-differences. The lab should be completed in your group. To get credit, upload your .R script to the appropriate place on Canvas.
Open up a new R script (named ICL17_XYZ.R
, where XYZ
are your initials) and add the usual “preamble” to the top:
# Add names of group members HERE
library(tidyverse)
library(wooldridge)
library(broom)
library(magrittr)
library(stargazer)
library(clubSandwich)
Our data set will be a pooled cross section of workers in Kentucky and Michigan, as analyzed by @meyer_al1995. Load the data from the wooldridge
package and restrict to those living in Kentucky:
df <- as_tibble(injury)
df %<>%
dplyr::filter(ky==1)
In 1980, Kentucky raised its cap on weekly earnings that were covered by worker’s compensation.1 The outcome variable is ldurat
, which is the log duration (in weeks) of worker’s compensation benefits. The policy was such that the cap increase did not affect low-earnings workers, but did affect high-earnings workers. Thus, low-earnings workers serve as the control group, while high-earnings workers serve as the treatment group.
We are interested to know if the policy caused workers to spend more time out of work. If benefits are not generous enough, then workers may sue the company for on-the-job injuries. On the other hand, benefits that are too generous may induce workers to be more reckless on the job, or to claim that off-the-job injuries were incurred while at work.
In difference-in-differences settings, it is often helpful to see if there even is a policy effect. Let’s compute the difference-in-differences (with no regression) based on the pre- and post-means for the treatment and control groups
df %>% group_by(afchnge,highearn) %>%
summarize(mean.ldurat = mean(ldurat))
## # A tibble: 4 x 3
## # Groups: afchnge [2]
## afchnge highearn mean.ldurat
## <int> <int> <dbl>
## 1 0 0 1.13
## 2 0 1 1.38
## 3 1 0 1.13
## 4 1 1 1.58
The basic regression model to analyze the policy’s impact is
\[ \log(durat) = \beta_0 + \delta_0 afchnge + \beta_1 highearn + \delta_1 afchnge \cdot highearn + u \]
Estimate this model, calling it est.did
. I suppress the code here, since this should be old hat by now. (Hint: recall that, for two dummy variables x1
and x2
, putting x1*x2
in the lm()
formula will include in the formula each dummy and the interaction of the two.)
est.did <- lm(ldurat ~ afchnge*highearn, data=df)
We might want to control for other aspects of our workers. For example, perhaps claims made by construction or manufacturing workers tend to have longer duration than claims made workers in other industries. Or maybe those claiming back injuries tend to have lonter claims than those claiming head injuries. One may also want to control for worker demographics such as gender, marital status, and age.
Estimate an expanded version of the basic regression modle, where the following additional variables are included:
male
married
age
hosp
(1 = hospitalized)indust
(1 = manuf, 2 = construc, 3 = other)injtype
(1-8; categories for different types of injury)lprewage
(log of wage prior to filing a claim)Be sure to format indust
and injtyp
as factors before proceeding. Call your model est.did.x
.
df %<>% mutate(indust=as.factor(indust), injtype=as.factor(injtype))
est.did.x <- lm(ldurat ~ afchnge*highearn + male + married + age + I(age^2) + injtype + lprewage + indust, data=df)
Calling stargazer
can help view the results:
stargazer(est.did,est.did.x,type="text")
##
## ======================================================================
## Dependent variable:
## --------------------------------------------------
## ldurat
## (1) (2)
## ----------------------------------------------------------------------
## afchnge 0.008 0.017
## (0.045) (0.045)
##
## highearn 0.256*** -0.160*
## (0.047) (0.097)
##
## male -0.071
## (0.046)
##
## married 0.041
## (0.041)
##
## age 0.025***
## (0.008)
##
## I(age2) -0.0002**
## (0.0001)
##
## injtype2 0.775***
## (0.156)
##
## injtype3 0.346***
## (0.092)
##
## injtype4 0.632***
## (0.101)
##
## injtype5 0.493***
## (0.093)
##
## injtype6 0.392***
## (0.093)
##
## injtype7 0.773***
## (0.206)
##
## injtype8 0.510***
## (0.129)
##
## lprewage 0.314***
## (0.088)
##
## indust2 0.262***
## (0.059)
##
## indust3 0.182***
## (0.041)
##
## afchnge:highearn 0.191*** 0.215***
## (0.069) (0.069)
##
## Constant 1.126*** -1.559***
## (0.031) (0.464)
##
## ----------------------------------------------------------------------
## Observations 5,626 5,347
## R2 0.021 0.049
## Adjusted R2 0.020 0.046
## Residual Std. Error 1.269 (df = 5622) 1.246 (df = 5329)
## F Statistic 39.540*** (df = 3; 5622) 16.100*** (df = 17; 5329)
## ======================================================================
## Note: *p<0.1; **p<0.05; ***p<0.01
How different is your estimate of \(\hat{\delta}_1\) from that in (2)?
Do you see any interesting patterns among the \(x\)’s in predicting log duration of benefits?