Skip to main content

DSF C++ core with Python bindings via pybind11

Project description

DynamicalSystemFramework

Latest Release PyPI version DOI

Standard TBB SPDLOG CSV JSON SQLite codecov

The aim of this project is to rework the original Traffic Flow Dynamics Model. This rework consists of a full code rewriting, in order to implement more features (like intersections) and get advantage from the latest C++ updates.

Table of Contents

Installation

The library is available on PyPI:

pip install dsf-mobility

To check the installation you can simply run

import dsf

print(dsf.__version__)

Installation (from source)

Requirements

The project requires C++20 or greater, cmake, tbb simdjson, spdlog, csv-parser and SQLiteCpp. To install requirements on Ubuntu:

sudo apt install cmake libtbb-dev

To install requirements on macOS:

brew install cmake tbb

Utilities are written in python. To install their dependencies:

pip install -r ./requirements.txt

Installation (C++)

The library can be installed using CMake. To build and install the project in the default folder run:

cmake -B build -DCMAKE_BUILD_TYPE=Release && cmake --build build -j$(nproc)
sudo cmake --install build

Otherwise, it is possible to customize the installation path:

cmake -B build -DCMAKE_INSTALL_PREFIX=/path/to/install

then building and installing it (eventually in sudo mode) with:

cmake --build build
cmake --install build

Installation (Python)

If you want to use the library from Python, you can build the Python bindings using pybind11. Make sure you have Doxygen installed to generate the docstrings:

sudo apt install doxygen libtbb-dev

Then, the installation is automatic via uv:

uv build

or you can just use the classic pip:

pip install .

After installation, you should be able to import the module in Python:

import dsf

print(dsf.__version__)

If you encounter issues, ensure that the installation path is in your PYTHONPATH environment variable.

Testing

This project uses Doctest for testing.

If the project is compiled in Debug or Coverage mode, tests are always built. Otherwise, you can add the -DDSF_TESTS=ON flag to enable test build.

cmake -B build -DDSF_TESTS=ON
cmake --build build -j$(nproc)

To run the tests use the command:

ctest --test-dir build -j$(nproc) --output-on-failure

Benchmarking

Some functionalities of the library have been benchmarked in order to assess their efficiency.
The benchmarks are performed using Google Benchmarks. To build the benchmarks add the flag -DDSF_BENCHMARKS=ON :

cmake -B build -DDSF_BENCHMARKS=ON
cmake --build build -j$(nproc)

To run all the benchmarks together use the command:

cd benchmark
for f in ./*.out ; do ./$f ; done

Citing

@software{berselli_2026_18745492,
  author       = {Berselli, Gregorio},
  title        = {DynamicalSystemFramework},
  month        = mar,
  year         = 2026,
  publisher    = {Zenodo},
  doi          = {10.5281/zenodo.18745492},
  url          = {https://doi.org/10.5281/zenodo.18745492},
}

Bibliography

  • Mungai, Veronica (2024) Studio dell'ottimizzazione di una rete semaforica. University of Bologna, Bachelor's Degree in Physics [L-DM270]. Link to Thesis.
  • Berselli, Gregorio (2024) Advanced queuing traffic model for accurate congestion forecasting and management. University of Bologna, Master's Degree in Physics [LM-DM270]. Link to Thesis.
  • Berselli, Gregorio (2022) Modelli di traffico per la formazione della congestione su una rete stradale. University of Bologna, Bachelor's Degree in Physics [L-DM270]. Link to Thesis.

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

dsf_mobility-5.3.3.tar.gz (141.0 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

dsf_mobility-5.3.3-cp312-cp312-win_amd64.whl (1.5 MB view details)

Uploaded CPython 3.12Windows x86-64

dsf_mobility-5.3.3-cp312-cp312-manylinux_2_39_x86_64.whl (1.7 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.39+ x86-64

dsf_mobility-5.3.3-cp312-cp312-macosx_15_0_arm64.whl (1.5 MB view details)

Uploaded CPython 3.12macOS 15.0+ ARM64

dsf_mobility-5.3.3-cp310-cp310-win_amd64.whl (1.5 MB view details)

Uploaded CPython 3.10Windows x86-64

dsf_mobility-5.3.3-cp310-cp310-manylinux_2_39_x86_64.whl (1.7 MB view details)

Uploaded CPython 3.10manylinux: glibc 2.39+ x86-64

dsf_mobility-5.3.3-cp310-cp310-macosx_15_0_arm64.whl (1.5 MB view details)

Uploaded CPython 3.10macOS 15.0+ ARM64

File details

Details for the file dsf_mobility-5.3.3.tar.gz.

File metadata

  • Download URL: dsf_mobility-5.3.3.tar.gz
  • Upload date:
  • Size: 141.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for dsf_mobility-5.3.3.tar.gz
Algorithm Hash digest
SHA256 3c8c0a9f592e75fa0a05b0cff428d9b9285f81083e07b67721fc169e4d0b7731
MD5 005346a01e8d0f375f23effce06e9156
BLAKE2b-256 7620b010ee425460e19e792d67af2b9fcb39f4ed4a9bc11ea9dbdbac371e6640

See more details on using hashes here.

File details

Details for the file dsf_mobility-5.3.3-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for dsf_mobility-5.3.3-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 414104c24cf4012c85b64440a34d322621df0adaa2106eb8a4d2d666a3793940
MD5 a8c2c6f5dac4e6a841a8a30e3527f485
BLAKE2b-256 8374cce0824875507b5f10e0fed66320733ded1d9972167cc451dc1c74998069

See more details on using hashes here.

File details

Details for the file dsf_mobility-5.3.3-cp312-cp312-manylinux_2_39_x86_64.whl.

File metadata

File hashes

Hashes for dsf_mobility-5.3.3-cp312-cp312-manylinux_2_39_x86_64.whl
Algorithm Hash digest
SHA256 27ff88c93b55a0f09478de80f86995ba91523afca69a95cc67b22c321ef1057d
MD5 093f31fc793a3c5bf76396ce29178372
BLAKE2b-256 b164b25596326993f8d5ce6ec54291b2ea8b4fc80558ad1394a74bd6d89c2295

See more details on using hashes here.

File details

Details for the file dsf_mobility-5.3.3-cp312-cp312-macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for dsf_mobility-5.3.3-cp312-cp312-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 8092ebb087cb9f8ee64497f5cca27085262d0a565c6f06c6d6f62e3a043c7728
MD5 7bc75853d7c1a23aa26e5dc81fc37b9c
BLAKE2b-256 cdbdfc22fe1b3b6e78c00985cfd1255477003bd9d23d50937d707d6abbaf9107

See more details on using hashes here.

File details

Details for the file dsf_mobility-5.3.3-cp310-cp310-win_amd64.whl.

File metadata

File hashes

Hashes for dsf_mobility-5.3.3-cp310-cp310-win_amd64.whl
Algorithm Hash digest
SHA256 01bbb1efa917de934bb42561e253adfda9014aebb5414d09fa3594bf245508ca
MD5 61cd127bc17da6566ddf329a332afcb6
BLAKE2b-256 5da06f2529e84b6e3d66c769b3ca43ec8ec05b652b4471ee2d62f66b66791fca

See more details on using hashes here.

File details

Details for the file dsf_mobility-5.3.3-cp310-cp310-manylinux_2_39_x86_64.whl.

File metadata

File hashes

Hashes for dsf_mobility-5.3.3-cp310-cp310-manylinux_2_39_x86_64.whl
Algorithm Hash digest
SHA256 998b596cf035d1032f9354a6ccde2a59398231e878feb7fef572bb10d8e53680
MD5 798766ce1a071e4e52337f5762083ef5
BLAKE2b-256 88c2cf6c738f35949acb47b1cc50c14a51a2f72432f76411e27f9c6790f05b08

See more details on using hashes here.

File details

Details for the file dsf_mobility-5.3.3-cp310-cp310-macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for dsf_mobility-5.3.3-cp310-cp310-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 7b56cae52860befd5e0a9e8ac03396dd265d1b32a50e5f9abb7ad370d244da62
MD5 0945192365e14b318ea23f0638d11778
BLAKE2b-256 5b0d202063660ff16af26a069498dbbe5850fca0286d5622101bb5053efe279c

See more details on using hashes here.

Supported by

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