Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mpjashby/sfhotspot
R package for hotspot mapping
https://github.com/mpjashby/sfhotspot
hotspot hotspots hotspots-analysis mapping mapping-tools
Last synced: about 1 month ago
JSON representation
R package for hotspot mapping
- Host: GitHub
- URL: https://github.com/mpjashby/sfhotspot
- Owner: mpjashby
- License: other
- Created: 2021-12-17T14:31:39.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2023-09-18T16:02:51.000Z (over 1 year ago)
- Last Synced: 2024-01-26T15:54:53.328Z (12 months ago)
- Topics: hotspot, hotspots, hotspots-analysis, mapping, mapping-tools
- Language: R
- Homepage: http://pkgs.lesscrime.info/sfhotspot/
- Size: 3.35 MB
- Stars: 9
- Watchers: 2
- Forks: 1
- Open Issues: 7
-
Metadata Files:
- Readme: README.Rmd
- License: LICENSE
Awesome Lists containing this project
README
---
output: github_document
---```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)
```# sfhotspot
[![CRAN status](https://www.r-pkg.org/badges/version/sfhotspot)](https://CRAN.R-project.org/package=sfhotspot)
[![R-CMD-check](https://github.com/mpjashby/sfhotspot/workflows/R-CMD-check/badge.svg)](https://github.com/mpjashby/sfhotspot/actions)
[![codecov](https://codecov.io/gh/mpjashby/sfhotspot/branch/main/graph/badge.svg?token=KPS526F0V1)](https://app.codecov.io/gh/mpjashby/sfhotspot)
[![Lifecycle: stable](https://img.shields.io/badge/lifecycle-stable-brightgreen.svg)](https://lifecycle.r-lib.org/articles/stages.html#stable)sfhotspot provides functions to identify and understand clusters of points
(typically representing the locations of places or events). All the functions in
the package work on and produce [simple
features](https://r-spatial.github.io/sf/) (SF) objects, which means they can be
used as part of modern spatial analysis in R.## Installation
You can install the development version of sfhotspot from
[GitHub](https://github.com/) with:``` r
# install.packages("remotes")
remotes::install_github("mpjashby/sfhotspot")
```## Functions
sfhotspot has the following functions. All can be used by just supplying an SF
object containing points, or can be configured using the optional arguments to
each function.```{r functions-table, echo=FALSE}
knitr::kable(data.frame(
"name" = c(
"`hotspot_count()`",
"`hotspot_change()`",
"`hotspot_kde()`",
"`hotspot_dual_kde()`",
"`hotspot_gistar()`",
"`hotspot_classify()`"
),
"use" = c(
paste(
"Count the number of points in each cell of a regular grid. Cell size",
"can be set by the user or chosen automatically."
),
paste(
"Measure the change in the count of points in each cell between two",
"periods of time."
),
paste(
"Estimate kernel density for each cell in a regular grid. Cell size and",
"bandwidth can be set by the user or chosen automatically."
),
paste(
"Compare the kernel density of two layers of points, e.g. to estimate",
"the local risk of an event occurring relative to local population."
),
paste(
"Calculate the Getis–Ord $G_i^*$ statistic for each cell in a regular",
"grid, while optionally estimating kernel density. Cell size, bandwidth",
"and neighbour distance can be set by the user or chosen automatically."
),
paste(
"Classify grid cells according to whether they have had significant",
"clusters of points at different time periods. All parameters can be",
"chosen automatically or be set by the user using the",
"`hotspot_classify_params()` helper function."
)
)
))
```The results produced by `hotspot_count()`, `hotspot_change()`, `hotspot_kde()`,
`hotspot_dual_kde()` and `hotspot_classify()` can be easily plotted using
included methods for`autoplot()` and `autolayer()`.There are also included datasets:
* `memphis_robberies`, containing records of
`r format(nrow(sfhotspot::memphis_robberies), big.mark = ",")` robberies in
Memphis, TN, in 2019.
* `memphis_robberies_jan`, containing the same data but only for the
`r format(nrow(sfhotspot::memphis_robberies_jan), big.mark = ",")` robberies
recorded in January 2019.
* `memphis_population`, containing population counts for the centroids of
`r format(nrow(sfhotspot::memphis_population), big.mark = ",")` census
blocks in Memphis, TN, in 2020.## Example
We can use the `hotspot_gistar()` function to identify cells in a regular grid
in which there are more/fewer points than would be expected if the points were
distributed randomly. In this example, the points represent the locations of
personal robberies in Memphis, which is a dataset included with the package.```{r example}
# Load packages
library(sf)
library(sfhotspot)
library(tidyverse)# Transform data to UTM zone 15N so that we can think in metres, not decimal
# degrees
memphis_robberies_utm <- st_transform(memphis_robberies, 32615)# Identify hotspots, set all the parameters automatically by not specifying cell
# size, bandwidth, etc.
memphis_robberies_hotspots <- hotspot_gistar(memphis_robberies_utm)# Visualise the hotspots by showing only those cells that have significantly
# more points than expected by chance. For those cells, show the estimated
# density of robberies.
memphis_robberies_hotspots %>%
filter(gistar > 0, pvalue < 0.05) %>%
ggplot(aes(colour = kde, fill = kde)) +
geom_sf() +
scale_colour_distiller(aesthetics = c("colour", "fill"), direction = 1) +
labs(title = "Density of robberies in Memphis, 2019") +
theme_void()
```