This vignettes demonstrates possibilities when zoning systems from different cities meet. It raises the question: how should different systems be combined geographically?
You need the latest version of the package:
remotes::install_github("zonebuilders/zonebuilder")
For this demo, we need the following libraries:
library(zonebuilder) # for the zoning system
library(sf) # for processing spatial data
library(dplyr) # for processing general data
library(tmap) # for visualizing spatial data
We will apply the zoning system to the main Dutch cities, and analyse commuting patterns between the zones. The data can be read as follows:
NLD_cities = readRDS(url("https://github.com/zonebuilders/zonebuilder/releases/download/0.0.1/NLD_cities.Rds"))
NLD_wijk_od = readRDS(url("https://github.com/zonebuilders/zonebuilder/releases/download/0.0.1/NLD_wijk_od.Rds"))
NLD_wijk_centroids = readRDS(url("https://github.com/zonebuilders/zonebuilder/releases/download/0.0.1/NLD_wijk_centroids.Rds"))
Let’s take a look at the NLD_cities
data:
…and plot it on an interactive map:
The following code chunk generated zones for the Dutch cities:
zbs = do.call(rbind, lapply(1:nrow(NLD_cities), function(i) {
ci = NLD_cities[i, ]
# Amsterdam 5, Eindhoven-Rotterdam 4, Roermond-Zeeland 2, others 3
nrings = ifelse(ci$population < 60000, 2,
ifelse(ci$population < 220000, 3,
ifelse(ci$population < 800000, 4, 5)))
zb = zb_zone(x = ci, n_circles = nrings) %>%
mutate(name = ci$name,
labelplus = paste(ci$name, label, sep = "_"))
zb
}))
tm_basemap("OpenStreetMap") +
tm_shape(zbs) +
tm_polygons(col = "circle_id", id = "labelplus", style = "cat", palette = "YlOrBr", alpha = 0.7) +
tm_scale_bar()