This is an R Markdown Notebook. When you execute code within the notebook, the results appear beneath the code.
Try executing this chunk by clicking the Run button within the chunk or by placing your cursor inside it and pressing Cmd+Shift+Enter.
setwd("~/Desktop")
#libraries
library(data.table)
library(sp)
library(rgdal)
library(ggplot2)
library(maptools)
library(raster)
library(leaflet)
#read in data table
ny_dat = fread("March 1 - final - March 1 - final.csv")
#convert to data table
ny_dat = as.data.table(ny_dat)
#table of total incidents by community
#filter places outside of chicago communities
#final number of observations = 1021
ny_tab = ny_dat['City or County'!=""]
#filter out NA values
ny_tab = na.omit(ny_dat)
#Change data type to NUM
ny_tab$Lat <- as.numeric(ny_tab$Lat)
ny_tab$Long <- as.numeric(ny_tab$Long)
#make data spatial
coordinates(ny_tab) = c("Long","Lat")
crs.geo1 = CRS("+proj=longlat")
proj4string(ny_tab) = crs.geo1
plot(ny_tab, pch = 20, col = "steelblue")

#read in shapefile of New York
New_York_Shape_File = readOGR(dsn = "./NYS Shapefile", layer = "cty036")
OGR data source with driver: ESRI Shapefile
Source: "/Users/ericfletcher/Desktop/NYS Shapefile", layer: "cty036"
with 67 features
It has 80 fields
plot(New_York_Shape_File)
points(ny_tab, pch = 20, col = "orange")

NA
NA
NA
#read in shapefile of chicago
New_York_Shape_File = readOGR(dsn = "./NYS Shapefile", layer = "cty036")
OGR data source with driver: ESRI Shapefile
Source: "/Users/ericfletcher/Desktop/NYS Shapefile", layer: "cty036"
with 67 features
It has 80 fields
#reproject coordinates
proj4string(New_York_Shape_File) = crs.geo1
A new CRS was assigned to an object with an existing CRS:
+proj=longlat +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +no_defs
without reprojecting.
For reprojection, use function spTransform
ny_agg = aggregate(x=ny_tab["Total_Involved"],by=New_York_Shape_File,FUN=length)
qpal = colorBin("Reds", ny_agg$Total_Involved, bins=4)
leaflet(ny_agg) %>%
addPolygons(stroke = TRUE,opacity = 1,fillOpacity = 0.5, smoothFactor = 0.5,
color="black",fillColor = ~qpal(Total_Involved),weight = 1) %>%
addLegend(values=~Total_Involved,pal=qpal,title="Total Injured or Killed <br> in Gun Violence per County <br> 03-01-20 to 4-26-20", na.label = "None Reported")
NA
NA
NA
#bins <- c(0, 10, 20, 30, 40, 50, 60, 70, 80, 100)
qpal = colorBin("Reds", ny_agg$Total_Involved, bins=4)
labels <- sprintf(
"<strong>%s</strong>",
ny_agg$Total_Involved
) %>% lapply(htmltools::HTML)
leaflet(ny_agg) %>%
addPolygons(stroke = TRUE,opacity = 1,fillOpacity = 0.5, smoothFactor = 0.5,
color="black",fillColor = ~qpal(Total_Involved),weight = 1, label = labels,
labelOptions = labelOptions(
style = list("font-weight" = "normal", padding = "3px 8px"),
textsize = "15px",
direction = "auto")) %>%
addLegend(values=~Total_Involved,pal=qpal,title="Total Injured or Killed <br> in Gun Violence per County <br> 03-01-20 to 4-26-20", na.label = "None Reported")
Add a new chunk by clicking the Insert Chunk button on the toolbar or by pressing Cmd+Option+I.
When you save the notebook, an HTML file containing the code and output will be saved alongside it (click the Preview button or press Cmd+Shift+K to preview the HTML file).
The preview shows you a rendered HTML copy of the contents of the editor. Consequently, unlike Knit, Preview does not run any R code chunks. Instead, the output of the chunk when it was last run in the editor is displayed.
LS0tCnRpdGxlOiAiUiBOb3RlYm9vayIKb3V0cHV0OiBodG1sX25vdGVib29rCi0tLQoKVGhpcyBpcyBhbiBbUiBNYXJrZG93bl0oaHR0cDovL3JtYXJrZG93bi5yc3R1ZGlvLmNvbSkgTm90ZWJvb2suIFdoZW4geW91IGV4ZWN1dGUgY29kZSB3aXRoaW4gdGhlIG5vdGVib29rLCB0aGUgcmVzdWx0cyBhcHBlYXIgYmVuZWF0aCB0aGUgY29kZS4gCgpUcnkgZXhlY3V0aW5nIHRoaXMgY2h1bmsgYnkgY2xpY2tpbmcgdGhlICpSdW4qIGJ1dHRvbiB3aXRoaW4gdGhlIGNodW5rIG9yIGJ5IHBsYWNpbmcgeW91ciBjdXJzb3IgaW5zaWRlIGl0IGFuZCBwcmVzc2luZyAqQ21kK1NoaWZ0K0VudGVyKi4gCgpgYGB7cn0Kc2V0d2QoIn4vRGVza3RvcCIpCgojbGlicmFyaWVzCmxpYnJhcnkoZGF0YS50YWJsZSkKbGlicmFyeShzcCkKbGlicmFyeShyZ2RhbCkKbGlicmFyeShnZ3Bsb3QyKQpsaWJyYXJ5KG1hcHRvb2xzKQpsaWJyYXJ5KHJhc3RlcikKbGlicmFyeShsZWFmbGV0KQoKI3JlYWQgaW4gZGF0YSB0YWJsZQpueV9kYXQgPSBmcmVhZCgiTWFyY2ggMSAtIGZpbmFsIC0gTWFyY2ggMSAtIGZpbmFsLmNzdiIpCgojY29udmVydCB0byBkYXRhIHRhYmxlCm55X2RhdCA9IGFzLmRhdGEudGFibGUobnlfZGF0KQoKI3RhYmxlIG9mIHRvdGFsIGluY2lkZW50cyBieSBjb21tdW5pdHkKI2ZpbHRlciBwbGFjZXMgb3V0c2lkZSBvZiBjaGljYWdvIGNvbW11bml0aWVzCiNmaW5hbCBudW1iZXIgb2Ygb2JzZXJ2YXRpb25zID0gMTAyMQpueV90YWIgPSBueV9kYXRbJ0NpdHkgb3IgQ291bnR5JyE9IiJdCgojZmlsdGVyIG91dCBOQSB2YWx1ZXMKbnlfdGFiID0gbmEub21pdChueV9kYXQpCgojQ2hhbmdlIGRhdGEgdHlwZSB0byBOVU0KbnlfdGFiJExhdCA8LSBhcy5udW1lcmljKG55X3RhYiRMYXQpCm55X3RhYiRMb25nIDwtIGFzLm51bWVyaWMobnlfdGFiJExvbmcpCgoKI21ha2UgZGF0YSBzcGF0aWFsCmNvb3JkaW5hdGVzKG55X3RhYikgPSBjKCJMb25nIiwiTGF0IikKY3JzLmdlbzEgPSBDUlMoIitwcm9qPWxvbmdsYXQiKSAgCnByb2o0c3RyaW5nKG55X3RhYikgPSBjcnMuZ2VvMSAgCgoKcGxvdChueV90YWIsIHBjaCA9IDIwLCBjb2wgPSAic3RlZWxibHVlIikKCmBgYApgYGB7cn0KI3JlYWQgaW4gc2hhcGVmaWxlIG9mIE5ldyBZb3JrCk5ld19Zb3JrX1NoYXBlX0ZpbGUgPSByZWFkT0dSKGRzbiA9ICIuL05ZUyBTaGFwZWZpbGUiLCBsYXllciA9ICJjdHkwMzYiKQoKcGxvdChOZXdfWW9ya19TaGFwZV9GaWxlKQoKcG9pbnRzKG55X3RhYiwgcGNoID0gMjAsIGNvbCA9ICJvcmFuZ2UiKQoKCgpgYGAKCgpgYGB7cn0KI3JlYWQgaW4gc2hhcGVmaWxlIG9mIGNoaWNhZ28KTmV3X1lvcmtfU2hhcGVfRmlsZSA9IHJlYWRPR1IoZHNuID0gIi4vTllTIFNoYXBlZmlsZSIsIGxheWVyID0gImN0eTAzNiIpCgojcmVwcm9qZWN0IGNvb3JkaW5hdGVzCnByb2o0c3RyaW5nKE5ld19Zb3JrX1NoYXBlX0ZpbGUpID0gY3JzLmdlbzEKCm55X2FnZyA9IGFnZ3JlZ2F0ZSh4PW55X3RhYlsiVG90YWxfSW52b2x2ZWQiXSxieT1OZXdfWW9ya19TaGFwZV9GaWxlLEZVTj1sZW5ndGgpCgpxcGFsID0gY29sb3JCaW4oIlJlZHMiLCBueV9hZ2ckVG90YWxfSW52b2x2ZWQsIGJpbnM9NCkKCmxlYWZsZXQobnlfYWdnKSAlPiUKICBhZGRQb2x5Z29ucyhzdHJva2UgPSBUUlVFLG9wYWNpdHkgPSAxLGZpbGxPcGFjaXR5ID0gMC41LCBzbW9vdGhGYWN0b3IgPSAwLjUsCiAgICAgICAgICAgICAgY29sb3I9ImJsYWNrIixmaWxsQ29sb3IgPSB+cXBhbChUb3RhbF9JbnZvbHZlZCksd2VpZ2h0ID0gMSkgJT4lCiAgYWRkTGVnZW5kKHZhbHVlcz1+VG90YWxfSW52b2x2ZWQscGFsPXFwYWwsdGl0bGU9IlRvdGFsIEluanVyZWQgb3IgS2lsbGVkIDxicj4gaW4gR3VuIFZpb2xlbmNlIHBlciBDb3VudHkgPGJyPiAwMy0wMS0yMCB0byA0LTI2LTIwIiwgbmEubGFiZWwgPSAiTm9uZSBSZXBvcnRlZCIpCgoKCmBgYApgYGB7cn0KI2JpbnMgPC0gYygwLCAxMCwgMjAsIDMwLCA0MCwgNTAsIDYwLCA3MCwgODAsIDEwMCkKcXBhbCA9IGNvbG9yQmluKCJSZWRzIiwgbnlfYWdnJFRvdGFsX0ludm9sdmVkLCBiaW5zPTQpCgpsYWJlbHMgPC0gc3ByaW50ZigKICAiPHN0cm9uZz4lczwvc3Ryb25nPiIsCiAgbnlfYWdnJFRvdGFsX0ludm9sdmVkCikgJT4lIGxhcHBseShodG1sdG9vbHM6OkhUTUwpCgpsZWFmbGV0KG55X2FnZykgJT4lCiAgYWRkUG9seWdvbnMoc3Ryb2tlID0gVFJVRSxvcGFjaXR5ID0gMSxmaWxsT3BhY2l0eSA9IDAuNSwgc21vb3RoRmFjdG9yID0gMC41LAogICAgICAgICAgICAgIGNvbG9yPSJibGFjayIsZmlsbENvbG9yID0gfnFwYWwoVG90YWxfSW52b2x2ZWQpLHdlaWdodCA9IDEsIGxhYmVsID0gbGFiZWxzLAogICAgICAgICAgICAgIGxhYmVsT3B0aW9ucyA9IGxhYmVsT3B0aW9ucygKICAgICAgICAgICAgICAgIHN0eWxlID0gbGlzdCgiZm9udC13ZWlnaHQiID0gIm5vcm1hbCIsIHBhZGRpbmcgPSAiM3B4IDhweCIpLAogICAgICAgICAgICAgICAgdGV4dHNpemUgPSAiMTVweCIsCiAgICAgICAgICAgICAgICBkaXJlY3Rpb24gPSAiYXV0byIpKSAlPiUKICBhZGRMZWdlbmQodmFsdWVzPX5Ub3RhbF9JbnZvbHZlZCxwYWw9cXBhbCx0aXRsZT0iVG90YWwgSW5qdXJlZCBvciBLaWxsZWQgPGJyPiBpbiBHdW4gVmlvbGVuY2UgcGVyIENvdW50eSA8YnI+IDAzLTAxLTIwIHRvIDQtMjYtMjAiLCBuYS5sYWJlbCA9ICJOb25lIFJlcG9ydGVkIikKYGBgCgpBZGQgYSBuZXcgY2h1bmsgYnkgY2xpY2tpbmcgdGhlICpJbnNlcnQgQ2h1bmsqIGJ1dHRvbiBvbiB0aGUgdG9vbGJhciBvciBieSBwcmVzc2luZyAqQ21kK09wdGlvbitJKi4KCldoZW4geW91IHNhdmUgdGhlIG5vdGVib29rLCBhbiBIVE1MIGZpbGUgY29udGFpbmluZyB0aGUgY29kZSBhbmQgb3V0cHV0IHdpbGwgYmUgc2F2ZWQgYWxvbmdzaWRlIGl0IChjbGljayB0aGUgKlByZXZpZXcqIGJ1dHRvbiBvciBwcmVzcyAqQ21kK1NoaWZ0K0sqIHRvIHByZXZpZXcgdGhlIEhUTUwgZmlsZSkuIAoKVGhlIHByZXZpZXcgc2hvd3MgeW91IGEgcmVuZGVyZWQgSFRNTCBjb3B5IG9mIHRoZSBjb250ZW50cyBvZiB0aGUgZWRpdG9yLiBDb25zZXF1ZW50bHksIHVubGlrZSAqS25pdCosICpQcmV2aWV3KiBkb2VzIG5vdCBydW4gYW55IFIgY29kZSBjaHVua3MuIEluc3RlYWQsIHRoZSBvdXRwdXQgb2YgdGhlIGNodW5rIHdoZW4gaXQgd2FzIGxhc3QgcnVuIGluIHRoZSBlZGl0b3IgaXMgZGlzcGxheWVkLgoK