Skip to main content

The sumo-experiments library implements a python interface for the Simulation of Urban MObility (SUMO) software.

Project description

Contributors Forks Stargazers Issues Status Version MIT License LinkedIn


Logo

sumo-experiments

The sumo-experiments library implements a python interface for the Simulation of Urban MObility (SUMO) software.

Examples · Report Bug · Request Feature

Table of Contents
  1. About The Project
  2. Getting Started
  3. Usage
  4. Contributing
  5. License
  6. Contact
  7. Acknowledgments

About The Project

SUMO simulation


The sumo-experiments package aims to provide an ergonomic environment for creating and configuring highly reproducible SUMO simulations.

Creating a SUMO network for a simulation is very time-consuming. Infrastructure and flows have to be defined either using the netedit tool, or by manually creating all the numerous XML configuration files. This complexity also makes it difficult to reproduce experiments taken from scientific papers. The sumo-experiments package aims to solve this problem by deploying a set of tools to define SUMO networks, automatically generate configuration files and launch simulations, directly from Python.

For further information, please refer to the jupyter notebooks in the examples folder, which will guide you through the use of the package.

Getting Started

Prerequisites

This package only work with Debian distributions. Also, you must install SUMO. Please refer to the SUMO installation manual.

Installation

  1. Get the package from the Python Package Index.

    pip install sumo-experiments
    
  2. Check that the $SUMO_HOME environment variable is set. This command must return the value of $SUMO_HOME.

    printenv | grep 'SUMO_HOME'
    

    If the variable is not set, you can add it temporarily with the following command.

    export SUMO_HOME=your_path_to_sumo
    

    To set this variable permanently, write this in the .bashrc file.

Usage

This script is one of the more simple uses of the package. We first instanciate a preset network from preset_networks. This network contains only one intersection, making the junction between two two-way roads, with one lane for each way. Secondly, we instanciate an Experiment with three parameters : - The name of the experiment - A function that defines the infrastructures of the network (nodes, edges, connections, etc) from the preset network - A function that defines the flows of the simulation (vehicle types, density, etc) from the preset network Finally, we run the simulation with the SUMO GUI. We recommand you to use the clean files method to delete all configuration and data files.

from sumo_experiments import Experiment
from sumo_experiments.preset_networks import OneCrossroadNetwork

network = OneCrossroadNetwork()
exp = Experiment('Test', network.generate_infrastructures, network.generate_flows_all_directions)
exp.run(gui=True)
exp.clean_files()

For more examples, please refer to the examples folder

Contributing

Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.

If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement". Don't forget to give the project a star! Thanks again!

  1. Fork the Project
  2. Create your Feature Branch (git checkout -b feature/AmazingFeature)
  3. Commit your Changes (git commit -m 'Add some AmazingFeature')
  4. Push to the Branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

License

Distributed under the LGPL-2.1 License. See LICENSE.txt for more information.

Contact

Jules Bompard - Linkedin - jules.bompard.etu@univ-lille.fr

Project Link: https://github.com/cristal-smac/sumo-experiments

Acknowledgments

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

sumo_experiments-3.2.0.tar.gz (73.7 MB view details)

Uploaded Source

Built Distribution

sumo_experiments-3.2.0-py3-none-any.whl (76.5 kB view details)

Uploaded Python 3

File details

Details for the file sumo_experiments-3.2.0.tar.gz.

File metadata

  • Download URL: sumo_experiments-3.2.0.tar.gz
  • Upload date:
  • Size: 73.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.10.12

File hashes

Hashes for sumo_experiments-3.2.0.tar.gz
Algorithm Hash digest
SHA256 28f3148024bbc642ee3c90093e52d4f33ced2cc512a28877edf79d85ffdc9d30
MD5 4934f3605c2ee5b4928824402b1080ef
BLAKE2b-256 88eb80bf9e359afc5d134ee22f179ab87563370ef60b5eaee0f2f0245ed3bf1c

See more details on using hashes here.

File details

Details for the file sumo_experiments-3.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for sumo_experiments-3.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 911146e25f65f300200681470679e906c485f3af89fbd4d1060c6ebd4628f838
MD5 9ea46543a7371f67e3f4ff0b492bafaa
BLAKE2b-256 1d7e2ccef9d63bb0c7cb9ab65b51ee14175a6b610966ea9004ff9fed6d8edfd5

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page