HiSim is a Python package for simulation and analysis of household scenarios and building systems using modern components as alternative to fossil fuel based ones. This package integrates load profiles generation of electricity consumption, heating demand, electricity generation, and strategies of smart strategies of modern components, such as heat pump, battery, electric vehicle or thermal energy storage. HiSim is a package under development by Forschungszentrum Jülich und Hochschule Emden/Leer. For detailed documentation, please access ReadTheDocs of this repository.
If you want to use the feature that generates system charts, you need to install GraphViz in your system. If you don't have Graphviz installed, you will experience error messages about a missing dot.exe under Windows.
Follow the installation instructions from here: https://www.graphviz.org/download/
(or simply disable the system charts)
To clone this repository, enter the following command to your terminal:
git clone https://github.com/FZJ-IEK3-VSA/HiSim.git
Before installing hisim
, it is recommended to set up a Python virtual environment. Let hisimvenv
be the name of
virtual environment to be created. For Windows users, setting the virtual environment in the path \hisim
is done with
the command line:
python -m venv hisimvenv
After its creation, the virtual environment can be activated in the same directory:
hisimvenv\Scripts\activate
For Linux/Mac users, the virtual environment is set up and activated as follows:
virtual hisimvenv source hisimvenv/bin/activate
Alternatively, Anaconda can be used to set up and activate the virtual environment:
conda create -n hisimvenv python=3.9
conda activate hisimvenv
With the successful activation, hisim
is ready to be locally installed.
After setting up the virtual environment, install the package to your local libraries:
pip install -e .
Run the python interpreter in the hisim/examples
directory with the following command:
python ../hisim/hisim_main.py simple_examples.py first_example
This command executes hisim_main.py
on the setup function first_example
implemented in the file examples.py
that
is stored in hisim/examples
. The same file contains another setup function that can be used: second_example
. The
results can be visualized under directory results
created under the same directory where the script with the setup
function is located.
The directory hisim\examples
also contains a basic household configuration in the script basic_household.py
. The
first setup function (basic_household_explicit
) can be executed with the following command:
python ../hisim/hisim_main.py basic_household.py basic_household_explicit
The system is set up with the following elements:
- Occupancy (Residents' Demands)
- Weather
- Photovoltaic System
- Building
- Heat Pump
Hence, photovoltaic modules and the heat pump are responsible to cover the electricity the thermal energy demands as
best as possible. As the name of the setup function says, the components are explicitly connected to each other, binding
inputs correspondingly to its output sequentially. This is difference then automatically connecting inputs and outputs
based its similarity. For a better understanding of explicit connection, proceed to session IO Connecting Functions
.
The basic structure of a setup function follows:
- Set the simulation parameters (See
SimulationParameters
class inhisim/hisim/component.py
) - Create a
Component
object and add it toSimulator
object- Create a
Component
object from one of the child classes implemented inhisim/hisim/components
- Check if
Component
class has been correctly imported
- Check if
- If necessary, connect your object's inputs with previous created
Component
objects' outputs. - Finally, add your
Component
object toSimulator
object
- Create a
- Repeat step 2 while all the necessary components have been created, connected and added to the
Simulator
object.
Once you are done, you can run the setup function according to the description in the simple example run.
The main program is executed from hisim/hisim/hisim_main.py
. The Simulator
(simulator.py
) object groups Component
s declared and added from the setups functions. The ComponentWrapper
(simulator.py
) gathers together the Component
s
inside an Simulator
Object. The Simulator
object performs the entire simulation under the
function run_all_timesteps
and stores the results in a Python pickle data.pkl
in a subdirectory
of hisim/hisim/results
named after the executed setup function. Plots and the report are automatically generated from
the pickle by the class PostProcessor
(hisim/hisim/postprocessing/postprocessing.py
).
A child class inherits from the Component
class in hisim/hisim/component.py
and has to have the following methods
implemented:
- i_save_state: updates previous state variable with the current state variable
- i_restore_state: updates current state variable with the previous state variable
- i_simulate: performs a timestep iteration for the
Component
- i_doublecheck: checks if the values are expected throughout the iteration
These methods are used by Simulator
to execute the simulation and generate the results.
Theses classes inherent from Component
(component.py
) class and can be used in your setup function to customize
different configurations. All Component
class children are stored in hisim/hisim/components
directory. Some of these
classes are:
RandomNumbers
(random_numbers.py
)SimpleController
(simple_controller.py
)SimpleSotrage
(simple_storage.py
)Transformer
(transformer.py
)PVSystem
(pvs.py
)CHPSystem
(chp_system.py
)Csvload
(csvload.py
)SumBuilderForTwoInputs
(sumbuilder.py
)SumBuilderForThreeInputs
(sumbuilder.py
)- ToDo: more components to be added
Let my_home_electricity_grid
and my_appliance
be Component objects used in the setup function. The
object my_apppliance
has an output ElectricityOutput
that has to be connected to an object ElectricityGrid
. The
object my_home_electricity_grid
has an input ElectricityInput
, where this connection takes place. In the setup
function, the connection is performed with the method connect_input
from the Simulator
class:
my_home_electricity_grid.connect_input(input_fieldname=my_home_electricity_grid.ELECTRICITY_INPUT,
src_object_name=my_appliance.component_name,
src_field_name=my_appliance.ELECTRICITY_OUTPUT)
A configuration automator is under development and has the goal to reduce connections calls among similar components.
After the simulator runs all time steps, the post processing (postprocessing.py
) reads the persistent saved results,
plots the data and
generates a report.
MIT License
Copyright (C) 2020-2021 Noah Pflugradt, Vitor Zago, Frank Burkard, Tjarko Tjaden, Leander Kotzur, Detlef Stolten
You should have received a copy of the MIT License along with this program. If not, see https://opensource.org/licenses/MIT
We are the Institute of Energy and Climate Research - Techno-economic Systems Analysis (IEK-3) belonging to the Forschungszentrum Jülich. Our interdisciplinary institute'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.
Development Partners:
Hochschule Emden/Leer inside the project "Piegstrom".
4ward Energy inside the EU project "WHY"
This work was supported by the Helmholtz Association under the Joint Initiative "Energy System 2050 A Contribution of the Research Field Energy" .
For this work weather data is based on data from "German Weather Service (Deutscher Wetterdienst-DWD)" and "NREL National Solar Radiation Database" (License: Creative Commons Attribution 3.0 United States License); individual values are averaged.
This project has received funding from the European Union’s Horizon 2020 research and innovation programme under grant agreement No 891943.