Skip to main content

Dynamic simulation of buildings and integration with semantic modeling.

Project description

docs

twin4build: A python package for Data-driven and Ontology-based modeling and simulation of buildings

Dynamic modeling and simulation of buildings, featuring fully differentiable models for parameter estimation and optimal control. Supports integration of semantic models for automatic model generation and fast implementation.

Core Classes and Functionality

Twin4Build provides several top-level classes for building, simulating, translating, calibrating, and optimizing building energy models:

  • Model:
    The main container for your building system, components, and their connections. Use this class to assemble your digital twin from reusable components.

  • Simulator:
    Runs time-based simulations of your Model, producing time series outputs for all components. Handles the simulation loop and time stepping.

  • Translator:
    Automatically generates a Model from a semantic model (ontology-based building description) and maintains a link between these. Enables ontology-driven, automated model creation.

  • Estimator:
    Performs parameter estimation (calibration) for your Model using measured data. Supports both least-squares and PyTorch-based optimization.

  • Optimizer:
    Optimizes building operation by adjusting setpoints or control variables to minimize objectives or satisfy constraints, using gradient-based methods.

All classes are accessible via the main package import:

import twin4build as tb

A typical workflow would look like this:

Examples and Tutorials

Below are some examples of how to use the package. More examples are coming soon.

Basics of Twin4Build

  • Open In Colab Part 1: Connecting components, simulating a model, and visualization
  • Open In Colab Part 2: Modeling and control of indoor CO2 concentration

Translator

  • Open In Colab Part 1: How to use the translator to generate simulation models from semantic models.

Estimator

  • Open In Colab Part 1: Basic parameter estimation and calibration

Optimizer

  • Open In Colab Part 1: Optimization of space heater power consumption, constrained by heating and cooling setpoints.

Documentation

The documentation can be found online. Below is a code snippet showing the basic functionality of the package.

import twin4build as tb

# Create a model
model = tb.Model(id="example_model")

# Define components
damper = tb.DamperTorchSystem(id="damper")
space = tb.BuildingSpaceTorchSystem("space")

# Add connections to the model
self.add_connection(damper, space, 
                    "airFlowRate", "supplyAirFlowRate")

# Load the model
model.load()

# Create a simulator instance
simulator = tb.Simulator(model)

# Simulate the model
step_size = 600 #Seconds
start_time = datetime.datetime(year=2025, month=1, day=10, hour=0, minute=0, second=0) # Optionally set the timezone
end_time = datetime.datetime(year=2025, month=1, day=12, hour=0, minute=0, second=0) # Optionally set the timezone
simulator.simulate(step_size=step_size,
                   start_time=start_time,
                   end_time=end_time)

# Plot the results
plot.plot_component(simulator, 
                    components_1axis=[("Damper", "airFlowRate")],
                    components_2axis=[("Damper", "damperPosition")],
                    ylabel_1axis="Air flow rate", #Optional
                    ylabel_2axis="Damper position", #Optional
                    show=True,
                    nticks=11)

Installation

The package is installed with pip:

pip install twin4build

The following python versions are supported:

Python version Windows Ubuntu
3.9 windows-python3.9 ubuntu-python3.9
3.10 windows-python3.10 ubuntu-python3.10
3.11 windows-python3.11 ubuntu-python3.11
3.12 windows-python3.12 ubuntu-python3.12

Graphviz (recomended)

To utilize the graph-drawing capabilities of twin4build, the drawing engine Graphviz must be installed. It can be installed by downloading the install-file from the official website or by using your favorite package manager:

Ubuntu

sudo add-apt-repository universe
sudo apt update
sudo apt install graphviz

Windows

On windows, the winget or choco package managers can be used:

winget install graphviz
choco install graphviz

MacOS

brew install graphviz

Publications

[1] Bjørnskov, J. & Thomsen, A. & Jradi, M. (2025). Large-scale field demonstration of an interoperable and ontology-based energy modeling framework for building digital twins. Applied Energy, 387, [125597]

[2] Bjørnskov, J. & Jradi, M. & Wetter, M. (2025). Automated Model Generation and Parameter Estimation of Building Energy Models Using an Ontology-Based Framework. Energy and Buildings 329, [115228]

[3] Bjørnskov, J. & Jradi, M. (2023). An Ontology-Based Innovative Energy Modeling Framework for Scalable and Adaptable Building Digital Twins. Energy and Buildings, 292, [113146].

[4] Bjørnskov, J., Badhwar, A., Singh, D., Sehgal, M., Åkesson, R., & Jradi, M. (2025). Development and demonstration of a digital twin platform leveraging ontologies and data-driven simulation models. Journal of Building Performance Simulation, 1–13.

[5] Bjørnskov, J. & Jradi, M. (2023). Implementation and demonstration of an automated energy modeling framework for scalable and adaptable building digital twins based on the SAREF ontology. Building Simulation.

[6] Andersen, A. H. & Bjørnskov, J. & Jradi, M. (2023). Adaptable and Scalable Energy Modeling of Ventilation Systems as Part of Building Digital Twins. In Proceedings of the 18th International IBPSA Building Simulation Conference: BS2023 International Building Performance Simulation Association.

Cite as

@article{OntologyBasedBuildingModelingFramework,
    title = {An ontology-based innovative energy modeling framework for scalable and adaptable building digital twins},
    journal = {Energy and Buildings},
    volume = {292},
    pages = {113146},
    year = {2023},
    issn = {0378-7788},
    doi = {https://doi.org/10.1016/j.enbuild.2023.113146},
    url = {https://www.sciencedirect.com/science/article/pii/S0378778823003766},
    author = {Jakob Bjørnskov and Muhyiddine Jradi},
    keywords = {Digital twin, Data-driven, Building energy model, Building simulation, Ontology, SAREF},
}

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

twin4build-1.1.1.tar.gz (572.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

twin4build-1.1.1-py3-none-any.whl (618.8 kB view details)

Uploaded Python 3

File details

Details for the file twin4build-1.1.1.tar.gz.

File metadata

  • Download URL: twin4build-1.1.1.tar.gz
  • Upload date:
  • Size: 572.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for twin4build-1.1.1.tar.gz
Algorithm Hash digest
SHA256 d12cc4a1c847395820c8c448159fa95ccfb96906cd2f5badfa2e2453a8dd9817
MD5 7bfcebb4b2fa293a08fc95cc18034808
BLAKE2b-256 a1a8f8282df12cf81e5b209ab337f241edd625f38f18b48e6ab8112939121342

See more details on using hashes here.

Provenance

The following attestation bundles were made for twin4build-1.1.1.tar.gz:

Publisher: publish_pypi.yml on JBjoernskov/Twin4Build

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file twin4build-1.1.1-py3-none-any.whl.

File metadata

  • Download URL: twin4build-1.1.1-py3-none-any.whl
  • Upload date:
  • Size: 618.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for twin4build-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 86c226934804b38dc57cad27be0cb48a0ee20e73932f1b27ff16b8e2a1425051
MD5 c5b7d8eeb31d47ff5d5506941d2d256c
BLAKE2b-256 d5e570174df117f854adb6fe9e1bd8f448d8b3ec35244fd54cc81c88816cd677

See more details on using hashes here.

Provenance

The following attestation bundles were made for twin4build-1.1.1-py3-none-any.whl:

Publisher: publish_pypi.yml on JBjoernskov/Twin4Build

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page