Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/py-b/osmbus
Export OpenStreetMap Bus Lines to GPX
https://github.com/py-b/osmbus
bus gpx openstreetmap osm r rstats rstats-package
Last synced: about 12 hours ago
JSON representation
Export OpenStreetMap Bus Lines to GPX
- Host: GitHub
- URL: https://github.com/py-b/osmbus
- Owner: py-b
- Created: 2018-08-15T09:50:18.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2020-11-16T09:10:14.000Z (about 4 years ago)
- Last Synced: 2024-11-21T05:05:50.390Z (2 months ago)
- Topics: bus, gpx, openstreetmap, osm, r, rstats, rstats-package
- Language: R
- Homepage:
- Size: 166 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.Rmd
Awesome Lists containing this project
README
---
output: github_document
---[![R build status](https://github.com/py-b/osmbus/workflows/R-CMD-check/badge.svg)](https://github.com/py-b/osmbus/actions)
[![CRAN status](https://www.r-pkg.org/badges/version/osmbus)](https://cran.r-project.org/package=osmbus)
# osmbus**osmbus** is an R package which exports [OpenStreetMap](https://www.openstreetmap.org)
(OSM) public transport lines to GPX files.It works with OSM _relations_ containing the following tags :
* `type` = `route`
* `route` = `aerialway|bus|ferry|monorail|subway|train|tram|trolleybus`You can install the package from GitHub with :
``` r
# install.packages("remotes")
remotes::install_github("py-b/osmbus")
```### Just give me my GPX file
The only mandatory argument is the OSM identifier of the transport line. For
instance, to export [this bus line](https://www.openstreetmap.org/relation/3220296)
(in Nancy, France) :```r
write_gpx(id_rel = "3220296")
```The data coming from the OSM server must be clean for the export to work.
As stated in the OSM documentation, the ways in the relation should be listed
beginning with the way at the initial stop position and ending with the way at
the terminal stop, in the right order. The package will automatically reverse
some ways to produce a continuous track.If roundabouts (or any circular ways) are part of the track, **osmbus** will
find its way through them, i.e. it will select the only nodes used by the
transport vehicle from entrance to exit.##### Content of the output file
- transport line metadata : some retrieved from OSM (for example the
version of the relation) and some calculated by the package (for example the
length in kilometers) ;
- coordinates and names of the stops (`role=stop` in the relation), as `wpt(s)`
elements ;
- list of the track points in the correct order, as a `trkseg` element.It will be structured like this :
```xml
#20B14A
Seichamps Haie Cerlin
Tempo 3 : Seichamps Haie Cerlin → Villers Campus Sciences
Stan
Transdev
Tempo 3
bus
Villers Campus Sciences
route
46
946
17.383
Seichamps Haie Cerlin
Seichamps Église
Villers Campus Sciences
```
Attributes of OSM objects (`osm_node` and `version`) can be ommited in the file
by setting `osm_info = FALSE`.##### Example of use
With the gpx file, you are a few steps away from creating a map like
[this](http://u.osmfr.org/m/218270)._(this map was not made with R but with an interactive tool called
[uMap](http://umap.openstreetmap.fr))_### Get the underlying data into R
It is also possible to get the intermediate data that was used to generate the
gpx file (this can be useful to do something else than exporting to GPX).``` r
extract_data(id_rel = "3220296")
#> $bounds
#> minlat minlon maxlat maxlon
#> 48.663444 6.142478 48.719615 6.269548
#>
#> $rel_tags
#> colour
#> "#20B14A"
#> from
#> "Seichamps Haie Cerlin"
#> name
#> "Tempo 3 : Seichamps Haie Cerlin → Villers Campus Sciences"
#> network
#> "Stan"
#> operator
#> "Transdev"
#> ref
#> "Tempo 3"
#> route
#> "bus"
#> to
#> "Villers Campus Sciences"
#> type
#> "route"
#>
#> $rel_attr
#> id version timestamp
#> "3220296" "79" "2020-11-08T17:23:43Z"
#> changeset uid user
#> "93750625" "1075986" "py_berrard"
#>
#> $stop_count
#> [1] 46
#>
#> $trkpt_count
#> [1] 946
#>
#> $trk_km
#> [1] 17.383
#>
#> $stop_base
#> # A tibble: 46 x 5
#> id name lat lon version
#>
#> 1 3163674258 Seichamps Haie Cerlin 48.7 6.27 1
#> 2 3163519911 Seichamps Église 48.7 6.27 1
#> 3 966281833 Donon 48.7 6.27 2
#> 4 3163208966 Jardin Roussel 48.7 6.27 1
#> 5 3140811791 Semoir 48.7 6.26 1
#> 6 963538950 Collège Goncourt 48.7 6.26 2
#> 7 3065252842 Blés d'Or 48.7 6.26 2
#> 8 962186695 Charles de Gaulle 48.7 6.25 3
#> 9 3414202098 Renaissance 48.7 6.25 2
#> 10 3138716806 Porte Verte 48.7 6.24 2
#> # ... with 36 more rows
#>
#> $trkpt_base
#> # A tibble: 946 x 5
#> id lat lon version d_last
#>
#> 1 3163674258 48.7 6.27 1 0
#> 2 3163674481 48.7 6.27 2 4.16
#> 3 3070509280 48.7 6.27 3 3.74
#> 4 3163674482 48.7 6.27 2 6.68
#> 5 3070509345 48.7 6.27 3 4.95
#> 6 65074447 48.7 6.27 3 12.7
#> 7 3163674477 48.7 6.27 2 23.3
#> 8 3163674476 48.7 6.27 1 2.94
#> 9 4720935403 48.7 6.26 1 88.5
#> 10 4720935406 48.7 6.26 1 5.41
#> # ... with 936 more rows
```_(`d_last` in the `trkpt_base` data.frame gives the distance to the previous
point, in meters)_> If you wish to both export to a file and keep the data, you can affect the
> result of `write_gpx()` to an objet :
> ```r
> bus_data <- write_gpx(id_rel = "3220296")
> ```### Overpass API
The data is retrieved from OpenStreetMap using the
[overpass API](https://wiki.openstreetmap.org/wiki/Overpass_API).You can choose which instance of the API is used via the `overpass_url` argument
of the functions. By default, the main instance `"http://overpass-api.de/api/interpreter"`
is used. See the link above for a list of available instances.Note that this read-only API can be a few minutes behind the editing API.