vector based energy and material flow optimization framework in python
flixOpt is in early state! Not completely documented yet,... Do not hesitate to contact authors!
Collaboration is welcome!
flixOpt is an vector based optimization framework creating and solving mixed-integer programming problems (MILP). It is created with focus on energy flows but can be used for material flows as well.
flixOpt was developed in project SMARTBIOGRID by TU Dresden. This project was funded by the German Federal Ministry for Economic Affairs and Energy (FKZ: 03KB159B).
flixOpt development is based on Matlab framework flixOptMat developed in project FAKS by TU Dresden and has a few influences from oemof/solph (Great thanks for your tool!)
Install this package via pip in to your environment: pip install git+https://github.com/flixOpt/flixOpt.git
- various constraints available
- operation optimization optionally combined with investment optimization
- segmented linear correlations for
- flows
- invest costs and invest size
- effects
- various effects, e.g. costs, CO2 emissions, primary energy, area demand etc.
- effects coupleable, e.g. specific costs of CO2-emissions
- constraints, e.g. max sum of CO2 emissions
- simply switch effect, which should be minimized (optimization target)
- others
- non-equidistant timesteps possible
- investment and flow-on/off variables in one model
You can choose between three calculation modes:
- full -> exact and slow
- segmented (with variable time overlap) -> fast but not exact for big storages, not usable for investment decision problems
- aggregated (automatically creation of typical periods via TSAM) -> fast, quite exact
- interlayer flixBase for modeling and good overview of (vectorized) variables and equations
- postprocessing unit
- allows integration of other modeling languages than Pyomo
- By installing flixOpt with pip the open source solver HiGHS will be part of the package. Alternatively, various solvers are usable. Further easy-to-use open source solvers are CBC and GLPK. Executables can be found for example here for CBC and here for GLPK (Windows: You have to put solver-executables to the PATH-variable) It is also possible to use the commercial solvers Gurobi or CPLEX. Regarding licensing details please check the corresponding web-pages.
For citing use DOI:10.18086/eurosun.2022.04.07, to get a short overview DOI:10.13140/RG.2.2.14948.24969.
- Testing: Using
python -m unittest discover -s tests
in the command line will run all tests