MObility Simulation System
Project description
MOSS: MObility Simulation System
A GPU-accelerated Large-scale Open Microscopic Traffic Simulation System
Website: https://moss.fiblab.net
Documentation: https://python-moss.readthedocs.io/en/latest/
API Reference: https://python-moss.readthedocs.io/en/latest/apidocs/index.html
Features
- Efficient: MOSS adopts GPU as the computational engine, which accelerates 100 times compared to existing microscopic traffic simulators, allowing rapid simulation of large-scale urban road networks.
- Realistic: MOSS provides the cutting-edge AIGC method to generate globally available realistic OD matrices for travel demand generation and allows the user to quickly calibrate the simulation parameters to obtain realistic simulation results.
- Open: The simulator, toolchain, and sample programs will be open-sourced on Github for community access, and we hope that more people will join in the development and application of MOSS.
Awesome MOSS
The related repositories of MOSS are as follows:
cityproto: The protobuf-driven data structure definition for all city simulation projects of FIBLAB, URL. The project provides C/C++, Golang, Python, and Javascript/Typescript interfaces to access the data structure. (match python-moss>=1.0.0)mosstool: The toolchain for MOSS, URL. The project is a Python packages that includes map building, traffic demand generation, SUMO format conversion, and some format conversion utilities. It is the key to build the input of MOSS. (match python-moss>=1.0.0)routing: A gRPC-powered routing service with A* shortest path algorithm, URL. The project is the necessary service formosstoolwhen generating traffic demand or just callingpre_routefunctions to compute the routes of people. (match python-moss>=1.0.0)moss-replay: A internal JS/TS package for building web-based UI to visualize the simulation results, URL. (match python-moss>=1.0.0)moss-webui-frontend: A web UI to visualize the PostgreSQL output of the MOSS project, URL. The project is only a frontend built onmoss-replayand provide a simple 2D visualization for debugging. Users can choose the backend URL in the web settings to connect to their backend and databases. (match python-moss>=1.0.0)moss-webui-backend: A web backend to provide HTTP Restful API for the database output of the MOSS project, URL. The project provides Docker images to allow users to deploy the backend easily. (match python-moss>=1.0.0)moss-ui: A simple UI to visualize the AVRO output of the MOSS project by adaptingmoss-replayto the AVRO output, URL. The project is a desktop application using web technologies, but it now faces performance challenges to manage data without a database. (match python-moss>=1.0.0, unstable)- MOSS based transportation optimization benchmark: A benchmark for large-scale transportation optimization benchmark based on MOSS, URL. The project includes simulation performance evaluation, traffic signal control optimization, dynamic lane control optimization, tidal lane control optimization, congestion pricing optimization, and road planning optimization. (match python-moss>=0.3.3,<1.0.0, will be updated)
- sample programs: The sample programs for MOSS, URL. The project includes the showcases of MOSS for traffic signal control optimization. (match python-moss==0.2.0, deprecated)
Installation
Prerequisites
- Linux
- CUDA 11.8
- Python >= 3.9
Install
pip install python-moss
Very Simple Demo
We assume that you have the map input map.pb and the person input person.pb generated by mosstool. The following code is a simple demo to run the simulation.
from moss import Engine, Verbosity
from moss.export import DBRecorder
e = Engine(
"name",
"data/map.pb",
"data/person.pb",
0,
1,
output_dir="output", # AVRO output, local directory
speed_stat_interval=300, # open road status statistics
verbose_level=Verbosity.ALL,
)
recorder = DBRecorder(
e,
"postgres://user:password@url:port/simulation",
"map_db.map_coll", # map collection used for webui-backend
"name",
) # used for PostgreSQL output
for _ in range(3600):
e.next_step(1)
recorder.record()
# YOU CAN DO SOMETHING HERE
# persons = e.fetch_persons()
# ...
# save the simulation results to the database
recorder.flush()
Development
If you are interested in the development of MOSS, you can follow the instructions below.
Prequsites
- Linux
- CUDA 11.8 or higher
- CMake >= 3.18
- Python >= 3.9
- Network that can access the GitHub repository
Compile and Build
- Install Boost
wget -O boost_1_86_0.tar.gz https://archives.boost.io/release/1.86.0/source/boost_1_86_0.tar.gz
tar -zxvf boost_1_86_0.tar.gz
cd boost_1_86_0
./bootstrap.sh --with-libraries=filesystem,iostreams,program_options,regex,system --prefix=/usr/local # avro dependency
./b2 cxxflags=-fPIC install
cd ..
rm -r boost_1_86_0
rm boost_1_86_0.tar.gz
- Build MOSS
mkdir build
cd build
cmake ..
make -j
- Test MOSS: You can use the compiled MOSS executable to run the simulation to skip the python package installation.
./build/bin/moss -h
Usage: Moss [--help] [--version] --name VAR --config VAR [--gpu VAR] [--quiet]
Optional arguments:
-h, --help shows help message and exits
-v, --version prints version information and exits
-n, --name name of the simulation [required]
-c, --config path to config file [required]
--gpu GPU device ID [nargs=0..1] [default: 0]
-q, --quiet
The config file is a YAML file that contains the simulation parameters. You can refer to the ConfigFile in the repository. The meanings of the parameters can be found in the python package Engine's docstring in engine.py.
- Install Python Package
pip install . -v
- You can submit a pull request to the repository to contribute to the project.
Version History
v1.1
- We apply a CUDA memory arena to do dynamic memory allocation in the GPU memory, which make the project been seen as a right CUDA project.
- Based on the memory arena, we implement the checkpoint mechanism to save the simulation state to CPU memory and restore it from CPU memory.
- More efficient database recorder with incompatible APIs.
- Some bug fixes, performance improvements and more Python API.
From v0.4 to v1.0
That is what we change and why we change it.
- Focus on the microscopic traffic simulation only (vehicle and pedestrian), no crowd in AOI, no bus for more clear code to support community contribution.
- No overlap in junction to avoid deadlock following CBLab's design.
- Can output files with widely-used data format for visualization (visualization is the first for the user to understand the simulation). We choose AVRO as the output format.
- AOI is just as a marker of the starting/ending point of vehicles/pedestrians, no other functions for more clear code.
- clear code structure and documentation written in English.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distributions
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 python_moss-1.4.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.
File metadata
- Download URL: python_moss-1.4.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 25.2 MB
- Tags: CPython 3.12, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e55e36f2483515b7844cef66409f8f454f1f21876c3fa13883a038954262b143
|
|
| MD5 |
3cc6ce1e9c1cdd44a92cc5e892bedb1d
|
|
| BLAKE2b-256 |
00a96c9995a5a5764372cb97d4f620c13cbfb8558ff633c4da04f6294cf40736
|
Provenance
The following attestation bundles were made for python_moss-1.4.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl:
Publisher:
python-publish.yml on tsinghua-fib-lab/moss
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
python_moss-1.4.0-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.whl -
Subject digest:
e55e36f2483515b7844cef66409f8f454f1f21876c3fa13883a038954262b143 - Sigstore transparency entry: 204785646
- Sigstore integration time:
-
Permalink:
tsinghua-fib-lab/moss@7443fd129c1c629dadee9f007aab5ce8be11b1a1 -
Branch / Tag:
refs/tags/v1.4.0 - Owner: https://github.com/tsinghua-fib-lab
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@7443fd129c1c629dadee9f007aab5ce8be11b1a1 -
Trigger Event:
push
-
Statement type:
File details
Details for the file python_moss-1.4.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.
File metadata
- Download URL: python_moss-1.4.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 25.2 MB
- Tags: CPython 3.11, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cbdcdbcc2000d56dc1d2c1782c2e3c3a8950e8daf4cfe5fb283d92f18b6ab98f
|
|
| MD5 |
2c97e55d6df2d0c5a445935b1826c158
|
|
| BLAKE2b-256 |
e6d860a0519f872f57a53e0be4e4ee12431a42098a7e135b7c620fb5a4bfc6e4
|
Provenance
The following attestation bundles were made for python_moss-1.4.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl:
Publisher:
python-publish.yml on tsinghua-fib-lab/moss
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
python_moss-1.4.0-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.whl -
Subject digest:
cbdcdbcc2000d56dc1d2c1782c2e3c3a8950e8daf4cfe5fb283d92f18b6ab98f - Sigstore transparency entry: 204785647
- Sigstore integration time:
-
Permalink:
tsinghua-fib-lab/moss@7443fd129c1c629dadee9f007aab5ce8be11b1a1 -
Branch / Tag:
refs/tags/v1.4.0 - Owner: https://github.com/tsinghua-fib-lab
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@7443fd129c1c629dadee9f007aab5ce8be11b1a1 -
Trigger Event:
push
-
Statement type:
File details
Details for the file python_moss-1.4.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.
File metadata
- Download URL: python_moss-1.4.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 25.2 MB
- Tags: CPython 3.10, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d5784d39b0a5020c7f04256cd13d47f8622a3c6ea8e22fd998106ec1f449bc39
|
|
| MD5 |
58d3fbb24f0d2484da4dd2b9b4b93092
|
|
| BLAKE2b-256 |
1f98b772470a0da7d9d692ea12887397f908d59d4fcc814cef0d1918d4347e14
|
Provenance
The following attestation bundles were made for python_moss-1.4.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl:
Publisher:
python-publish.yml on tsinghua-fib-lab/moss
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
python_moss-1.4.0-cp310-cp310-manylinux2014_x86_64.manylinux_2_17_x86_64.whl -
Subject digest:
d5784d39b0a5020c7f04256cd13d47f8622a3c6ea8e22fd998106ec1f449bc39 - Sigstore transparency entry: 204785643
- Sigstore integration time:
-
Permalink:
tsinghua-fib-lab/moss@7443fd129c1c629dadee9f007aab5ce8be11b1a1 -
Branch / Tag:
refs/tags/v1.4.0 - Owner: https://github.com/tsinghua-fib-lab
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@7443fd129c1c629dadee9f007aab5ce8be11b1a1 -
Trigger Event:
push
-
Statement type:
File details
Details for the file python_moss-1.4.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.
File metadata
- Download URL: python_moss-1.4.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 25.2 MB
- Tags: CPython 3.9, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fc53c4774df9979ef096b9cfdf196de335d4acb419a3c0fd31c4c3934c1dba80
|
|
| MD5 |
e632792b32f2dc92c955c8bd9c8f649d
|
|
| BLAKE2b-256 |
4796f1c72412a47929d2e9d68b714d8ac653a7fbab6b5752da228c3617b2f7b4
|
Provenance
The following attestation bundles were made for python_moss-1.4.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl:
Publisher:
python-publish.yml on tsinghua-fib-lab/moss
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
python_moss-1.4.0-cp39-cp39-manylinux2014_x86_64.manylinux_2_17_x86_64.whl -
Subject digest:
fc53c4774df9979ef096b9cfdf196de335d4acb419a3c0fd31c4c3934c1dba80 - Sigstore transparency entry: 204785648
- Sigstore integration time:
-
Permalink:
tsinghua-fib-lab/moss@7443fd129c1c629dadee9f007aab5ce8be11b1a1 -
Branch / Tag:
refs/tags/v1.4.0 - Owner: https://github.com/tsinghua-fib-lab
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@7443fd129c1c629dadee9f007aab5ce8be11b1a1 -
Trigger Event:
push
-
Statement type: