##1) Overview This library contains code for performing analysis of vehicle GPS data on urban road networks. Specifically, it contains traffic estimation algorithms, graph partitioning and preprocessing algorithms, efficient routing algorithms including Bidirectional Dijkstra's, Bidirectional A* and Bidirectional ArcFlags, integration with PostgreSQL database systems, and a framework for performing large-scale parallel analyses using mpi4py. The library is designed to work with maps loaded from OpenStreetMap via AwesomeStitch. This document serves as a quick-start for those wishing to use any of the included code. The purpose is to describe the purpose and usage of various modules and files within this library.
##2)License
This software is licensed under the University of Illinois/NCSA Open Source License:
Copyright (c) 2013 The Board of Trustees of the University of Illinois. All rights reserved
Developed by: Department of Civil and Environmental Engineering University of Illinois at Urbana-Champaign
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal with the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimers. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimers in the documentation and/or other materials provided with the distribution. Neither the names of the Department of Civil and Environmental Engineering, the University of Illinois at Urbana-Champaign, nor the names of its contributors may be used to endorse or promote products derived from this Software without specific prior written permission.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE CONTRIBUTORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS WITH THE SOFTWARE.
##3) Modules / Folders
Includes all of the code relating to loading, representing, and processing road network graphs, and performing shortest-path routing queries on them. Specifically, it can:
- Load/save road networks from/to CSV files, using the same format as AwesomeStitch
- Efficiently match coordinates to the nearest node in the graph using a KD-Tree
- Partition road networks using a KD-Tree
- Partition road networks using the KaHip library. KaHip needs to be downloaded and compiled before these particular functions work.
- Generate figures that show the color-coded partitioning results
- Identify strongly-connected components using kosajaru's algorithm, and prune the graph down to one large strongly-connected component
- Efficiently erform shortest-path routing queries using Bidirectional Dijkstra's algorithm, Bidirectional A*, and Bidirectional ArcFlags
- Perform the preprocessing steps which are necessary for ArcFlags
All code relating to estimating traffic conditions from taxi GPS data. Specifically, it is designed to estimate the travel times on links of the road network, even when the data only contains origins, destinations, and total travel times. In other words, no intermediate way-points or paths are required - they are estimated simultaneously with the traffic conditions. Specifically, this module can:
- Estimate the traffic conditions from GPS data
- Perform cross-validation experiments to quantify the prediction accuracy
- Produce graphics which show the estimated traffic conditions
This module allows the code connect to a PostgreSQL database for saving/loading data and results. Specifically, it can:
- Load taxi trips (which contain GPS coordinates, times, etc.) from the database
- Load and save traffic estimates (i.e. travel times on each link) into the database. Travel times are indexed by the date/time that they occured, since they generally change over time
- Load and save ArcFlags, which are produced in the /routing module. These are also indexed by the date/time, since the ArcFlags depend on the traffic conditions, which change over time.
This module is built on top of mpi4py. It contains a convenient framework for performing large-scale parallel tasks on supercomputers. The basic idea is similar to the map portion of a map-reduce operation - it applies the same function to a large set of inputs at the same time. The usage is similar to Python's built-in map or **multiprocessing.Pool.map()*. However, it is specialized to quickly disseminate data that is used by all of the workers. The reason behind this is that many of the applications of parallel processing in this library use the same road network in each instance.
Not a module - contains a sample map of New York City, which can be used with the remainder of the code. The data format is explained below:
node.csv:
- node_id - a unique identifier for each node
- is_complete
- num_in_links - the number of incoming links to this node
- num_out_links - the number f outgoing links from this node
- osm_traffic_controller
- xcoord - the longitude of this node
- ycoord - the latitude of this node
- osm_changeset - the changeset ID from OSM
- birth_timestamp - the time this node was loaded by AwesomeStitch
- death_timestamp - the time this node was deleted in AwesomeStitch
- region_id
links.csv:
- link_id
- begin_node_id
- end_node_id
- begin_angle
- end_angle
- street_length
- osm_name
- osm_class
- osm_way_id
- startX
- startY
- endX
- endY
- osm_changeset
- birth_timestamp
- death_timestamp
##4) Files