Skip to main content

Framework for integrated energy systems assessment

Project description

ETHOS.FINE - Framework for Integrated Energy System Assessment

Build Status Version Conda Version Documentation Status PyPI - License codecov

Forschungszentrum Juelich Logo

The ETHOS.FINE python package provides a framework for modeling, optimizing and assessing energy systems. With the provided framework, systems with multiple regions, commodities and time steps can be modeled. Target of the optimization is the minimization of the total annual cost while considering technical and environmental constraints. Besides using the full temporal resolution, an interconnected typical period storage formulation can be applied, that reduces the complexity and computational time of the model.

This Readme provides information on the installation of the package. For further information have a look at the documentation.

ETHOS.FINE is used for the modelling of a diverse group of optimization problems within the Energy Transformation PatHway Optimization Suite (ETHOS) at IEK-3.

If you want to use ETHOS.FINE in a published work, please kindly cite following publication which gives a description of the first stages of the framework. The python package which provides the time series aggregation module and its corresponding literature can be found here.

Installation from conda-forge

If you would like to run ETHOS.FINE for your analysis we recommend to install it directly from conda-forge into a new Python environment with

mamba create --name fine --channel conda-forge fine

Note on Mamba vs.Conda: mamba commands can be substitued with conda. We highly recommend using (Micro-)Mamba instead of Conda. The recommended way to use Mamba on your system is to install the Miniforge distribution. They offer installers for Windows, Linux and OS X. In principle, Conda and Mamba are interchangeable. The commands and concepts are the same. The distributions differ in the methodology for determining dependencies when installing Python packages. Mamba relies on a more modern methodology, which (with the same result) leads to very significant time savings during the installation of ETHOS.FINE. Switching to Mamba usually does not lead to any problems, as it is virtually identical to Conda in terms of operation.

Note on the solver: The mamba/conda installation comes with GLPK (installation for Windows) as Mixed Integer Linear Programming (MILP) solver. If you want to solve large problems it is highly recommended to install GUROBI. See "Installation of an optimization solver" for more information.

Installation from pipy

The functionality of ETHOS.FINE depends on the following C libraries that need to be installed on your system. If you do not know how to install those, consider installing from conda-forge.

Create a virtual environment in the ETHOS.FINE folder and activate it

python -m venv .venv
source .venv/bin/activate

Install ETHOS.FINE with

python -m pip install fine

Installation of an optimization solver

ETHOS.FINE requires an MILP solver which can be accessed using PYOMO. It searches for the following solvers in this order:

GUROBI

This solver is recommended due to better performance but requires license (free academic version available). It is set as the default solver.

The installation requires the following three components:

  • Gurobi Optimizer
    • In order to download the software you need to create an account and obtain a license.
  • Gurobi license
    • The license needs to be installed according to the instructions in the registration process.
  • Gurobi python api

GLPK

This solver is installed with the ETHOS.FINE environment. A complete installation instruction for Windows can be found here.

CBC

Installation procedure can be found here.

Examples

A number of examples shows the capabilities of ETHOS.FINE.

  • 00_Tutorial
    • In this application, an energy supply system, consisting of two regions, is modeled and optimized. Recommended as starting point to get to know to ETHOS.FINE.
  • 01_1node_Energy_System_Workflow
    • In this application, a single region energy system is modeled and optimized. The system includes only a few technologies.
  • 02_EnergyLand
    • In this application, a single region energy system is modeled and optimized. Compared to the previous examples, this example includes a lot more technologies considered in the system.
  • 03_Multi-regional_Energy_System_Workflow
    • In this application, an energy supply system, consisting of eight regions, is modeled and optimized. The example shows how to model multi-regional energy systems. The example also includes a notebook to get to know the optional performance summary. The summary shows how the optimization performed.
  • 04_Model_Run_from_Excel
    • ETHOS.FINE can also be run by excel. This example shows how to read and run a model using excel files.
  • 05_District_Optimization
    • In this application, a small district is modeled and optimized. This example also includes binary decision variables.
  • 06_Water_Supply_System
    • The application cases of ETHOS.FINE are not limited. This application shows how to model the water supply system.
  • 07_NetCDF_to_save_and_set_up_model_instance
    • This example shows how to save the input and optimized results of an energy system Model instance to netCDF files to allow reproducibility.
  • 08_Spatial_and_technology_aggregation
    • These two examples show how to reduce the model complexity. Model regions can be aggregated to reduce the number of regions (spatial aggregation). Input parameters are automatically adapted. Furthermore, technologies can be aggregated to reduce complexity, e.g. reducing the number of different PV components (technology aggregation). Input parameters are automatically adapted.
  • 09_Stochastic_Optimization
    • In this application, a stochastic optimization is performed. It is possible to perform the optimization of an energy system model with different input parameter sets to receive a more robust solution.
  • 10_PerfectForesight
    • In this application, a transformation pathway of an energy system is modeled and optimized showing how to handle several investment periods with time-dependent assumptions for costs and operation.
  • 11_Partload
    • In this application, a hydrogen system is modeled and optimized considering partload behavior of the electrolyzer.

Notes for developers

Editable install from conda-forge

It is recommended to create a clean environment with conda to use ETHOS.FINE because it requires many dependencies.

mamba env create --name fine --file requirements_dev.yml
mamba activate fine

Install ETHOS.FINE as editable install and without checking the dependencies from pypi with

python -m pip install --no-deps --editable .

Editable install from pypi

If you do not want to use conda-forge consider the steps in section Installation from pipy and install ETHOS.FINE as editable install and with developer dependencies with

python -m pip install --editable .[develop]

License

MIT License

Copyright (C) 2016-2024 FZJ-IEK-3

Active Developers: Theresa Groß, Kevin Knosala, Noah Pflugradt, Johannes Behrens, Julian Belina, Arne Burdack, Toni Busch, Philipp Dunkel, David Franzmann, Patrick Freitag, Thomas Grube, Heidi Heinrichs, Maximilian Hoffmann, Jason Hu, Shitab Ishmam, Sebastian Kebrich, Felix Kullmann, Jochen Linßen, Rachel Maier, Shruthi Patil, Jan Priesmann, Julian Schönau, Maximilian Stargardt, Lovindu Wijesinghe, Christoph Winkler, Detlef Stolten

Alumni: Robin Beer, Henrik Büsing, Dilara Caglayan, Timo Kannengießer, Leander Kotzur, Stefan Kraus, Peter Markewitz, Lars Nolting,Stanley Risch, Martin Robinius, Bismark Singh, Andreas Smolenko, Peter Stenzel, Chloi Syranidou, Johannes Thürauf, Lara Welder, Michael Zier

You should have received a copy of the MIT License along with this program. If not, see https://opensource.org/licenses/MIT

About Us

Institute image IEK-3

We are the Institute of Energy and Climate Research - Techno-economic Systems Analysis (IEK-3) belonging to the Forschungszentrum Jülich. Our interdisciplinary department's research is focusing on energy-related process and systems analyses. Data searches and system simulations are used to determine energy and mass balances, as well as to evaluate performance, emissions and costs of energy systems. The results are used for performing comparative assessment studies between the various systems. Our current priorities include the development of energy strategies, in accordance with the German Federal Government’s greenhouse gas reduction targets, by designing new infrastructures for sustainable and secure energy supply chains and by conducting cost analysis studies for integrating new technologies into future energy market frameworks.

Contributions and Support

Every contributions are welcome:

  • If you have a question, you can start a Discussion. You will get a response as soon as possible.
  • If you want to report a bug, please open an Issue. We will then take care of the issue as soon as possible.
  • If you want to contribute with additional features or code improvements, open a Pull request.

Code of Conduct

Please respect our code of conduct.

Acknowledgement

This work was initially supported by the Helmholtz Association under the Joint Initiative "Energy System 2050 A Contribution of the Research Field Energy".

The authors also gratefully acknowledge financial support by the Federal Ministry for Economic Affairs and Energy of Germany as part of the project METIS (project number 03ET4064, 2018-2022).

This work was supported by the Helmholtz Association under the program "Energy System Design".

Helmholtz Logo

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

fine-2.3.7.tar.gz (206.3 kB view details)

Uploaded Source

Built Distribution

fine-2.3.7-py3-none-any.whl (189.7 kB view details)

Uploaded Python 3

File details

Details for the file fine-2.3.7.tar.gz.

File metadata

  • Download URL: fine-2.3.7.tar.gz
  • Upload date:
  • Size: 206.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for fine-2.3.7.tar.gz
Algorithm Hash digest
SHA256 cb57beafd91814c8d8a854c82bf5af4e4f08c58e4635bd4a1c134f848ee98a19
MD5 45c1d0941aeb35e4febac0466d2f4ac1
BLAKE2b-256 3dfa984d098d4df7cbf65c25bd3bb5257a55c84eb46fff8b567c21be9f0e5d21

See more details on using hashes here.

File details

Details for the file fine-2.3.7-py3-none-any.whl.

File metadata

  • Download URL: fine-2.3.7-py3-none-any.whl
  • Upload date:
  • Size: 189.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for fine-2.3.7-py3-none-any.whl
Algorithm Hash digest
SHA256 3cdf25c5b333b6ab97056936b0beb306ec77de4f19d95e552d1b4120ddc373ba
MD5 8571d0789fbdffcba78df241915d5344
BLAKE2b-256 1cadbbf3204ec47b262738d915ed7f12b54d5874f8dc31035b932a32c5c718b3

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