evrich is a cloud service available within the microservice-based grid automation platform SOGNO, designed to address the question of "where to charge" in distribution grids with multiple charging locations. It provides an application programming interface (API) that allows EV drivers to input their charging preferences, including search space, target state-of-charge, and parking period. In response, evrich identifies available charging spots in the specified area, gathers offers from charging station operators, and directs the EV driver to the optimal option based on the current situation. The current optimization approach in evrich focuses on minimizing charging costs for drivers [1]. However, its modular architecture allows for the integration of alternative strategies.
To effectively simulate interactions between the evrich service and external systems, a dynamic infrastructure has been developed. This setup automates request dispatch to the service based on predefined scenarios and logs the corresponding responses. Within this framework, the availability and charging commitments of charging stations in the test scenarios are modeled using datafev objects. datafev is a Python library specifically designed for developing and testing management algorithms for electric vehicles [2].
To enhance the flexibility of the test framework for incorporating numerous charging locations, the generation of Docker Compose files has been automated. The newly developed tool, docker-compose-prepper, streamlines this process. This automation is crucial for configuring both internal dependencies (containers within the SOGNO platform) and external dependencies (datafev objects representing charging stations). As a result, the test environment becomes more dynamic and scalable, efficiently accommodating a wide range of scenarios.
- Clone repository via SSH (
git clone [email protected]:acs/public/automation/evrich.git
) or clone repository via HTTPS (git clone https://git.rwth-aachen.de/acs/public/automation/evrich.git
) - Open an issue at https://git.rwth-aachen.de/acs/public/automation/evrich/issues
- Checkout the development branch:
git checkout development
- Update your local development branch (if necessary):
git pull origin development
- Create your feature/issue branch:
git checkout -b issueXY_explanation
- Commit your changes:
git commit -m "Add feature #XY"
- Push to the branch:
git push origin issueXY_explanation
- Submit a pull request from issueXY_explanation to development branch via https://git.rwth-aachen.de/acs/public/automation/evrich/pulls
- Wait for approval or revision of the new implementations.
Docker Desktop installation is essential to use evrich, which can be downloaded from: https://www.docker.com/products/docker-desktop/
Docker-compose-prepper requires at least the following Python packages:
- pandas >= 2.0.3
- pyyaml >= 6.0.1
- openpyxl >= 3.1.2
- User may start with reshaping input files under
PATH-TO-DIRECTORY/external/event_manager/data_handling/input.xlsx
,PATH-TO-DIRECTORY/external/utils/input.xlsx
andPATH-TO-DIRECTORY/sogno/utils/input.xlsx
with the desired scenario data. These input files should be exactly identical. - Docker-compose-prepper scripts located at
PATH-TO-DIRECTORY/external/utils/prep_docker_compose.py
andPATH-TO-DIRECTORY/sogno/utils/prep_docker_compose.py
should both be run. - In Windows PowerShell
docker-compose build
should be executed under both external(PATH-TO-DIRECTORY/evrich/external
) and SOGNO(PATH-TO-DIRECTORY/evrich/sogno
) directories. - Only for the first time, again in Windows PowerShell,
docker-compose up
should be first executed under external(PATH-TO-DIRECTORY/evrich/external
) and then under SOGNO(PATH-TO-DIRECTORY/evrich/sogno
) directory. This is due to the need to identify external networks to the SOGNO. - The building of the cloud-testing infrastructure of evrich service has been completed. The user should first execute
docker-compose up
command under SOGNO(PATH-TO-DIRECTORY/evrich/sogno
) and afterwards under external(PATH-TO-DIRECTORY/evrich/external
) directory in Windows PowerShell. - The output data will be saved under
PATH-TO-DIRECTORY/datafev/outputs
- Gümrükçü, E., Klemets, J. R. A., Suul, J. A., Ponci, F., & Monti, A. (2022). Decentralized energy management concept for urban charging hubs with multiple V2G aggregators. IEEE Transactions on Transportation Electrification. IEEE.
- Gumrukcu, E., Ahmadifar, A., Yavuzer, A., Ponci, F., & Monti, A. (2023). datafev—A Python framework for development and testing of management algorithms for electric vehicle charging infrastructures. Software Impacts, 15, 100467. Elsevier.
- Aytug Yavuzer, M.Sc. [email protected]
- Florian Oppermann, M.Sc. [email protected]
- Erdem Gumrukcu, M.Sc. [email protected]
- Univ.-Prof. Antonello Monti, Ph.D. [email protected]
Institute for Automation of Complex Power Systems (ACS) E.ON Energy Research Center (E.ON ERC) RWTH Aachen University, Germany