Create routable NetworkX graph with realistic transfer times from GTFS feeds. 🚌 🚆 🚡
- Cleaning & preprocessing
- Remove trips with unrealistic travel times and speeds
- Fix trips contradictory stop sequences and departure times
- Enable routability
- Ensure each node belongs only to single route
- Calculate average segment travel times
- Calculate average stop headway and service frequency
- Add edges for walking transfer between routes with realistic transfer time (walking time + headway / 2)
pip install gtfs2nx
import gtfs2nx as gx
G = gx.transit_graph('path/to/GTFS-feed.zip')
Customize transit network:
G = gx.transit_graph(
gtfs_paths='path/to/GTFS-feed.zip',
time_window=('06:00', '08:00'),
route_types=[700], # only buses
walk_transfer_max_distance=400, # allow transfers with long walking distance
)
See API docs for more details.
# access precomputed stop characteristics
frequency = nx.get_node_attributes(G, 'frequency')
# routing
route = nx.shortest_path(G, from_stop, to_stop, weight='weight')
# travel time to other stops
travel_times = nx.single_source_dijkstra_path_length(G, source=from_stop, weight='weight')
# centrality analysis
centrality = nx.closeness_centrality(G, distance='weight')
Build from source:
poetry build
pip install dist/gtfs2nx-*.whl --force-reinstall --no-deps