Percent Vacant housing units for 2011, Cenus Tracts, Harris County, TX
Vach11<-get_acs(geography = "tract",
state="TX",
county = "201",
year = 2011,
variables="DP04_0003P" ,
geometry = T,
output = "wide",
progress_bar=F ) %>%
mutate(PVHU = DP04_0003PE,
PVHU_er = DP04_0003PM/1.645,
PVHU_cv =100* (PVHU_er/PVHU)) %>%
filter(complete.cases(PVHU), is.finite(PVHU_cv)==T)%>%
select(GEOID, PVHU, PVHU_er,PVHU_cv)
head(Vach11)
Percent Vacant housing units for 2019, Census Tracts, Harris County, TX
Vach19<-get_acs(geography = "tract",
state="TX",
county = "201",
year = 2019,
variables="DP04_0003P" ,
geometry = T,
output = "wide",
progress_bar=F) %>%
mutate(PVHU19 = DP04_0003PE,
PVHU_er19 = DP04_0003PM/1.645,
PVHU_cv19 =100* (PVHU_er19/PVHU19)) %>%
filter(complete.cases(PVHU19), is.finite(PVHU_cv19)==T)%>%
select(GEOID, PVHU19, PVHU_er19,PVHU_cv19)
head(Vach19)
Mapping Percent Vacant Housing Units for 2011 & 2019, Census Tracts, Harris County, TX


Calculating the differences between the two years (2011 & 2019), including the test for significance of the differences
# Make one of the dataset a non sf class dataset
Vach19_df <- Vach19 %>%
data.frame() %>%
select(-geometry)
# Then merge the non sf class dataset to the sf class dataset
Vach1119 <- left_join(Vach11, Vach19_df, by=c("GEOID"="GEOID")) %>%
na.omit()
#calculate the change between the percent vacant housing unit in 2011 and 2019
diff1119<-acstest(names = Vach1119$GEOID,
geoid =Vach1119$GEOID,
est1 = Vach1119$PVHU,
est2 = Vach1119$PVHU19,
err1 = Vach1119$PVHU_er,
err2=Vach1119$PVHU_er19,
alpha = .1,
yr1 = 2011, yr2=2019,
span = 4)
# Then merge the diffences dataset with the Vach1119
Mergediff <- left_join(Vach1119, diff1119, by=c("GEOID"="geoid"))
head(Mergediff)
Mapping Differences In Percent Vacant Housing Units Between 2011 & 2019, Census Tracts, Harris County, TX

Mapping Test For Significance of the Changes In Percent Vacant Housing Units Between 2011 & 2019, Census Tracts, Harris County, TX

---
title: "GIS Homework 4 - Mapping Using the American Community Survey - Change Mapping"
author: "Samson A Olowolaju, MPH"
date: "`r format(Sys.time(), '%d %B, %Y')`"
output:
   html_document:
    df_print: paged
    fig_height: 7
    fig_width: 7
    toc: yes
    toc_float: yes
    code_download: true
    always_allow_html: yes
---

```{r, message=FALSE, echo=FALSE, warning=FALSE}
library(tidycensus)
library(tidyverse)
library(sf)
library(ggplot2)
library(ggsn)
library(rio)
library(tmap)
```


```{r,results='hide',echo=FALSE}
v10_Profile <- load_variables(2011,
                              "acs5/profile",
                              cache = TRUE) #demographic profile tables
v19_Profile <- load_variables(2019,
                              "acs5/profile",
                              cache = TRUE) #demographic 

#Search for variables by using grep()

v10_Profile[grep(x = v10_Profile$label,
                 "Vacant housing units",
                 ignore.case = TRUE), 
            c("name", "label")]

v19_Profile[grep(x = v19_Profile$label,
                 "Vacant housing units",
                 ignore.case = TRUE),
            c("name", "label")]
```


# Percent Vacant housing units for 2011, Cenus Tracts, Harris County, TX

```{r, message=FALSE, warning=FALSE}

Vach11<-get_acs(geography = "tract",
                state="TX",
                county = "201",
                year = 2011,
                variables="DP04_0003P" ,
                geometry = T,
                output = "wide",
               progress_bar=F ) %>%  
  mutate(PVHU = DP04_0003PE,
         PVHU_er = DP04_0003PM/1.645,
         PVHU_cv =100* (PVHU_er/PVHU)) %>%
  filter(complete.cases(PVHU), is.finite(PVHU_cv)==T)%>%
  select(GEOID, PVHU, PVHU_er,PVHU_cv)

head(Vach11)
```

# Percent Vacant housing units for 2019, Census Tracts, Harris County, TX 

```{r, message=FALSE, warning=FALSE}
Vach19<-get_acs(geography = "tract",
                state="TX",
                county = "201",
                year = 2019,
                variables="DP04_0003P" ,
                geometry = T,
                output = "wide",
                progress_bar=F) %>%  
  mutate(PVHU19 = DP04_0003PE,
         PVHU_er19 = DP04_0003PM/1.645,
         PVHU_cv19 =100* (PVHU_er19/PVHU19)) %>%
  filter(complete.cases(PVHU19), is.finite(PVHU_cv19)==T)%>%
  select(GEOID, PVHU19, PVHU_er19,PVHU_cv19)

head(Vach19)
```

# **Mapping Percent Vacant Housing Units for 2011 & 2019, Census Tracts, Harris County, TX**

```{r,fig.align='center',out.width='100%', echo=FALSE}

(p1 <- tm_shape(Vach11)+
  tm_polygons(c("PVHU"),
              title=c("% Vacant Housing Units"), 
              palette="Blues",
              style="quantile",
              n=5)+
  tm_scale_bar(position = c("LEFT", "BOTTOM"))+
  tm_compass( size = 2, position = c("right", "top"))+
  tm_credits("Data source:\n ACS 5year Estimates",
             align = "right", 
             position=c("right", "BOTTOM"),size = 0.5, ) + 
  tm_layout(main.title = "Percent Estimate of Vacant Housing Units, Census Tracts, Harris County, TX (2007-2011) ",
            main.title.fontfamily= "serif",
            main.title.fontface = "bold",
            main.title.size =1, 
            legend.frame = TRUE,
            legend.title.fontface = "bold",
            legend.title.size = .8,
            title.position = c('right', 'top'), 
            inner.margins=c(.04,.03, .02, .01)))

(p2 <-  tm_shape(Vach19)+
  tm_polygons(c("PVHU19"),
              title=c("% Vacant Housing Units"), 
              palette="Blues",
              style="quantile",
              n=5)+
  tm_scale_bar(position = c("LEFT", "BOTTOM"))+
  tm_compass( size = 2, position = c("right", "top"))+
  tm_credits("Data source:\n ACS 5year Estimates",
             align = "right", 
             position=c("right", "BOTTOM"),size = 0.5 ) + 
  tm_layout(main.title = "Percent Estimate of Vacant Housing Units, Census Tracts, Harris County, TX  (2015-2019) ",
            main.title.fontfamily= "serif",
            main.title.fontface = "bold",
            main.title.size =1, 
            legend.frame = TRUE,
            legend.title.fontface = "bold",
            legend.title.size = .8,
            title.position = c('right', 'top'), 
            inner.margins=c(.04,.03, .02, .01)))

```



```{r, echo=FALSE}
 
# creating a function to calculate differences between the two outcomes 
 acstest<-function(names,geoid, est1, err1, est2, err2, alpha, yr1, yr2, span){
  
  se1<-err1/qnorm(.90)
  se2<-err2/qnorm(.90)
  yrs1<-seq(yr1, to=yr1-span)
  yrs2<-seq(yr2, to=yr2-span)

  C<-mean(yrs2%in%yrs1)
  diff<- (est1-est2)
  test<-(est1-est2) / (sqrt(1-C)*sqrt(se1^2+se2^2))
  crit<-qnorm(1-alpha/2)
  pval<-1-pnorm(abs(test))
  result<-NULL
  result[pval > alpha]<-"Insignificant Change"
  result[pval < alpha & test < 0]<- "Significant Increase"
  result[pval < alpha & test > 0]<-"Significant Decrease" 
  
  data.frame(name=names,geoid=geoid, est1=est1, est2=est2, se1=se1, se2=se2,difference=diff, test=test, result=result, pval=pval)
}
```

# Calculating the differences between the two years (2011 & 2019), including the test for significance of the differences

```{r}

# Make one of the dataset a non sf class dataset
Vach19_df <- Vach19 %>% 
  data.frame() %>% 
  select(-geometry)

 # Then merge the non sf class dataset to the sf class dataset 
Vach1119 <- left_join(Vach11, Vach19_df, by=c("GEOID"="GEOID")) %>% 
   na.omit()

#calculate the change between the percent vacant housing unit in 2011 and 2019
diff1119<-acstest(names = Vach1119$GEOID,
                    geoid =Vach1119$GEOID,
                    est1 = Vach1119$PVHU,
                    est2 = Vach1119$PVHU19,
                    err1 = Vach1119$PVHU_er,
                    err2=Vach1119$PVHU_er19,
                    alpha = .1,
                    yr1 = 2011, yr2=2019,
                    span = 4)

# Then merge the diffences dataset with the Vach1119
Mergediff <- left_join(Vach1119, diff1119, by=c("GEOID"="geoid")) 

head(Mergediff)
```


# **Mapping Differences In Percent Vacant Housing Units Between 2011 & 2019, Census Tracts, Harris County, TX**

```{r, fig.align='center',out.width='100%',echo=FALSE}
  tm_shape(Mergediff)+
  tm_polygons(c("difference"),
              title=c("Changes in Percent"), 
              palette="Blues",
              style="quantile",
              n=5)+
  tm_scale_bar(position = c("LEFT", "BOTTOM"))+
  tm_compass( size = 2, position = c("right", "top"))+
  tm_credits("Data source:\n ACS 5year Estimates",
             align = "right", 
             position=c("right", "BOTTOM"),size = 0.5 ) + 
  tm_layout(main.title = "Change in Percent of Vacant Housing Units, Census Tracts, Harris County, TX (2011-2019) ",
            main.title.fontfamily= "serif",
            main.title.fontface = "bold",
            main.title.size =1, 
            legend.frame = TRUE,
            legend.title.fontface = "bold",
            legend.title.size =.8,
            title.position = c('right', 'top'), 
            inner.margins=c(.04,.03, .02, .01))
```

# **Mapping Test For Significance of the Changes In Percent Vacant Housing Units Between 2011 & 2019, Census Tracts, Harris County, TX**
```{r, fig.align='center',out.width='100%',echo=FALSE}
tm_shape(Mergediff)+
  tm_polygons(c("result"),
              title=c("Test Of Significance"), 
              palette="Set2",
              style="quantile",
              n=5)+
  tm_scale_bar(position = c("LEFT", "BOTTOM"))+
  tm_compass( size = 2, position = c("right", "top"))+
  tm_credits("Data source:\n ACS 5year Estimates",
             align = "right", 
             position=c("right", "BOTTOM"),size = 0.5 ) + 
  tm_layout(main.title = "Test For Significance Changes in Percent of Vacant Housing Units, Census Tracts,\n Harris County, TX (2011-2019) ",
            main.title.fontfamily= "serif",
            main.title.fontface = "bold",
            main.title.size =1, 
            legend.frame = TRUE,
            legend.title.fontface = "bold",
            legend.title.size =.8,
            title.position = c('right', 'top'), 
            inner.margins=c(.04,.03, .02, .01))
```

