Skip to main content

Python implementation of the Open Building Energy Simulation (OpenBES) tool.

Project description

OpenBES-py

Unittest ASHRAE 140 Suite .github/workflows/package_test.yml PyPI - Downloads PyPI - Version

OpenBES-py is an open-source building energy simulation tool written in Python. It is designed to provide transparent, reproducible, and extensible energy modeling for buildings, supporting research, education, and practical analysis.

Features

  • Modular simulation engine: Each energy category is implemented as a separate module for clarity and extensibility.
  • Comprehensive test suite: All core modules are covered by unit and integration tests.
  • Standardized test cases: Planned integration with ASHRAE Standard 140 test cases (see cases_ashrae_std140_... directory).
  • Modern dependency management: Uses UV for fast, reliable Python environment setup (uv.lock included).

Version 0.1.9 implements the core functionality of OpenBES with parity to Excel version 32.

Version 0.2.0 implements the core functionality of OpenBES with parity to Excel version 34.

Version 0.3.0 has full parity to Excel version 34.

Version 1.0.0 will be the first stable release:

  • Validation performed directly against ASHRAE Standard 140
  • Excel parity abandoned
  • Stable Input/Output formats
  • Documentation and examples
  • License

Installation

You can install OpenBES-py via pip:

pip install openBES[jit]

This will install the package along with optional JIT compilation support for improved performance (via Numba). If you do not need JIT support, you can install without the [jit] extra.

Why doesn't the package default to JIT support?

A major use-case for the package is in a web-based environment, using Pyodide. Pyodide does not currently support Numba, so to keep the package lightweight and compatible with such environments, JIT support is made optional.

At a later date we might custom-compile the project to WASM with Numba support, but for now this is not available.

Usage

Here is a simple example of how to use OpenBES-py to run a building energy simulation:

from openBES import BuildingSimulation, OpenBESSpecification

spec_file = "path/to/specification.toml"
spec = OpenBESSpecification.from_toml(spec_file)
simulation = BuildingSimulation(spec)  # the simulation is run upon initialization
total_annual_energy_used = simulation.energy_use.sum().sum()  # collaspse energy use DataFrame -> annual energy in kWh

Development

  1. Install UV if you do not have it: pip install uv

  2. Set up a virtual environment (recommended): uv venv

  3. Install editable package: uv pip install -e .[dev]

  4. Install dependencies: uv sync

  5. Run tests to verify installation: uv run python -m unittest discover -s tests

License

The license for this project is under consideration.

Credits

We use Pandas for data manipulation and NumPy for numerical calculations.

We use PVLib.iotools for reading EPW (energy plus weather) files.

Jensen, A., Anderson, K., Holmgren, W., Mikofski, M., Hansen, C., Boeman, L., Loonen, R. “pvlib iotools — Open-source Python functions for seamless access to solar irradiance data.” Solar Energy, 266, 112092, (2023). DOI: 10.1016/j.solener.2023.112092.

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

openbes-0.3.1rc5.tar.gz (1.4 MB view details)

Uploaded Source

Built Distribution

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

openbes-0.3.1rc5-py3-none-any.whl (1.5 MB view details)

Uploaded Python 3

File details

Details for the file openbes-0.3.1rc5.tar.gz.

File metadata

  • Download URL: openbes-0.3.1rc5.tar.gz
  • Upload date:
  • Size: 1.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for openbes-0.3.1rc5.tar.gz
Algorithm Hash digest
SHA256 17d38f46dbd3b76bcbc03a675ee17d1335804c7d2ea8d1e9eadc230c71ec3530
MD5 80ba2c60066d8e9e3f1ff23d7f8ebe86
BLAKE2b-256 b0bb17355d49145ddd9c66612458ccfba11fb51e49ecac2a3ccb4cb2e1b17cbc

See more details on using hashes here.

File details

Details for the file openbes-0.3.1rc5-py3-none-any.whl.

File metadata

  • Download URL: openbes-0.3.1rc5-py3-none-any.whl
  • Upload date:
  • Size: 1.5 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for openbes-0.3.1rc5-py3-none-any.whl
Algorithm Hash digest
SHA256 7d9bb58ea306f8bac1a66b5b7d12dd731eae7c97fbd7e05a1e03650cfd3b48e4
MD5 025515620a80a411f87d33bf3e49f916
BLAKE2b-256 2f912500f70cceb500a9f7d1eb8108a48413e2ed313c7151bf719fc46a9f5a3b

See more details on using hashes here.

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