data %>%
mutate(dividend_yield = dividend / s_p_price,
earnings_yield = earnings / s_p_price) %>%
select(date, dividend_yield, earnings_yield) %>%
gather(variable, value, -date) %>%
na.omit %>%
filter(date >= as.Date("1980-01-01")) %>%
mutate(variable_desc = case_when(variable == "dividend_yield" ~ "Dividend Yield (%)",
variable == "earnings_yield" ~ "Earnings Yield (%)")) %>%
na.omit %>%
ggplot(.) + geom_line(aes(x = date, y = value, color = variable_desc)) +
ylab("Dividend / Earnings Yield (%)") + xlab("") + theme_minimal() +
scale_color_manual(values = viridis(3)[1:2]) +
scale_x_date(breaks = as.Date(paste0(seq(1980, 2100, 5), "-01-01")),
labels = date_format("%y"),) +
geom_rect(data = nber_recessions %>%
filter(Peak > as.Date("1980-01-01")),
aes(xmin = Peak, xmax = Trough, ymin = -Inf, ymax = +Inf),
fill = 'grey', alpha = 0.5) +
theme(legend.position = c(0.45, 0.9),
legend.title = element_blank()) +
scale_y_continuous(breaks = 0.01*seq(0, 30, 1),
labels = scales::percent_format(accuracy = 1))