A high-performance map matching tool for GMNS networks
Project description
MapMatcher4GMNS
A high-performance map matching tool for GPS trajectories on GMNS (General Modeling Network Specification) networks.
Features
- High-Performance Map Matching: Efficient Hidden Markov Model (HMM) based map matching algorithm
- GMNS Network Support: Native support for GMNS network format (node.csv, link.csv)
- Multi-Core Processing: Built-in parallel processing support for large-scale GPS data
- Flexible Configuration: Comprehensive parameters for fine-tuning matching quality
- Route Generation: Automatic generation of complete routes between matched points
Installation
From PyPI (when published)
pip install mapmatcher4gmns
Quick Start
import mapmatcher4gmns as m4g
import pandas as pd
def main():
# Load network from GMNS format
net = m4g.loadNetFromCSV(
folder='path/to/network',
node_file='node.csv',
link_file='link.csv'
)
# Load GPS data
gps_df = pd.read_csv('gps_data.csv')
# Create matcher
matcher = m4g.mapmatching(
network=net,
time_field='timestamp',
time_format='%Y-%m-%dT%H:%M:%S.%fZ',
out_dir='output',
result_file='matched_result.csv',
route_file='matched_route.csv',
)
# Perform map matching
matcher.match(gps_df)
if __name__ == '__main__':
main()
Input Data Requirements
Network Files (GMNS Format)
node.csv (required fields):
node_id: Unique node identifierx_coord: Longitude (if coordinate_type='lonlat') or X coordinatey_coord: Latitude (if coordinate_type='lonlat') or Y coordinate
link.csv (required fields):
link_id: Unique link identifierfrom_node_id: Starting node IDto_node_id: Ending node IDlanes: Number of lanesgeometry: LineString geometry in WKT format
GPS Data
Required fields:
journey_id(or custom agent_field): Unique identifier for each GPS trajectorylongitude: GPS longitudelatitude: GPS latitude
Optional but recommended:
time(or custom time_field): Timestamp for temporal orderingspeed: Speedheading: Heading direction in degrees
Configuration Parameters
Core Matching Parameters
search_radius(default: 12.0): Search radius in meters for candidate linksnoise_sigma(default: 30.0): GPS noise standard deviation in meterstrans_weight(default: 6.0): Weight for transition probabilitymax_candidates(default: 10): Maximum number of candidate links per GPS point
Movement Consistency
turn_sigma(default: 45.0): Turn angle standard deviation in degreesheading_sigma(default: 30.0): Heading difference standard deviationuse_heading(default: True): Whether to use heading information
Filtering
filter_dwell(default: True): Filter out stationary pointsdwell_dist(default: 5.0): Distance threshold for dwell detection in metersdwell_count(default: 2): Minimum consecutive points to be considered dwellingmax_gap_seconds(default: 45.0): Maximum time gap allowed between consecutive points
Performance
core_num: Number of CPU cores to use (default: auto-detect)batch_size: Batch size for parallel processing (default: 1)max_agents(default: None): Maximum number of trajectories to process (useful for testing/debugging). If set, only the first N trajectories will be matched
Output
The tool generates two main output files:
1. Matched Results (matched_result.csv)
Contains the matched GPS points with:
journey_id: Trajectory identifierseq: Sequence numbertime: Timestamplink_id: Matched link IDfrom_node_id,to_node_id: Link endpointslongitude,latitude: Original GPS coordinatesspeed_mph: Speed (if provided)match_heading: Heading of matched linkroute_dis: Culmulative route distance
2. Route File (matched_route.csv)
Contains the complete route for each journey:
journey_id: Trajectory identifierlink_ids: Comma-separated list of link IDs forming the complete route
Advanced Usage
Note: When using multiprocessing features, wrap your code in if __name__ == '__main__': to avoid issues, especially on Windows.
Multi-Core Processing
matcher = m4g.mapmatching(
network=net,
core_num=4, # Use 4 CPU cores
batch_size=10, # Process 10 journeys per batch
# ... other parameters
)
Custom Field Names
matcher = m4g.mapmatching(
network=net,
agent_field='vehicle_id', # Custom trajectory ID field
lng_field='lon', # Custom longitude field
lat_field='lat', # Custom latitude field
time_field='timestamp', # Custom time field
# ... other parameters
)
Extra Fields
Keep additional fields from input GPS data in the output:
matcher = m4g.mapmatching(
network=net,
extra_fields=['vehicle_type', 'driver_id', 'trip_purpose'],
# ... other parameters
)
Requirements
- Python >= 3.8
- numpy >= 1.20.0
- pandas >= 1.3.0
- shapely >= 2.0.0
- geopandas >= 0.10.0
- networkx >= 2.6.0
- tqdm >= 4.60.0
Citation
If you use this tool in your research, please cite:
[Add your citation here]
License
This project is licensed under the MIT License - see the LICENSE file for details.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Acknowledgments
This package was inspired by and references the excellent work of the TrackIt (GoTrackIt) project. We are grateful for their contributions to the open-source map matching community and their innovative approach to HMM-based map matching algorithms.
References
- TrackIt/GoTrackIt: A comprehensive map matching Python package based on Hidden Markov Model (HMM)
- GitHub: https://github.com/zdsjjtTLG/TrackIt
- Documentation: https://gotrackit.readthedocs.io/
- Developed by: TangKai and contributors at Hangzhou Zecheng Data Technology Co., Ltd.
This tool is designed to work with the General Modeling Network Specification (GMNS) format, supporting transportation network analysis and GPS trajectory processing.
Support
For questions, issues, or feature requests, please contact us.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mapmatcher4gmns-0.1.2.tar.gz.
File metadata
- Download URL: mapmatcher4gmns-0.1.2.tar.gz
- Upload date:
- Size: 39.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2f5b1c6cf65c0557090478ca51b1fa6123e42317066e967297b66e14d87d60fa
|
|
| MD5 |
0418ba5bb67e150d90ea44fcbd342c51
|
|
| BLAKE2b-256 |
39965e3b759cca9b793c1faa92466f7397efc56ec757fcd3b960f1713cc06b39
|
File details
Details for the file mapmatcher4gmns-0.1.2-py3-none-any.whl.
File metadata
- Download URL: mapmatcher4gmns-0.1.2-py3-none-any.whl
- Upload date:
- Size: 38.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
38fd0b40aecf20ff04f78beb69f0d4bed0b1aab79b04f5a9c76daeb0b74e6b5c
|
|
| MD5 |
9f3c1881555c07e1ec5a8b272150b87d
|
|
| BLAKE2b-256 |
092db514986d89d263a849299b26d3cbf0bba2b3ba4bf6dda3d455bdd309d839
|