FlixOpt Concepts
FlixOpt is built around a set of core concepts that work together to represent and optimize energy and material flow systems. This page provides a high-level overview of these concepts and how they interact.
Core Concepts
FlowSystem
The FlowSystem
is the central organizing unit in FlixOpt.
Every FlixOpt model starts with creating a FlowSystem. It:
- Defines the timesteps for the optimization
- Contains and connects components, buses, and flows
- Manages the effects (objectives and constraints)
Flows
Flow
objects represent the movement of energy or material between a Bus and a Component in a predefined direction.
- Have a
size
which, generally speaking, defines how fast energy or material can be moved. Usually measured in MW, kW, m³/h, etc. - Have a
flow_rate
, which is defines how fast energy or material is transported. Usually measured in MW, kW, m³/h, etc. - Have constraints to limit the flow-rate (min/max, total flow hours, on/off etc.)
- Can have fixed profiles (for demands or renewable generation)
- Can have Effects associated by their use (operation, investment, on/off, ...)
Flow Hours
While the Flow Rate defines the rate in which energy or material is transported, the Flow Hours define the amount of energy or material that is transported. Its defined by the flow_rate times the duration of the timestep in hours.
Examples:
Flow Rate | Timestep | Flow Hours |
---|---|---|
10 (MW) | 1 hour | 10 (MWh) |
10 (MW) | 6 minutes | 0.1 (MWh) |
10 (kg/h) | 1 hour | 10 (kg) |
Buses
Bus
objects represent nodes or connection points in a FlowSystem. They:
- Balance incoming and outgoing flows
- Can represent physical networks like heat, electricity, or gas
- Handle infeasible balances gently by allowing the balance to be closed in return for a big Penalty (optional)
Components
Component
objects usually represent physical entities in your system that interact with Flows
. They include:
LinearConverters
- Converts input flows to output flows with (piecewise) linear relationshipsStorages
- Stores energy or material over timeSources
/Sinks
/SourceAndSinks
- Produce or consume flows. They are usually used to model external demands or supplies.Transmissions
- Moves flows between locations with possible losses- Specialized
LinearConverters
likeBoilers
,HeatPumps
,CHPs
, etc. These simplify the usage of theLinearConverter
class and can also be used as blueprint on how to define custom classes or parameterize existing ones.
Effects
Effect
objects represent impacts or metrics related to your system, such as:
- Costs (investment, operation)
- Emissions (CO₂, NOx, etc.)
- Resource consumption
- Area demand
These can be freely defined and crosslink to each other (CO₂
──[specific CO₂-costs]─→ Costs
).
One effect is designated as the optimization objective (typically Costs), while others can be constrained.
This approach allows for a multi-criteria optimization using both...
- ... the Weigted SumMethod, by Optimizing a theoretical Effect which other Effects crosslink to.
- ... the (\(\epsilon\)-constraint method) by constraining effects.
Calculation
A FlowSystem
can be converted to a Model and optimized by creating a Calculation
from it.
FlixOpt offers different calculation modes:
FullCalculation
- Solves the entire problem at onceSegmentedCalculation
- Solves the problem in segments (with optioinal overlap), improving performance for large problemsAggregatedCalculation
- Uses typical periods to reduce computational requirements
Results
The results of a calculation are stored in a CalculationResults
object.
This object contains the solutions of the optimization as well as all information about the Calculation
and the FlowSystem
it was created from.
The solutions is stored as an xarray.Dataset
, but can be accessed through their assotiated Component, Bus or Effect.
This CalculationResults
object can be saved to file and reloaded from file, allowing you to analyze the results anytime after the solve.
How These Concepts Work Together
The process of working with FlixOpt can be divided into 3 steps:
- Create a
FlowSystem
, containing all the elements and data of your system- Define the time series of your system
- Add
Components
likeBoilers
,HeatPumps
,CHPs
, etc. - Add
Buses
as connection points in your system - Add
Effects
to represent costs, emissions, etc. - This
FlowSystem
can also be loaded from a netCDF file
- Translate the model to a mathematical optimization problem
- Create a
Calculation
from your FlowSystem and choose a Solver - ...The Calculation is translated internaly to a mathematical optimization problem...
- ...and solved by the chosen solver.
- Create a
- Analyze the results
- The results are stored in a
CalculationResults
object - This object can be saved to file and reloaded from file, retaining all information about the calculation
- As it contains the used
FlowSystem
, it can be used to start a new calculation
- The results are stored in a
Advanced Usage
As flixopt is build on linopy, any model created with FlixOpt can be extended or modified using the great linopy API. This allows to adjust your model to very specific requirements without loosing the convenience of FlixOpt.