Skip to content

Tool for planning and optimizing virtual stations in demand-responsive transport systems by defining and minimizing a global energy.

License

Notifications You must be signed in to change notification settings

munterfi/drtplanr

Repository files navigation

Demand-responsive transport planner

Lifecycle: experimental R build status pkgdown Codecov test coverage

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.

Getting started

Install the development version from GitHub with:

remotes::install_github("munterfi/drtplanr")

Load example data

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.

Run a model

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:

  1. Relocate a virtual station randomly on the road segments.
  2. Calculate the new global energy of the model using the routing graphs.
  3. If the energy is lower than previuos iteration: Keep the new location of the virtual station; otherwise: Reset to the previous location.
m1 <- drt_iterate(m, 100)

Visualize results

Plot the energy optimization curve and the station map of the model:

drt_plot(m)                 # Energy plot showing progress of iterations
drt_map(m)                  # Map with the inital and final station locations

Authors

  • Merlin Unterfinger - munterfi
  • Oliver Hofer (ideas and feedback) - nebucaz

References

  • hereR: R interface to the HERE REST APIs
  • BfS: Population data for Switzerland
  • OSM: Street network data for routing purposes.

Licence

  • This repository is licensed under the GNU General Public License v3.0 - see the LICENSE.md file for details.

About

Tool for planning and optimizing virtual stations in demand-responsive transport systems by defining and minimizing a global energy.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published