Importing and Filtering
of Data and Shape Files
#Creating a reference map using the Philly shooting data set
#Import Shape Data
shootingMap <- st_read("https://tkelleman.github.io/tkweb/Week8/shootings.geojson")
Reading layer `shootings' from data source
`https://tkelleman.github.io/tkweb/Week8/shootings.geojson'
using driver `GeoJSON'
replacing null geometries with empty geometries
Simple feature collection with 15577 features and 21 fields (with 30 geometries empty)
Geometry type: POINT
Dimension: XY
Bounding box: xmin: -75.27362 ymin: 39.87799 xmax: -74.95936 ymax: 40.13117
Geodetic CRS: WGS 84
neighborhoodMap <- st_read("https://tkelleman.github.io/tkweb/Week8/philadelphiaNeighborhoods.geojson")
Reading layer `philadelphiaNeighborhoods' from data source
`https://tkelleman.github.io/tkweb/Week8/philadelphiaNeighborhoods.geojson'
using driver `GeoJSON'
Simple feature collection with 158 features and 8 fields
Geometry type: MULTIPOLYGON
Dimension: XY
Bounding box: xmin: -75.28027 ymin: 39.867 xmax: -74.95576 ymax: 40.13799
Geodetic CRS: WGS 84
#Read the Philly Crime data
phillyCrime <- na.omit(read.csv("https://tkelleman.github.io/tkweb/Week7/PhillyCrimeSince2015.csv"))
phillyCrime$name = toupper(gsub("-", "_", phillyCrime$neighborhood))
#Extract Year
y <- mdy_hm(phillyCrime$date)
phillyCrime$year <- year(y)
#Locations of Points on Map
dplotloc = st_as_sf(data.frame(x = -75.3677, y = 39.9168),
coords = c("x", "y"),
crs = 4326)
rplotloc = st_as_sf(data.frame(x = -75.3477, y = 39.9168),
coords = c("x", "y"),
crs = 4326)
Data Processing
In the code chunk above, spatial data for shootings and neighborhoods
in Philadelphia were imported using the st_read function from GeoJSON
files hosted on GitHub. The Philadelphia crime dataset since 2015 was
then read from a CSV file, omitting any missing values, and the
neighborhood names were standardized by converting them to uppercase and
replacing hyphens with underscores. Additionally, the date column from
the crime dataset was parsed to extract the year, which was added as a
new column. Finally, two points were defined using specific longitude
and latitude coordinates to represent locations on the map, and these
were converted into simple feature objects to be used as buttons to show
the ridgeline and density plots.
#Create Density Plot
dplot<-ggplot(phillyCrime, aes(x = age, color = race)) +
geom_density() +
labs(title = "Density Plot of Age by Race", x = "Age", y = "Density", fill="Race")
#Save Ridgeline Plot
ggsave(filename="dplot.png", plot=dplot)
#Create Ridgeline Plot
rplot<-ggplot(phillyCrime, aes(x = age, y = race, fill = race)) +
geom_density_ridges() +
labs(title = "Ridgeline Plot of Philadelphia Crime by Race", subtitle = "Age distribution by race", x = "Age", y = "Race") +
theme(legend.position = "none")
#Save Ridgeline Plot
ggsave(filename="rplot.png", plot=rplot)
# Import Pictures of Plots as PNG
dplot="https://tkelleman.github.io/tkweb/Week8/dplot.png"
rplot="https://tkelleman.github.io/tkweb/Week8/rplot.png"
# Define the style for the map title
style <- "position: fixed; top: 10px; left: 50%; transform: translateX(-50%);
background-color: rgba(135, 206, 235, 0.75); color: white;
padding: 5px; font-size: 18px; z-index: 400;"
map_title <- tags$div(style = style, "Map of Philadelpia Crime by Neighborhood")
#Generate Leaflet Map
leaflet() %>%
setView(lng=-75.15092, lat=40.00995, zoom = 11) %>%
addProviderTiles(providers$CartoDB.DarkMatter, group="DarkLabel") %>%
addProviderTiles(providers$CartoDB.DarkMatterNoLabels, group="Dark") %>%
addProviderTiles(providers$Esri.NatGeoWorldMap, group="Esri") %>%
addControl(map_title, position = "topleft", className="map-title")%>%
addMiniMap() %>%
addPolygons(data = neighborhoodMap,
color = 'skyblue',
weight = 1) %>%
addCircleMarkers(data = phillyCrime,
radius = ~ifelse(fatal == "Fatal", 5, 3),
stroke = FALSE,
fillOpacity = 0.5,
clusterOptions = markerClusterOptions(maxClusterRadius = 40))%>%
addLayersControl(baseGroups = c('Dark', 'DarkLabel', 'Esri'),
overlayGroups = c("Crime Data"))%>%
addCircleMarkers(data = dplotloc,
color = "skyblue",
weight = 2,
label = "Density Plot by Race",
stroke = FALSE,
fillOpacity = 0.95,
group = "dplotloc") %>%
addPopupImages(dplot,
width = 500,
height = 350,
tooltip = FALSE,
group = "dplotloc")%>%
addCircleMarkers(data = rplotloc,
color = "blue",
weight = 2,
label = "Ridgeline Plot by Race",
stroke = FALSE,
fillOpacity = 0.95,
group = "rplotloc") %>%
addPopupImages(rplot,
width = 500,
height = 350,
tooltip = FALSE,
group = "rplotloc")
Interactive Map of
Philadelphia Crime
The code chunk above creates two types of plots from the phillyCrime
dataset: a density plot and a ridgeline plot, both based on the age
distribution of different races in the phillyCrime datase and saves the
plots as a PNG image to be hosted on GitHub. An interactive Leaflet map
centered on Philadelphia is created with layers for dark, dark with
labels, and standard ESRI basemap.
This interactive leaflet
map shows crimes and neighborhoods the Philadelphia region. As the user
zooms in the markers show crimes committed in smaller sections based on
the coordinates in the dataset. From this map it could be interpreted
which neighborhoods in the Philadelphia region have higher or lower
crime rates. This could potentially be beneficial for first responder
resource allocation, prevention strategy implementation, property
valuation, and many other uses. Selecting the sky-blue marker pulls up
the density plot of age by race in the dataset. The blue marker pulls up
the ridgeline plot of Philadelphia crime by race in the dataset. Both of
these dataset show similar trends. From these plots, it is ages 20-40
make up the majority of crimes in the set.
---
title: "Week 8 - More R Maps and Case Study"
author: "Tim Kelleman"
date: "2024-03-21"

output:
  html_document: 
    toc: no
    toc_depth: 4
    toc_float: yes
    fig_width: 8
    fig_caption: yes
    number_sections: yes
    toc_collapsed: yes
    code_folding: hide
    code_download: yes
    smooth_scroll: true
    theme: readable
   
  pdf_document: 
    toc: no
    toc_depth: 4
    fig_caption: yes
    number_sections: yes
    fig_width: 5
    fig_height: 4
---

```{=html}
<style type="text/css">

div#TOC li {
    list-style:none;
    background-color:lightgray;
    background-image:none;
    background-repeat:none;
    background-position:0;
    font-family: Arial, Helvetica, sans-serif;
    color: #780c0c;
}

/* mouse over link */
div#TOC a:hover {
  color: red;
}

/* unvisited link */
div#TOC a:link {
  color: blue;
}



h1.title {
  font-size: 24px;
  color: Darkblue;
  text-align: center;
  font-family: Arial, Helvetica, sans-serif;
  font-variant-caps: normal;
}
h4.author { 
    font-size: 18px;
  font-family: "Times New Roman", Times, serif;
  color: DarkRed;
  text-align: center;
}
h4.date { 
  font-size: 18px;
  font-family: "Times New Roman", Times, serif;
  color: DarkBlue;
  text-align: center;
}
h1 {
    font-size: 24px;
    font-family: "Times New Roman", Times, serif;
    color: darkred;
    text-align: center;
}
h2 {
    font-size: 18px;
    font-family: "Times New Roman", Times, serif;
    color: navy;
    text-align: left;
}

h3 { 
    font-size: 15px;
    font-family: "Times New Roman", Times, serif;
    color: navy;
    text-align: left;
}

h4 { /* Header 4 - and the author and data headers use this too  */
    font-size: 18px;
    font-family: "Times New Roman", Times, serif;
    color: darkred;
    text-align: left;
}

/* unvisited link */
a:link {
  color: green;
}

/* visited link */
a:visited {
  color: green;
}

/* mouse over link */
a:hover {
  color: red;
}

/* selected link */
a:active {
  color: yellow;
}
</style>
```
---
```{r setup, include=FALSE}
# code chunk specifies whether the R code, warnings, and output 
# will be included in the output files.
options(repos = list(CRAN="http://cran.rstudio.com/"))
if (!require("tidyverse")) {
   install.packages("tidyverse")
   library(tidyverse)
}
if (!require("knitr")) {
   install.packages("knitr")
   library(knitr)
}
if (!require("cowplot")) {
   install.packages("cowplot")
   library(cowplot)
}
if (!require("latex2exp")) {
   install.packages("latex2exp")
   library(latex2exp)
}
if (!require("plotly")) {
   install.packages("plotly")
   library(plotly)
}
if (!require("gapminder")) {
   install.packages("gapminder")
   library(gapminder)
}
if (!require("png")) {
    install.packages("png")             # Install png package
    library("png")
}
if (!require("RCurl")) {
    install.packages("RCurl")           # Install RCurl package
    library("RCurl")
}
if (!require("colourpicker")) {
    install.packages("colourpicker")              
    library("colourpicker")
}
if (!require("gifski")) {
    install.packages("gifski")              
    library("gifski")
}
if (!require("magick")) {
    install.packages("magick")              
    library("magick")
}
if (!require("grDevices")) {
    install.packages("grDevices")              
    library("grDevices")
}
### ggplot and extensions
if (!require("ggplot2")) {
    install.packages("ggplot2")              
    library("ggplot2")
}
if (!require("gganimate")) {
    install.packages("gganimate")              
    library("gganimate")
}
if (!require("ggridges")) {
    install.packages("ggridges")              
    library("ggridges")
}
if (!require("graphics")) {
    install.packages("graphics")              
    library("graphics")
}
if (!require("dplyr")) {
    install.packages("dplyr")              
    library("dplyr")
}
if (!require("lubridate")) {
    install.packages("lubridate")              
    library("lubridate")
}
if (!require("tmap")) {
    install.packages("tmap")              
    library("tmap")
}
if (!require("sf")) {
    install.packages("sf")              
    library("sf")
}

if (!require("leaflet")) {
    install.packages("leaflet")              
    library("leaflet")
}
if (!require("leafpop")) {
    install.packages("leafpop")              
    library("leafpop")
}
if (!require("htmltools")) {
    install.packages("htmltools")              
    library("htmltools")
}

knitr::opts_chunk$set(echo = TRUE,       
                      warning = FALSE,   
                      result = TRUE,   
                      message = FALSE,
                      comment = NA)
```
# Importing and Filtering of Data and Shape Files
```{r eval=TRUE}
#Creating a reference map using the Philly shooting data set
#Import Shape Data
shootingMap <- st_read("https://tkelleman.github.io/tkweb/Week8/shootings.geojson")
neighborhoodMap  <- st_read("https://tkelleman.github.io/tkweb/Week8/philadelphiaNeighborhoods.geojson")

#Read the Philly Crime data
phillyCrime <- na.omit(read.csv("https://tkelleman.github.io/tkweb/Week7/PhillyCrimeSince2015.csv"))
phillyCrime$name = toupper(gsub("-", "_", phillyCrime$neighborhood)) 
#Extract Year
y <- mdy_hm(phillyCrime$date)
phillyCrime$year <- year(y)

#Locations of Points on Map
dplotloc = st_as_sf(data.frame(x = -75.3677, y = 39.9168),
                coords = c("x", "y"),
                 crs = 4326)
rplotloc = st_as_sf(data.frame(x = -75.3477, y = 39.9168),
                coords = c("x", "y"),
                crs = 4326)
```
# Data Processing
In the code chunk above, spatial data for shootings and neighborhoods in Philadelphia were imported using the st_read function from GeoJSON files hosted on GitHub. The Philadelphia crime dataset since 2015 was then read from a CSV file, omitting any missing values, and the neighborhood names were standardized by converting them to uppercase and replacing hyphens with underscores. Additionally, the date column from the crime dataset was parsed to extract the year, which was added as a new column. Finally, two points were defined using specific longitude and latitude coordinates to represent locations on the map, and these were converted into simple feature objects to be used as buttons to show the ridgeline and density plots. <br>

```{r eval=TRUE}
#Create Density Plot
dplot<-ggplot(phillyCrime, aes(x = age, color = race)) +
  geom_density() +
  labs(title = "Density Plot of Age by Race", x = "Age", y = "Density", fill="Race")  
#Save Ridgeline Plot
ggsave(filename="dplot.png", plot=dplot)

#Create Ridgeline Plot
rplot<-ggplot(phillyCrime, aes(x = age, y = race, fill = race)) +
  geom_density_ridges() +
  labs(title = "Ridgeline Plot of Philadelphia Crime by Race", subtitle = "Age distribution by race", x = "Age", y = "Race") +
  theme(legend.position = "none")
#Save Ridgeline Plot
ggsave(filename="rplot.png", plot=rplot)  

# Import Pictures of Plots as PNG
dplot="https://tkelleman.github.io/tkweb/Week8/dplot.png"
rplot="https://tkelleman.github.io/tkweb/Week8/rplot.png"


# Define the style for the map title
style <- "position: fixed; top: 10px; left: 50%; transform: translateX(-50%);
          background-color: rgba(135, 206, 235, 0.75); color: white;
          padding: 5px; font-size: 18px; z-index: 400;"
map_title <- tags$div(style = style, "Map of Philadelpia Crime by Neighborhood")

#Generate Leaflet Map
leaflet() %>%
  setView(lng=-75.15092, lat=40.00995, zoom = 11) %>%
  addProviderTiles(providers$CartoDB.DarkMatter, group="DarkLabel") %>%
  addProviderTiles(providers$CartoDB.DarkMatterNoLabels, group="Dark") %>%  
  addProviderTiles(providers$Esri.NatGeoWorldMap, group="Esri") %>%
  addControl(map_title, position = "topleft", className="map-title")%>%
  addMiniMap() %>%
  addPolygons(data = neighborhoodMap,
              color = 'skyblue',
              weight = 1)  %>%
  addCircleMarkers(data = phillyCrime,
                   radius = ~ifelse(fatal == "Fatal", 5, 3),
                   stroke = FALSE, 
                   fillOpacity = 0.5,
                   clusterOptions = markerClusterOptions(maxClusterRadius = 40))%>%
  addLayersControl(baseGroups = c('Dark', 'DarkLabel', 'Esri'),
                   overlayGroups = c("Crime Data"))%>%
  addCircleMarkers(data = dplotloc, 
                  color = "skyblue",
                  weight = 2,
                  label = "Density Plot by Race",
                  stroke = FALSE, 
                  fillOpacity = 0.95,
                  group = "dplotloc") %>%
  addPopupImages(dplot, 
                  width = 500,
                  height = 350,
                  tooltip = FALSE,
                  group = "dplotloc")%>%
  addCircleMarkers(data = rplotloc, 
                  color = "blue",
                  weight = 2,
                  label = "Ridgeline Plot by Race",
                  stroke = FALSE, 
                  fillOpacity = 0.95,
                   group = "rplotloc") %>%
  addPopupImages(rplot, 
                  width = 500,
                  height = 350,
                  tooltip = FALSE,
                  group = "rplotloc")
```
# Interactive Map of Philadelphia Crime
The code chunk above creates two types of plots from the phillyCrime dataset: a density plot and a ridgeline plot, both based on the age distribution of different races in the phillyCrime datase and saves the plots as a PNG image to be hosted on GitHub. An interactive Leaflet map centered on Philadelphia is created with layers for dark, dark with labels, and standard ESRI basemap. <br> <br>
This interactive leaflet map shows crimes and neighborhoods the Philadelphia region. As the user zooms in the markers show crimes committed in smaller sections based on the coordinates in the dataset. From this map it could be interpreted which neighborhoods in the Philadelphia region have higher or lower crime rates. This could potentially be beneficial for first responder resource allocation, prevention strategy implementation, property valuation, and many other uses.  Selecting the sky-blue marker pulls up the density plot of age by race in the dataset. The blue marker pulls up the ridgeline plot of Philadelphia crime by race in the dataset. Both of these dataset show similar trends. From these plots, it is ages 20-40 make up the majority of crimes in the set.  

