FEMA has several Hazard Mitigation Assistance (HMA) programs that provide grants for planning, resilient infrastructure, household mitigation, and buyouts:

  1. Hazard Mitigation Grant Program (HMGP)
    • provides funding to local governments so they can develop hazard mitigation plans and rebuild in a way that reduces, or mitigates, future disaster losses in their communities.
    • Availability: after a presidentially declared disaster.
    • Activities: Planning (code enforcements, buyouts); Flood Protection (levees, floodwalls, elevations, drainage); Retrofitting
  2. Flood Mitigation Assistance (FMA)
    • provides funding to local governments for projects that reduce risk of repetitive flood damage to NFIP insured buildings
    • Subsumed two defunct programs: Repetitive Flood Claims grant program (RFC) & Severe Repetitive Loss grant program (SRL)
    • Availability:
    • Activities:
  3. Building Resilient Communities (BRIC)
    • Subsumed Pre-disaster Mitigation Program (PDM), which ended out of 2018
    • Availability:
    • Activities: “Capability and capacity building”
  4. Legislative Pre-disaster Mitigation grant program (LPDM)
    • Also known as “Pre-disaster Mitigation congressional community projects”
    • As far as I can tell, this is competitive PDM funding that is just extra and for some reason not branded as BRIC?

The full extent of how FEMA and other agencies will use the new CDRZ designations is still unknown, but FEMA has announced that CDRZ census tracts will receive priority in selection and increased federal cost share support under BRIC. We explore whether that represents a significant shift in where historical BRIC funding has been directed.

Datasets:

History of all HMA funding

History of PDM / BRIC Funding

PDM / BRIC FUNDING:
BRIC is one of the programs that CDRZs designations will affect funding for.

Comparing previous funding vs. CDRZ designations

---
title: "FEMA's Hazard Mitigation Funding & CDRZ"
output: html_notebook
---

```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = FALSE, warning=FALSE, message=FALSE)
setwd("~/Analysis/FEMA_funding")
Packages <- c("dplyr", "ggplot2", "tidyverse", "httr", "jsonlite", "readxl", "tidycensus", "tidyr")
lapply(Packages, library, character.only = TRUE)
source("functions/analysis_functions.R")
```

FEMA has several Hazard Mitigation Assistance (HMA) programs that provide grants for planning, resilient infrastructure, household mitigation, and buyouts:  

1. **Hazard Mitigation Grant Program (HMGP)**  
    + provides funding to local governments so they can develop hazard mitigation plans and rebuild in a way that reduces, or mitigates, future disaster losses in their communities.   
    + Availability: after a presidentially declared disaster.  
    + Activities: Planning (code enforcements, buyouts); Flood Protection (levees, floodwalls, elevations, drainage); Retrofitting     
2. **Flood Mitigation Assistance (FMA)**  
    + provides funding to local governments for projects that reduce risk of repetitive flood damage to NFIP insured buildings
    + Subsumed two defunct programs: Repetitive Flood Claims grant program (RFC) & Severe Repetitive Loss grant program (SRL)  
    + Availability:  
    + Activities:  
3. **Building Resilient Communities (BRIC)**  
    + Subsumed Pre-disaster Mitigation Program (PDM), which ended out of 2018 
    + Availability:
    + Activities: "Capability and capacity building" 
4. **Legislative Pre-disaster Mitigation grant program (LPDM)**  
    + Also known as "Pre-disaster Mitigation congressional community projects"  
    + As far as I can tell, this is competitive PDM funding that is just extra and for some reason not branded as BRIC?   

The full extent of how FEMA and other agencies will use the new CDRZ designations is still unknown, but FEMA has announced that CDRZ census tracts will receive priority in selection and increased federal cost share support under **BRIC**. We explore whether that represents a significant shift in where historical BRIC funding has been directed.   

##### Datasets:  
* [*Hazard Mitigation Assistance Projects (V3)*](https://www.fema.gov/openfema-data-page/hazard-mitigation-assistance-projects-v3)
  + funded projects under HMA grant programs, including HMGP, FMA, PDM, and BRIC 
  + FY2002 - FY2023 (FY2019 for BRIC)
* [*HMA Subapplications*](https://www.fema.gov/openfema-data-page/hma-subapplications-v1)
  + subapplications / subgrants for FEMA HMA grants, with data collected under FEMA Grants Outcome (FEMA GO) grant system. Contains fields not included in prior project data, due to improved grant management system. 
  + Includes BRIC & FMA; will include BRIC in CY 2023   
  + FY2020 - FY2022  
* [*Hazard Mitigation Assistance Mitigated Properties*](https://www.fema.gov/openfema-data-page/hazard-mitigation-assistance-mitigated-properties-v3)  
  + data on the individual properties that were mitigated under HMA grant programs, representing a subset of the HMA Projects (V3) funds
  + FY1989 - FY2023

```{r}
#HMA data
hma_proj <- read.csv("data_raw/HazardMitigationAssistanceProjects.csv")
hma_props <- read.csv("data_raw/HazardMitigationAssistanceMitigatedProperties.csv")
hma_subapps <- read.csv("data_raw/HmaSubapplications.csv")
```

```{r}
#other datasets
cdrz <- read.csv("data_raw/FEMA_CommunityDisasterResilienceZones_0.csv") %>% 
  mutate(GEOID20 = as.character(GEOID20), 
         GEOID20 = str_pad(GEOID20, width=11, side="left", pad="0"))
xwalk <- read_excel("data_raw/TRACT_ZIP_032023.xlsx")
```

```{r}
#Data keys
states <- read.csv("keys/state_fips.csv", colClasses="character")
state_FIPS <- dplyr::pull(states, FIPS)
bric_fields <- read.csv("keys/bric_datafields.csv")
```
  
  
### History of all HMA funding  

```{r}
#Gather PDM + BRIC funding from two datasets
newnames <- dplyr::pull(bric_fields, new)
oldnames <- dplyr::pull(bric_fields, old)

pre2020 <- hma_proj %>% 
  rename_with(~ newnames[which(oldnames == .x)], .cols = oldnames)

post2020 <- hma_subapps %>% 
  filter(status == "subAwardAccepted") %>% 
  mutate(subapplicantZipCode = as.character(subapplicantZipCode)) %>% 
  mutate(subapplicantZipCode = str_pad(subapplicantZipCode, width=5, side="left", pad="0"))
```

```{r}
#combine project & FEMA GO dataset
full_HMA <- post2020 %>% bind_rows(pre2020) %>% 
  select(subapplicationIdentifier, id, program, fiscalYear, 
         subapplicantState, benefitingCounties, applicantName,
         status, totalSubapplicationAmount, totalObligatedAmount, federalSharePercentage, 
         benefitCostRatio, fundingCategory, primaryActivity, projectType) %>% 
  mutate(program = str_replace_all(program, c("Building Resilient Infrastructure and Communities" = "BRIC", 
                                              "Flood Mitigation Assistance" = "FMA"))) %>% 
  # relabeling defunct programs
  mutate(program = str_replace_all(program, c("RFC" = "FMA", 
                                              "SRL" = "FMA"))) 
                                              #"PDM" = "BRIC",
                                              #"LBRIC" = "LPDM")))
```

```{r}
#CPI conversion
moneyvars <- c("totalObligatedAmount", "totalSubapplicationAmount")

full_HMA <- apply_cpi(base_year="2022", df=full_HMA, 
                  money_fields=moneyvars, year_concat=c("fiscalYear" = "Year"))

```

```{r}
#graph data frame
gdf <- full_HMA %>% group_by(program, fiscalYear) %>% summarize(obligated = sum(totalObligatedAmount), app_totals = sum(totalSubapplicationAmount, na.rm=TRUE)) %>% 
  #convert to BILLIONS
  mutate(obligated = obligated / 1000000000)
```

```{r}
p <- gdf %>%
  ggplot( aes(x=fiscalYear, y=obligated, fill=factor(program, levels=c("HMGP", "FMA","PDM","BRIC", "LPDM")))) +
  geom_bar(stat = "identity") +
  scale_x_continuous(breaks = seq(1989, 2023, 3)) +
  #geom_point() +
  ggtitle("All FEMA HMA funded projects by Fiscal Year") +
  ylab("$Billions ($2022)") +
  xlab("Fiscal Year") +
  labs(caption="Note: FMA includes RFC & SRL; BRIC includes PDM",
       fill="program") + 
  scale_fill_brewer(palette = "Set2")
p
```

### History of PDM / BRIC Funding  
  
***PDM / BRIC FUNDING:***  
BRIC is one of the programs that CDRZs designations will affect funding for.  
  
* Prior to 2020: *HMA Projects*  
  + Pre-2019: BRIC was called the "pre-disaster mitigation" (PDM) program  
  + 2019: renamed as "BRIC"    
* 2020 onward: *HMA Subapplications*  

```{r}
full_BRIC <- full_HMA %>% 
  filter(program == "PDM" | program == "LPDM" | program == "BRIC")
```


```{r}
# graph data frame
gdf <- full_BRIC %>% group_by(program, fiscalYear) %>% summarize(obligated = sum(totalObligatedAmount), app_totals = sum(totalSubapplicationAmount, na.rm=TRUE)) %>% 
  # convert to MILLIONS
  mutate(obligated = obligated / 1000000)
```

```{r}
p <- gdf %>%
  ggplot( aes(x=fiscalYear, y=obligated, fill=program)) +
  geom_bar(stat = "identity") +
  scale_x_continuous(breaks = seq(2000, 2023, 2)) +
  #geom_point() +
  ggtitle("Pre-Disaster Mitigation + Building Resilient Communities funding by Fiscal Year") +
  ylab("$Millions (nominal)") +
  xlab("Fiscal Year") + 
  scale_fill_manual(values=c("#E78AC3", "#A6D854", "#8DA0CB"))
  #scale_fill_brewer(palette = "Set2")
p
```


```{r}
# BRIC + CDRZ overlap
# estimate per county benefits of BRIC funding (funding is equally distributed across "benefiting counties")
# f <- BRIC_post2020 %>% 
#   select(subapplicationIdentifier, subapplicantState, benefitingCounties, totalObligatedAmount, federalSharePercentage) %>% 
#   separate_longer_delim(benefitingCounties, delim = "; ") %>% 
#   group_by(subapplicationIdentifier) %>% 
#   mutate(distributed_amount = totalObligatedAmount / n()) %>% 
#   ungroup() %>% 
#   mutate(subapplicantState = str_to_title(subapplicantState),
#          benefitingCounties = str_to_title(benefitingCounties)) %>% 
#   mutate(benefitingCounties = str_remove_all(benefitingCounties, " County")) %>% 
#   group_by(subapplicantState, benefitingCounties) %>% 
#   summarize(sum_distributed_amount = sum(distributed_amount))
# 
# #summarize # of cdrz tracts in county
# c <- cdrz %>% group_by(State, County) %>% summarize(n_tracts = n())
# 
# # join cdrz tract count + funding estimates
# cf <- f %>% full_join(c, by=c("subapplicantState" = "State", "benefitingCounties" = "County"))
```


```{r}
# BRIC + CDRZ overlap
# estimate per county benefits of BRIC funding (funding is equally distributed across "benefiting counties")
f <- full_BRIC %>% 
  select(subapplicationIdentifier, subapplicantState, benefitingCounties, totalObligatedAmount, federalSharePercentage) %>% 
  separate_longer_delim(benefitingCounties, delim = "; ") %>% 
  group_by(subapplicationIdentifier) %>% 
  mutate(distributed_amount = totalObligatedAmount / n()) %>% 
  ungroup() %>% 
  mutate(subapplicantState = str_to_title(subapplicantState),
         benefitingCounties = str_to_title(benefitingCounties)) %>% 
  mutate(benefitingCounties = str_remove_all(benefitingCounties, " County")) %>% 
  group_by(subapplicantState, benefitingCounties) %>% 
  summarize(sum_distributed_amount = sum(distributed_amount))

#summarize # of cdrz tracts in county
c <- cdrz %>% group_by(State, County) %>% summarize(n_tracts = n())

# join cdrz tract count + funding estimates
cf <- f %>% full_join(c, by=c("subapplicantState" = "State", "benefitingCounties" = "County"))
```


```{r}
# JOIN to all counties
#pull full list of counties
all_counties <- tigris::counties(state=state_FIPS, cb=TRUE) %>%
  tigris::shift_geometry()

counties_cf <- all_counties %>% 
  left_join(cf, by=c("STATE_NAME" = "subapplicantState", "NAME" = "benefitingCounties")) %>% 
  mutate(sum_buckets = ntile(sum_distributed_amount, 10)) %>% 
  mutate(sum_mill = sum_distributed_amount/1000000)

```


### Comparing previous funding vs. CDRZ designations  
* Estimations at county level  
* BRIC funding post FY2020 attributed to all "benefitting counties". When multiple are listed, total obligated funds are equally distributed  
* Per County Funding summed across all fiscal years (FY2000 - FY2021)  
* CDRZ summed as a count within the county  
* Some historical records pre FY2020 do not have a "benefitting county" designated. I've omitted those for now. 

```{r}
# counties_cf %>%
#   ggplot( aes(x=sum_mill)) +
#     geom_histogram(bins=40, fill='skyblue', color='#69b3a2')
```

```{r, fig.width=10,fig.height=11}
library(viridis, cowplot)
#col.ramp <- viridis(n = 10)
#counties_cf <- counties_cf %>% mutate(sum_mill = replace_na(sum_mill,0))

qa <- quantile(counties_cf$sum_mill, c(0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9,1.0), na.rm=TRUE)
counties_cf$sum_mill_q <- cut(counties_cf$sum_mill, qa,
                              labels = c("0-10%", "20%", "30%", "40%", "50%", "60%", "70%", "80%", "90%", ">90%"),
                              include.lowest = TRUE)
col.pal <- colorRampPalette(c("#559999", "grey80", "#BB650B"))(10)


p1 <- ggplot(data=counties_cf, aes(fill=sum_mill_q)) + 
  geom_sf(color=NA) +
  theme_void() + 
  scale_fill_manual(values = col.pal, na.value = "grey50") +
  #scale_fill_viridis() +
  labs(fill="Benefits\nPercentile") + 
  theme(legend.key.size = unit(0.5, units="cm"), 
        legend.title = element_text(size = 10),
        legend.text = element_text(size = 10))

p2 <- ggplot(data=counties_cf, aes(fill=sum_mill)) + 
  geom_sf(color=NA) +
  theme_void() + 
  scale_fill_viridis(limits = c(0, 10), oob = scales::squish) + 
  labs(fill="Benefits\nMillions ($2022)") + 
  theme(legend.key.size = unit(0.5, units="cm"), 
        legend.title = element_text(size = 10),
        legend.text = element_text(size = 10))

# title_gg <- ggplot() + 
#   labs(title = "Total FEMA PDM+BRIC Federal Funding Benefits, by County", 
#        subtitle = "Obligated project funding from FY2000 - FY2021")

ptitle <- cowplot::ggdraw() + 
  cowplot::draw_label("Total FEMA PDM+BRIC Federal Funding Benefits, by County") +
  #cowplot::draw_label("Obligated project funding from FY2000 - FY2021") + 
  theme(plot.margin = margin(0, 0, 0, 7))

cowplot::plot_grid(ptitle, p1, p2, ncol=1, rel_heights = c(0.1, 1, 1))

```



```{r, fig.width=10, fig.height=11}
p1 <- ggplot(data=counties_cf, aes(fill=factor(n_tracts))) + 
  geom_sf(color=NA) +
  theme_void() + 
  scale_fill_brewer(palette = "YlOrRd", na.value = "grey50") +
    #scale_fill_gradient2() + 
  labs(fill="# CDRZs Tracts") + 
  theme(legend.key.size = unit(0.5, units="cm"), 
        legend.title = element_text(size = 10),
        legend.text = element_text(size = 10))

# title_gg <- ggplot() + 
#   labs(title = "Total FEMA PDM+BRIC Federal Funding Benefits, by County", 
#        subtitle = "Obligated project funding from FY2000 - FY2021")

ptitle <- cowplot::ggdraw() + 
  cowplot::draw_label("Count of CDRZ-designated Tracts, by County") +
  #cowplot::draw_label("Obligated project funding from FY2000 - FY2021") + 
  theme(plot.margin = margin(0, 0, 0, 7))

cowplot::plot_grid(ptitle, p1, ncol=1, rel_heights = c(0.1, 1))

```


