Tool for placing virtual stations in demand-responsive transport systems in villages by defining and minimizing a global energy (drtplanr
, name is inspired by stplanr). The station locations are randomly initialized in the street network and iteratively optimized based on the reachable population in combination with walking and driving times.
The model in the package example optimizes the positions of virtual stations in an assumed on-demand shuttle service for the community of Jegenstorf in Bern, Switzerland.
Install the development version from GitHub with:
remotes::install_github("munterfinger/drtplanr")
Load the package example data sets of a village in Switzerland:
aoi
: Area of Interest - 3 min driving time isochrone around the station of Jegenstorf, Bern.pop
: Centroids of population and structural business hectare grid statistis, where the variable ‘n’ is the sum of full-time equivalence jobs and residents per hectare (BfS).aoi <- sf::st_read(system.file("example.gpkg", package="drtplanr"), layer = "aoi") pop <- sf::st_read(system.file("example.gpkg", package="drtplanr"), layer = "pop")
To create the datasets for a different region in Switzerland use the create.sh and adjust the geocoded address:
./create.sh -k <YOUR HERE API KEY>
Note: A HERE API key is required and has to be passed as with the option -k
.
Create a new demand reponsive transport model for the aoi ‘Jegenstorf’, with 10 randomly initialized virtual on-demand stations.
m <- drt_drtm( model_name = "Jegenstorf", # Name of the drtm (used when exporting the model) aoi = aoi, # Area of interest (sf with geometry type POLYGON) pop = pop, # Population layer (sf with geometry type POINT) n_vir = 15, # Number of virtual stations to place (numeric) m_seg = 100 # Resolution of the segments on the street network )
Iterate the model 100 times, where every iteration consists of:
m1 <- drt_iterate(m, 100)