Thanks to David Kahle and Hadley Wickham who ramped up that example and subsequently developed the {ggmap} package, making maps in R can be really intuitive and fun!
I wrote a wrapper function that takes a location within England and Wales, downloads crime data around that location over a certain period of time and creates crime weather plots. This blog post discusses the data used, methodology and the wrapper function with some worked examples. The codes are available here.
(Nov-2013 Update: I have updated the codes and created a web app using Shiny and ShinyApps. For more information, please read this new blog post.)
Data
The street-level crime data is one of the 9,000 datasets available from data.gov.uk. The data can be downloaded systematically via the Police API. The latest version of the API no longer requires authentication.
The following URL can be used to obtain crime records at street-level within a one-mile radius of a single point. The parameters required are latitude, longitude and month. The downloaded data is in JSON format which can be converted into R's data format using the {RJSONIO} package.
Example URL: http://data.police.uk/api/crimes-street/all-crime?lat=52.629729&lng=-1.131592&date=2012-04
The following URL can be used to obtain crime records at street-level within a one-mile radius of a single point. The parameters required are latitude, longitude and month. The downloaded data is in JSON format which can be converted into R's data format using the {RJSONIO} package.
Example URL: http://data.police.uk/api/crimes-street/all-crime?lat=52.629729&lng=-1.131592&date=2012-04
Methodology
The methodology can be summarised in the following six steps:
1. Obtain latitude and longitude of a user-defined location using ggmap::geocode.
2. Download crime data via the Police API as discussed above.
3. Convert JSON into a list and then a data frame.
4. Download a base map from Google using ggmap::get_googlemap.
5. Covert the base map into a ggplot object using ggmap::ggmap.
6. Add multiple layers on top of the base map using the data frame like a normal ggplot.
For more details, check out the functions in the codes:
1. Obtain latitude and longitude of a user-defined location using ggmap::geocode.
2. Download crime data via the Police API as discussed above.
3. Convert JSON into a list and then a data frame.
4. Download a base map from Google using ggmap::get_googlemap.
5. Covert the base map into a ggplot object using ggmap::ggmap.
6. Add multiple layers on top of the base map using the data frame like a normal ggplot.
For more details, check out the functions in the codes:
- "get.data" and "list2df" for steps 1, 2 and 3
- "visualise.data" for steps 4, 5 and 6
Wrapper and Worked Examples
The wrapper function looks like this ...
... given the location, time period and a few more graphical settings, the wrapper can produce a crime weather map. The following worked examples illustrate the usage.
crimeplot.wrapper <- function( point.of.interest = "London Eye", ## user-defined location period = c("2013-01","2013-02"), ## period of time in YYYY-MM type.map = "roadmap", ## roadmap, terrain, satellite or hybrid type.facet = NA, ## options: NA, month, category or type type.print = NA, ## options: NA, panel or window output.plot = TRUE, ## print it to a png file? output.filename = "temp.png", ## provide a filename output.size = c(700,700)) ## width and height setting
Example 1 - All crimes around London Eye from Jan-2013 to Apr-2013
Comments:
Here we can see a huge crime hotspt in the Soho district of London - an area full of bars, restaurants, theatres and nightclubs (did I mention Chinatown?)
Codes:
## Define the period
ex1.period <- format(seq(as.Date("2013-01-01"),length=4,by="months"),"%Y-%m")
## Use the wrapper ex1.plot <- crimeplot.wrapper(point.of.interest = "London Eye", period = ex1.period, type.map = "roadmap", output.filename = "ex1.png", output.size = c(700,700))
Example 2 - Typical crimes and traffic incidents around London Eye from Jan-2013 to Apr-2013
(Note: click on the image to see original image in higher resolution)
Comments:
Now we seperate the data from British Transport Police (BTP) and all other forces (Force) using the facet function in {ggplot}. We can see a traffic black spot on the other side of River Thames.
Codes:
## Define the period ex2.period <- format(seq(as.Date("2013-01-01"),length=4,by="months"),"%Y-%m") ## Use the wrapper ex2.plot <- crimeplot.wrapper(point.of.interest = "London Eye", period = ex2.period, type.map = "roadmap", type.facet = "type", output.filename = "ex2.png", output.size = c(1400,700))
Example 3 - Monthly crimes in Manchester for the year 2012 on a satellite map
(Note: click on the image to see original image in higher resolution)
Comments:
Using the facet function on "month", we can look at the changes in patterns over time. Looks like there is not much seasonality in Manchester as the crime hotspots remain hot over the year.
Codes:
## Define the period ex3.period <- format(seq(as.Date("2012-01-01"),length=12,by="months"),"%Y-%m") ## Use the wrapper ex3.plot <- crimeplot.wrapper(point.of.interest = "Manchester", period = ex3.period, type.map = "satellite", type.facet = "month", output.filename = "ex3.png", output.size = c(1400,1400))
Example 4 - Crimes by categories in Liverpool from Jan-2013 to Apr-2013 on a hybrid map
(Note: click on the image to see original image in higher resolution)
Comments:
Now we separate different categories of crimes. It is interesting to see that only a small part of the city is affected by shoplifting and other theft while burglary, arson and vehicle crimes are very common problems in Liverpool.
Codes:
## Define the period ex4.period <- format(seq(as.Date("2013-01-01"),length=4,by="months"),"%Y-%m") ## Use the wrapper ex4.plot <- crimeplot.wrapper(point.of.interest = "Liverpool", period = ex4.period, type.map = "hybrid", type.facet = "category", output.filename = "ex4.png", output.size = c(1400,1400))
Further Work
Further work is needed to ...1. optimise the codes for "list2df" transformation (At the moment it is quite slow. I tried lapply but it didn't give me back the desired data frame format but I know there must be a solution.)
2. better automate the graphical settings for output resolution, font size etc.
3. make it interactive using {Shiny}
(Nov-2013 Update: I have improved (1) using plyr::ldply and done (2 & 3). See this.)
Acknowledgement
I would like to thank Yanchang Zhao for his excellent book titled "R and Data Mining: Examples and Case Studies" which encouraged me to shift from MATLAB to R. All embedded codes were Created by Pretty R at inside-R.org.
Thanks for sharing this article...
ReplyDeleteLeanpitch provides online training in Advanced Scrum Master during this lockdown period everyone can use it wisely.
Advanced Scrum Master Training Online
Thanks for sharing this informative content , Great work
ReplyDeleteLeanpitch provides online training in Advanced Scrum Master during this lockdown period everyone can use it wisely.
Advanced Scrum Master Training
Thanks for sharing this informative content , Great work
ReplyDeleteLeanpitch provides online training in Advanced Scrum Master during this lockdown period everyone can use it wisely.
Advanced CSM training online
Thanks for sharing this informative content , Great work
ReplyDeleteLeanpitch provides online training in Coaching agile transitions during this lockdown period everyone can use it wisely.
Coaching agile transitions
Thanks for sharing this informative content , Great work
ReplyDeleteLeanpitch provides online training in Product prototyping during this lockdown period everyone can use it wisely.
icp-cat training
Thanks for sharing this informative content , Great work
ReplyDeleteLeanpitch provides crash course in Conducting User Interview during this lockdown period everyone can use it wisely
Conducting user interview
Thanks for sharing this informative content , Great work
ReplyDeleteLeanpitch provides online training in Devops during this lockdown period everyone can use it wisely.
Devops Online Training
Thanks for sharing this informative content , Great work
ReplyDeleteDevops Online Training
Leanpitch provides online training in Devops during this lockdown period everyone can use it wisely.
Thanks for sharing this informative content , Great work
ReplyDeleteLeanpitch provides online certification in scrum master during this lockdown period everyone can use it wisely.
Scrum master certification
Thanks for sharing this informative content , Great work
ReplyDeleteLeanpitch provides online training in Product management during this lockdown period everyone can use it wisely.
Product management Certification
Thanks for sharing this.,
ReplyDeleteLeanpitch provides online training in Scrum Master during this lockdown period everyone can use it wisely.
Join Leanpitch 2 Days CSM Certification Workshop in different cities.
certified scrum master certification cost
Good. I am really impressed with your writing talents and also with the layout on your weblog. Appreciate, Is this a paid subject matter or did you customize it yourself? Either way keep up the nice quality writing, it is rare to peer a nice weblog like this one nowadays. Thank you, check also virtual edge and speaker thank you notes
ReplyDelete
ReplyDeleteThanks for sharing this informative content.,
Turient is an All-in-one platform for all our teaching needs. If Teaching is your passion ,enabling is ours
Read the Informative blog - 11 Free Teaching Tools for Online Teachers
11 Free Teaching Tools for Online Teachers
Free Teaching Tools
ReplyDeleteThanks for sharing this informative content.,
Leanpitch provides online training in Agile team facilitation during this lockdown period everyone can use it wisely.
ICP ATF
Agile facilitator
Thanks for sharing this informative content.,
ReplyDeleteLeanpitch provides online training in Agile team facilitation during this lockdown period everyone can use it wisely.
Agile facilitator
Team facilitator in Agile
Outsourcing Training institute In Dhaka Said,
ReplyDeleteThanks for sharing this informative content , Great work.
Excellent effort to make this blog more wonderful and attractive.
ReplyDeleteBusiness Analytics Course in Bangalore
ReplyDeleteI read your excellent blog post. It's a great job. I enjoyed reading your post for the first time, thank you.
Data Science Institutes in Bangalore
I think I have never seen such blogs ever before that has complete things with all details which I want. So kindly update this ever for us.
ReplyDeletefull stack developer course
Thank you for update us! your blog contained all the relevant information. London Clothing
ReplyDeleteThank you for sharing this information with us! I really appreciate your efforts. Software testing training Delhi
ReplyDeleteWow thanks for the great article. To learn more, visit:- React Native institute in bangalore
ReplyDeleteThis is an excellent demonstration of how powerful {ggmap} can be for visualizing crime data! The way you've mapped out crime hotspots across England and Wales makes it easy to see patterns and areas of concern, which can be incredibly valuable for policymakers and researchers. I especially appreciate how you've broken down the process step-by-step, making it accessible for anyone new to spatial analysis in R.
ReplyDeleteDigital Marketing Course In Hyderabad
Fantastic work on visualizing crime hotspots in England and Wales with {ggmap}! Your approach to mapping this data not only makes it more accessible but also highlights the critical areas that require attention. I appreciate how you’ve integrated different data layers to provide a comprehensive view of the crime landscape. It would be interesting to explore how these visualizations can inform local policy decisions or community initiatives. Thanks for sharing your insights and techniques—this is a valuable resource for both data analysts and policymakers!
ReplyDeleteDigital Marketing Course In Hyderabad