Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Project: public transit #372

Open
dabreegster opened this issue Oct 21, 2020 · 17 comments
Open

Project: public transit #372

dabreegster opened this issue Oct 21, 2020 · 17 comments
Labels
good first issue Good for newcomers

Comments

@dabreegster
Copy link
Collaborator

A/B Street has some modelling for public transit vehicles and riders, but it's quite incomplete. I'm not going to have any time to work on it soon, but I think it'd make a very fun project to jump in. I'm quite willing to mentor / help things along!

Some end goals could be:

  • previewing how a proposed/future rapid transit route will help its riders
  • exploring+proposing small changes to speed up an existing route
  • drawing entirely new bus routes somewhere

Some of the tasks, in no particular order:

  • importing data: snapping a bus route from OSM or GTFS to the map, handling map boundaries
  • importing data: figuring out when to spawn a bus at the beginning of the route from GTFS schedules
  • importing data: testing in many different cities, some of which have slightly different OSM tagging schemas for public transit
  • modelling / simulation: Figuring out how to model train stations. How long should it take somebody to walk from the road into/out of the station? How much indoor detail from OSM should be used? How to visualize everything?
  • UI: prevent map edits from breaking an existing bus route
  • UI: add a new UI to create/modify bus routes and stops
  • modeling / simulation: pathfinding / transit assignment. Who should try to take a bus? What transfers?
  • dataviz: how to judge how effective a transit route is? How to score efforts to speed up a route?
  • modeling / simulation: implement transit-signal priority, where traffic lights will change when a bus approaches
@JavedNissar
Copy link
Contributor

I'm confused. There are already buses aren't there? How are the current bus routes set up?

@dabreegster
Copy link
Collaborator Author

dabreegster commented Oct 23, 2020

A while ago, I started revamping how bus routes are interpreted, so that the vehicles don't make loops, but appear at the first stop ad vanish at the last: #190. I got distracted and dropped that effort, and in the current in-between state, most routes aren't imported properly.

The importing is done mostly in https://github.com/dabreegster/abstreet/blob/master/convert_osm/src/transit.rs and https://github.com/dabreegster/abstreet/blob/master/map_model/src/make/transit.rs. I can go into more detail if anyone's interested in picking this up. Some of the work described in this issue is half-started, but none of it is to the point of being usable yet.

@matkoniecz
Copy link
Contributor

Figuring out how to model train stations. How long should it take somebody to walk from the road into/out of the station?

What about:

Step 1: implement support highway=footway highway=steps highway=path a-b-street/osm2streets#81
Step 2: for train station create highway=footway connection between its location and nearest sidewalk/road/footway/combined footway/cycleway (maybe skip underground ones)
Step 3: run simulation as usual with pedestrians walking on footways

https://www.openstreetmap.org/query?lat=50.06501&lon=19.91663#map=18/50.08273/19.89345 https://www.openstreetmap.org/#map=19/50.08366/19.85961 https://www.openstreetmap.org/#map=19/50.08179/19.85769 look like a viable test cases

@dabreegster
Copy link
Collaborator Author

Good point -- previously I was trying to associate the bus/train position and pedestrian platform position with the old sidewalk model, which ignores separate footpaths. This might be much easier to do after a-b-street/osm2streets#81 is solved and the test case areas have consistent footway tags.

@dabreegster
Copy link
Collaborator Author

https://link.springer.com/chapter/10.1007/978-3-642-38527-8_6 could be nice for routing

@dabreegster
Copy link
Collaborator Author

https://factorio.com/blog/post/fff-364
The "train overview GUI" section has some really awesome ideas to peek in on all stations / buses of a single route, to get a quick sense of how stuck they are.

@dabreegster
Copy link
Collaborator Author

For when this work gets picked up, see some ideas/rationale in #500

@dabreegster
Copy link
Collaborator Author

https://osmus.slack.com/archives/C029HV951/p1619824463140400
https://wiki.openstreetmap.org/wiki/Proposed_features/Simpler_public_transport_route_relations
Someone brought up the "should the route relations in OSM contain all of the ways to show the route" question. Relevant because the current half-broken impl of route importing tries to use these, and has an awfully hard time just putting the ways in order.

@PayasR
Copy link

PayasR commented Aug 5, 2021

https://epubs.siam.org/doi/pdf/10.1137/1.9781611975499.5
The springer paper is old in the comment above, this is more-or-less state of the art

@dabreegster
Copy link
Collaborator Author

https://www.transit.land/routes/r-c23nb-48#export
TransitLand has some fantastic UIs for browsing routes and also for seeing an isochrone around stops, matched up with census data!

dabreegster added a commit that referenced this issue Aug 30, 2021
… grabs some schedule times from GTFS. #372

Not regenerating yet
@dabreegster
Copy link
Collaborator Author

Just found https://wiki.openstreetmap.org/wiki/Metro_Mapping by way of https://alexey-zakharenkov.github.io/subways/rapid/; great explanations of OSM's model there

dabreegster added a commit that referenced this issue Nov 18, 2021


This code stopped working around July 2020 when I attempted to tackle #190. It's sat dormant since then, with most bus and light rail routes not imported correctly at all. I'm going to (eventually) start another attempt at public transit in A/B Street by treating GTFS as the main source of truth, not trying to understand route relations mapped in OSM. It's simplest to just rip out all this old code first. Some of it may be useful later, but version control preserves it.

Regenerating everything; this is a binary format change.
dabreegster added a commit that referenced this issue Nov 18, 2021


This code stopped working around July 2020 when I attempted to tackle #190. It's sat dormant since then, with most bus and light rail routes not imported correctly at all. I'm going to (eventually) start another attempt at public transit in A/B Street by treating GTFS as the main source of truth, not trying to understand route relations mapped in OSM. It's simplest to just rip out all this old code first. Some of it may be useful later, but version control preserves it.

Regenerating everything; this is a binary format change.
dabreegster added a commit that referenced this issue Nov 18, 2021
 (#808)

This code stopped working around July 2020 when I attempted to tackle #190. It's sat dormant since then, with most bus and light rail routes not imported correctly at all. I'm going to (eventually) start another attempt at public transit in A/B Street by treating GTFS as the main source of truth, not trying to understand route relations mapped in OSM. It's simplest to just rip out all this old code first. Some of it may be useful later, but version control preserves it.

Regenerating everything; this is a binary format change.
dabreegster added a commit that referenced this issue Nov 19, 2021
Not uploading the downloaded files yet, on a weird connection.
@dabreegster
Copy link
Collaborator Author

I think this effort is slowly getting revived, so below is a bit of a project plan. My time is limited, but I'll aim to get the first part done myself in the next ~week, and then handover to a few people who've expressed interest in working on this.

Current code status

Currently:

  • nothing to import transit routes and stops
  • the map model has a representation for routes and stops, but it's probably dated. Terrible modeling of schedules.
  • the simulation layer can spawn buses that follow the route
  • pedestrians boarding and deboarding mostly works?
  • almost no UI

Importing routes

I'll try to crank this out in the next week to unblock the real work. The first attempt used OSM route relations, but there were lots of complications (described in other PRs and issues). I think just focusing on GTFS is a safer start.

The final desired model for stops and routes:

  • a transit stop associates a position on a walkable lane where the pedestrian waits and a position where the bus or train stops to pick them up
  • a transit route is a sequence of stops. The route starts and ends either at a transit stop or a border intersection. Since we clip map boundaries, usually routes won't fully be contained in a map. If the full GTFS route starts or ends outside the map, we'll snap the route's start/end position to a border intersection. If the full route starts/ends inside the map, the bus will magically appear or disappear at the first/last transit stop.
  • the route's schedule should follow what's in GTFS pretty directly. I haven't read and understood the schema yet.

Transit routes can get crazy: #190 (comment)
I don't think we should try to understand routes that loop or change route numbers in the middle yet. We'll try to more directly follow whatever's in GTFS. If we were aiming for lots of realism, we need to model what happens to a bus in between serving routes. Does it chill at a stopover for a while, then start the route in the opposite direction? Does it go to a bus depot? Figuring out how many physical buses and drivers are needed to fulfill some agency's schedule is not something we should tackle yet. These things could be interesting later to help a transit agency understand costs, but let's start small.

So my plan to import from GTFS is this:

  1. Download the GTFS files during import (done)
  2. Fill out some routes in RawMap. Each route has metadata (name, GTFS IDs to debug things), a shape (just a polyline that we'll initially clip to the map boundary), a list of stops, and a schedule
  3. In the RawMap->Map stage, we'll create the stops, just using distance-based snapping to get driving and sidewalk positions. We'll use A/B Street's pathfinding to make sure there's a driveable route between the sequence of stops, and toss out routes (with errors) that don't import reasonably. The polyline shape will tell us where the bus should enter and exit the map, if the first/last stop are outside the boundary.

Actually maybe we don't need to hold onto the full polyline in RawMap. We could take that full shape and try to snap the entire path to roads. We'd have to check that it's a valid driveable path anyway. Should the map model store the exact path that a bus takes, or always just calculate it as needed? People will edit the map and possibly adjust roads to change the pathfinding costs and make a bus want to take a slightly different route between stops. If we want to give people the ability to force a bus to follow a route they specify that doesn't match what pathfinding says, then we should store the exact path in the model and initially snap using the full shape. But... I don't think that's the right thing to start with.

Next steps coming...

@dabreegster
Copy link
Collaborator Author

These're steps intended for other people to do (with my help of course!). No order / priority necessarily.

Schedules

I'll just get the route shape and stops imported and ignore the schedule. Next step, somebody can figure out the right map model representation and import from GTFS.

Pathfinding for transit users

/// Attempt the pathfinding and see if we should ride a bus. If so, says (stop1, optional stop
currently ignores transit schedules entirely and doesn't model transfers. @PayasR will likely be creating a RAPTOR crate to help with this. Once it exists, we can integrate with A/B Street.

Simulation layer transfers

Once pathfinding can tell us a route with transfers (maybe walking in between or maybe waiting at the same platform for a different bus), make the simulation layer use this. https://a-b-street.github.io/docs/tech/trafficsim/trips.html describes how stuff works now.

Modeling transit stations

For the importing work I'll do, I'm going to just snap vehicle and sidewalk positions to the map in the naive distance-based way. In reality, we often have train stations / platforms that're underground, spread over multiple connected buildings, have multiple entrances/exits, etc. OSM has lots of this stuff tagged. How should we represent this in A/B Street? How much detail do we want? At the very least, representing that it takes at least 3 minutes to go from the street entrance to the platform seems important. Do we want to try to render station interiors? Maybe just a simplified view that shows the progress each passenger is in the station between street entrance and platform?

Editing

This is where it gets interesting! Once we can model public transit from real data reasonably, then we can let people change things. I'd think of this as a few stages:

  1. What changes can somebody make to roads and intersections to affect an existing bus route? Adding bus lanes or transit signal priority at traffic signals, mainly?

  2. Let people modify an existing route's schedule to be more/less frequent at different times of the day. Probably then it's time to think more about operating costs and how many physical buses/drivers are needed to fulfill a schedule.

  3. Let people modify a bus's route. Create, delete, move, re-order bus stops. Maybe force the bus to take a certain route between stops that's different than what the bus pathfinding engine says.

  4. Let people create entirely new routes. Bus and train routes probably work pretty differently here. Creating new light rail could maybe be conceptually pretty simple, since it doesn't really touch the existing road model much. But we could try to represent underground, elevated, and at-grade stuff. Maybe look at buildings the lines would cross under and reason about tunneling or eminent domain costs.

Measuring

What metrics are interesting to study for how successful transit is? How can we make nice dataviz UIs? If we want to gamify some piece of the public transit work, how do we assign a score for improving a route?

dabreegster added a commit that referenced this issue Dec 4, 2021
(Mostly renaming map_model code everywhere, not yet sim layer and above)
dabreegster added a commit that referenced this issue Dec 7, 2021
(Mostly renaming map_model code everywhere, not yet sim layer and above)
dabreegster added a commit that referenced this issue Dec 7, 2021
(Mostly renaming map_model code everywhere, not yet sim layer and above)
dabreegster added a commit that referenced this issue Feb 17, 2022
Back in #819, I broke things by creating the sidewalk+transit graph
before transit routes had been set up. This causes immediate crashing
when editing the 2 maps with transit (Arboretum and SF).
dabreegster added a commit that referenced this issue Feb 17, 2022
Transit stop IDs previously were tied to LaneIDs, but those can easily
change with edits to the number of lanes on a road. We still may need to
re-snap transit stops (if the driving position or sidewalk changes), but
this prevents one more common type of problem.

This requires regenerating everything, since it's a binary schema
change...
@dabreegster
Copy link
Collaborator Author

For reference: @ThomasDagier has found https://bl.ocks.org/kaezarrex/7a100491d541031b6c24, a super useful tool to debug GTFS shapes.txt. Note it seems quite slow for large input, like San Francisco's shapes.txt

@dabreegster
Copy link
Collaborator Author

https://www.youtube.com/watch?v=cKXoj6_LY2s a commercial tool in this space, UI examples

dabreegster added a commit that referenced this issue Apr 17, 2022
to get this test to pass. #372

Now regenerate the maps with PT
dabreegster added a commit that referenced this issue Apr 17, 2022
…ease]

The UX of bus info panels is terrible, but just unbreak this.
dabreegster added a commit that referenced this issue Apr 18, 2022
@dabreegster
Copy link
Collaborator Author

If anyone's interested, I've started walking + GTFS routing over in a-b-street/15m#4, an experimental rewrite of the 15-min neighbourhood tool. Plenty of project ideas, both frontend/design and backend.
image

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
good first issue Good for newcomers
Projects
None yet
Development

No branches or pull requests

4 participants