tests/testthat/test_controled.R

# These tests 
df_test_orig <- bacondecomp::castle
formula <- l_homicide ~ post + l_pop + l_income
id_var <- "state"
time_var <- "year"

formula <- formula(terms(formula, data = df_test_orig))

vars <- unpack_variable_names(formula)
outcome_var <- vars$outcome_var
treated_var <- vars$treated_var
control_vars <- vars$control_vars

df_test <- rename_vars(df_test_orig, id_var, time_var, outcome_var, treated_var)

# Create grid of treatment groups
treatment_group_calc <- create_treatment_groups(df_test, control_vars, 
                                                return_merged_df = TRUE)
# extract data to test
test_data <- treatment_group_calc$data
# dummy control var
control_formula <- update(formula,
                          paste0("treated ~ .  + factor(time) + factor(id) -",
                                 treated_var))
# Calculate the Ds
test_data <- run_fwl(test_data, control_formula)

# Calculate Omega
Omega <- calculate_Omega(test_data)
one_minus_Omega <- calculate_one_minus_Omega(test_data)

# Defined in Eqn 25, page 26 of Working Paper
# https://cdn.vanderbilt.edu/vu-my/wp-content/uploads/sites/2318/2019/07/29170757/ddtiming_7_29_2019.pdf
test_that("Omega and One Minus OmegaSum to 1", {
  expect_equal(Omega + one_minus_Omega, 1)
})

# Two way estimate
two_way_model <- lm(l_homicide ~ post + l_pop + l_income + factor(state) + 
                      factor(year),
                    data = df_test_orig)

beta_hat_dd_two_way <- two_way_model$coefficients["post"]
names(beta_hat_dd_two_way) <- NULL

# Equation 23
beta_hat_dd_23 <- cov(test_data$outcome, test_data$d_it_til)/var(test_data$d_it_til)

test_that("Recover Two Way Coef Using EQN 23", {
  expect_equal(beta_hat_dd_23, beta_hat_dd_two_way)
})

# Equation 25
beta_hat_w <- calculate_beta_hat_w(test_data)
beta_hat_b <- calculate_beta_hat_b(test_data)
beta_hat_dd_25 <- Omega * beta_hat_w + one_minus_Omega * beta_hat_b

test_that("Recover Two Way Coef Using EQN 25", {
  expect_equal(beta_hat_dd_25, beta_hat_dd_two_way)
})

# Equation 26
ret_bacon <- bacon(formula,
                   data = bacondecomp::castle,
                   id_var = "state",
                   time_var = "year")

two_by_twos <- ret_bacon$two_by_twos
beta_hat_b_two_by_twos <- weighted.mean(two_by_twos$estimate, two_by_twos$weight)

test_that("Equation 26 Correct", {
  expect_equal(beta_hat_b, beta_hat_b_two_by_twos)
})



# Recover Two Way FE

test_that("Two Way FE Recovered, Equation 27", {
  expect_equal(beta_hat_b_two_by_twos * (1 - ret_bacon$Omega) + ret_bacon$Omega * ret_bacon$beta_hat_w,
               beta_hat_dd_two_way)
})
evanjflack/bacondecomp documentation built on Sept. 19, 2021, 8:53 a.m.