Skip to main content

Surrogate-assisted Bayesian calibration for hydrodynamic and morphodynamic models (Telemac, OpenFOAM).

Project description

HydroBayesCal

Surrogate-assisted Bayesian calibration for computationally expensive hydro- and morphodynamic models.

Documentation License: BSD-3-Clause

HydroBayesCal calibrates expensive numerical models without running them thousands of times. It trains a Gaussian Process Emulator (GPE) as a fast surrogate from a small set of strategically sampled simulations, then refines it with Bayesian Active Learning (BAL) — iteratively adding the training points that maximise the information gain (relative entropy) and Bayesian model evidence for the calibration. Single- and multi-output GPEs are supported.

The package couples to open-source modelling software through a common binding layer:

  • TELEMAC (2D/3D) — fully supported
  • OpenFOAM (interFoam) — binding under active development

Experimental design and parameter sampling are delegated to BayesValidRox; the GP emulators and the Bayesian active-learning logic are implemented in-tree.

Installation

HydroBayesCal requires Python ≥ 3.10 (tested on 3.10–3.12). It is developed and tested on Linux.

pip install hydroBayesCal

or, for a development/editable install from a clone:

git clone https://github.com/sschwindt/hydrobayescal.git
cd hydrobayescal
pip install -e ".[dev,docs,mesh]"

A calibration additionally requires a working installation of the numerical solver (e.g. TELEMAC) on the system. See the installation guide for the full environment setup, including coupling HydroBayesCal with TELEMAC.

Quick start

Configure a calibration in a Python config file and run the TELEMAC driver:

python bal_telemac.py --config config_Telemac.py

See the documentation for the end-to-end workflow, the configuration parameters, the code architecture, and worked examples.

Development & releases

Contributions are welcome — see CONTRIBUTING.md for the development setup, coding conventions, and the documentation build.

For maintainers, a few essentials:

  • Editable install: pip install -e ".[dev,docs,mesh]" (Python ≥ 3.10, tested 3.10–3.12).
  • Versioning: Semantic Versioning / PEP 440; the version lives only in pyproject.toml (keep docs/conf.py in sync). PyPI versions are immutable — always bump for a new release.
  • Releases are automated: publishing a GitHub Release (tag vX.Y.Z) triggers .github/workflows/publish.yml, which builds the distributions and uploads them to PyPI via Trusted Publishing (OIDC, no stored token). No manual twine upload is needed. Build locally to sanity-check with python -m build && twine check dist/*.

Citing / scientific background

HydroBayesCal builds on the Bayesian active-learning framework of Oladyshkin et al. (2020) and on Gaussian-process regression (Rasmussen & Williams, 2006). Its application to reservoir sedimentation and 3D reservoir hydrodynamics is documented in Mouris et al. (2023) and Schwindt et al. (2023). Full references with DOIs are on the references page.

License

Distributed under the BSD 3-Clause License. See LICENSE.

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

hydrobayescal-0.1.2.tar.gz (146.0 kB view details)

Uploaded Source

Built Distribution

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

hydrobayescal-0.1.2-py3-none-any.whl (155.9 kB view details)

Uploaded Python 3

File details

Details for the file hydrobayescal-0.1.2.tar.gz.

File metadata

  • Download URL: hydrobayescal-0.1.2.tar.gz
  • Upload date:
  • Size: 146.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for hydrobayescal-0.1.2.tar.gz
Algorithm Hash digest
SHA256 2c89b4d875f91402a0a566465bc478e4c3ab7626617ecab4125e7ba0a746c3e7
MD5 bbe5a09ebade5c5457570eefd42419c9
BLAKE2b-256 90c9caf1760be61f6406961b31779f7398b0e5452cd530a8fc3538235ba832ac

See more details on using hashes here.

Provenance

The following attestation bundles were made for hydrobayescal-0.1.2.tar.gz:

Publisher: publish.yml on Ecohydraulics/hydrobayescal

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

File details

Details for the file hydrobayescal-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: hydrobayescal-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 155.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for hydrobayescal-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e495e2b677338ee04e32ba0798398481f9487a40a0383a92b18e390dfe2dbcd1
MD5 5bec6e35924e2b443b5542a2371174a6
BLAKE2b-256 b840ba03d60273c15b0e6cf7cd9e2ebe02f8307f7a4826ab70abb99f82ac78a4

See more details on using hashes here.

Provenance

The following attestation bundles were made for hydrobayescal-0.1.2-py3-none-any.whl:

Publisher: publish.yml on Ecohydraulics/hydrobayescal

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