Skip to main content

Depot Simulation for eFLIPS

Project description

Tests Code style: black

eflips-depot


Part of the eFLIPS/simBA list of projects.


eFLIPS has been developed within several research projects at the Department of Methods of Product Development and Mechatronics at the Technische Universität Berlin (see https://www.tu.berlin/mpm/forschung/projekte/eflips).

With eFLIPS, electric fleets and depots can be simulated, planned and designed. This repository contains only the planning and design tool for depots.

eflips_overview

The repository contains an example for the simulation and planning of an elecric bus depot, which is based on the dissertation by Dr.-Ing. Enrico Lauth (see https://depositonce.tu-berlin.de/items/f47662f7-c9ae-4fbf-9e9c-bcd307b73aa7).

Installation

  1. Clone this git repository (or download a specific release)

    git clone git@github.com:mpm-tu-berlin/eflips-depot.git
    
  2. Install the packages listed in poetry.lock and pyproject.toml into your Python environment. Notes:

    • The suggested Python version os 3.11.*, it may work with other versions, but this is not tested.
    • Using the poetry package manager is recommended. It can be installed accoring to the instructions listed here.

    macOS

    poetry env use 3.11
    poetry install
    

    Windows

    If you are using Windows, you have to provide the full path to the desired Python executable, e.g.:

    poetry env use C:\Users\user\AppData\Local\Programs\Python\Python311\python.exe
    poetry install
    
  3. To start a simulation, an existing eFLIPS-Model database is requires. Once you have that, you can run the script bin/example.py

Usage

Please refer to the Documentation section of this Readme for information on how to use eFLIPS-Depot.

The API of eFLIPS-Depot can be accessed via eFLIPS.depot.api. A usage example can be found in the script bus_depot/user_example.py.

Testing


NOTE: Be aware that the tests will clear the database specified in the DATABASE_URL environment variable. Make sure that you are not using a database that you want to keep.


Testing is done using the pytest framework with tests located in the testsdirectory. To run the tests, execute the following command in the root directory of the repository:

   export PYTHONPATH=tests:. # To make sure that the tests can find the eflips package
   export DATABASE_URL=postgis://postgres:postgres@localhost:5432/postgres # Or whatever your database URL is
   export DJANGO_SETTINGS_MODULE=tests.api.djangosettings # To make sure that the tests use the correct settings
   pytest

Documentation

Documentation is available on Read the Docs.

To locally create the documentaiton from the docstrings in the code using sphinx-autoapi, you can create the documentation execute the following command in the root directory of the repository:

   cd docs/
   sphinx-build -b html . _build

Development

We utilize the GitHub Flow branching structure. This means that the main branch is always deployable and that all development happens in feature branches. The feature branches are merged into main via pull requests.

We use black for code formatting. You can use pre-commit to ensure the code is formatted correctly before committing. You are also free to use other methods to format the code, but please ensure that the code is formatted correctly before committing.

Please make sure that your poetry.lock and pyproject.toml files are consistent before committing. You can use poetry check to check this. This is also checked by pre-commit.

License

This project is licensed under the AGPLv3 license - see the LICENSE file for details.

Funding Notice

This code was developed as part of the project eBus2030+ funded by the Federal German Ministry for Digital and Transport (BMDV) under grant number 03EMF0402.

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

eflips_depot-4.3.19.tar.gz (205.3 kB view details)

Uploaded Source

Built Distribution

eflips_depot-4.3.19-py3-none-any.whl (217.6 kB view details)

Uploaded Python 3

File details

Details for the file eflips_depot-4.3.19.tar.gz.

File metadata

  • Download URL: eflips_depot-4.3.19.tar.gz
  • Upload date:
  • Size: 205.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for eflips_depot-4.3.19.tar.gz
Algorithm Hash digest
SHA256 5a6e6773c15679308603b78478280fc16dca744f01e49873370e24a14eace786
MD5 cd30761d6ab157a2698dcfb38071e63a
BLAKE2b-256 04bd9862159a5b5225e6bcade536980f03895a664cafa890283df2d8708c4967

See more details on using hashes here.

Provenance

The following attestation bundles were made for eflips_depot-4.3.19.tar.gz:

Publisher: release.yml on mpm-tu-berlin/eflips-depot

Attestations:

File details

Details for the file eflips_depot-4.3.19-py3-none-any.whl.

File metadata

File hashes

Hashes for eflips_depot-4.3.19-py3-none-any.whl
Algorithm Hash digest
SHA256 65be520296ac47727a09003055f1afdc530abebfab1a21c6171e8aeec814bcc4
MD5 773465f263c81c384ff12a30814244b4
BLAKE2b-256 a63fb83e72d57a7446d2c0ad694ffb1130e94849b3cc0725ea9e184ee6051603

See more details on using hashes here.

Provenance

The following attestation bundles were made for eflips_depot-4.3.19-py3-none-any.whl:

Publisher: release.yml on mpm-tu-berlin/eflips-depot

Attestations:

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