Differentiable Hydrologic Model Library
Project description
Differentiable Hydrologic Models
A library of hydrological models developed on PyTorch and designed alongside 𝛿MG for the creation of end-to-end differentiable models, enabling parameter learning, bias correction, missing process representation, and more.
See 𝛿MG/examples using HydroDL2-based HBV models for published differentiable parameter learning (dPL) applications, and see citation for details on individual model architectures.
Installation
uv pip install hydrodl2
For development installs, see setup.
Quick Start
import hydrodl2
# List all available models
hydrodl2.available_models()
# {'hbv': ['hbv', 'hbv_1_1p', 'hbv_2', 'hbv_2_hourly', 'hbv_2_mts', 'hbv_adj']}
# Load a model class
Hbv = hydrodl2.load_model('hbv')
# Instantiate and use in a differentiable pipeline
model = Hbv()
Models are standard torch.nn.Module subclasses and can be composed with neural networks via δMG for end-to-end differentiable training.
Available Models
| Model | Name | Description |
|---|---|---|
| HBV 1.0 | hbv |
Base lumped differentiable HBV model |
| HBV Adjoint | hbv_adj |
Implicit scheme with adjoint-based gradients |
| HBV 1.1p | hbv_1_1p |
HBV with capillary rise modification |
| HBV 2.0 | hbv_2 |
Multi-scale, distributed HBV with elevation-dependent parameters |
| HBV 2.0 Hourly | hbv_2_hourly |
Sub-daily variant of HBV 2.0 |
| HBV 2.0 MTS | hbv_2_mts |
Multi-timescale variant of HBV 2.0 |
Repository Structure
.
├── src/
│ └── hydrodl2/
│ ├── api/ # Main API
│ │ ├── __init__.py
│ │ └── methods.py # Methods exposed to end-users
│ ├── core/ # Methods used internally
│ ├── models/ # Shared models directory
│ │ └── hbv/ # HBV model variants
│ └── modules/ # Augmentations for δMG models
├── docs/
├── tests/
└── pyproject.toml
Citation
This work is maintained by MHPI and advised by Dr. Chaopeng Shen. If you find it useful, please cite:
Shen, C., Appling, A.P., Gentine, P. et al. Differentiable modelling to unify machine learning and physical models for geosciences. Nat Rev Earth Environ 4, 552–567 (2023). https://doi.org/10.1038/s43017-023-00450-9
BibTeX
@article{shen_differentiable_2023,
title = {Differentiable modelling to unify machine learning and physical models for geosciences},
volume = {4},
issn = {2662-138X},
url = {https://doi.org/10.1038/s43017-023-00450-9},
doi = {10.1038/s43017-023-00450-9},
pages = {552--567},
number = {8},
journaltitle = {Nature Reviews Earth \& Environment},
author = {Shen, Chaopeng and Appling, Alison P. and Gentine, Pierre and Bandai, Toshiyuki and Gupta, Hoshin and Tartakovsky, Alexandre and Baity-Jesi, Marco and Fenicia, Fabrizio and Kifer, Daniel and Li, Li and Liu, Xiaofeng and Ren, Wei and Zheng, Yi and Harman, Ciaran J. and Clark, Martyn and Farthing, Matthew and Feng, Dapeng and Kumar, Praveen and Aboelyazeed, Doaa and Rahmani, Farshid and Song, Yalan and Beck, Hylke E. and Bindas, Tadd and Dwivedi, Dipankar and Fang, Kuai and Höge, Marvin and Rackauckas, Chris and Mohanty, Binayak and Roy, Tirthankar and Xu, Chonggang and Lawson, Kathryn},
date = {2023-08-01},
}
Models:
-
(HBV) Feng, D., Liu, J., Lawson, K., & Shen, C. (2022). Differentiable, learnable, regionalized process-based models with multiphysical outputs can approach state-of-the-art hydrologic prediction accuracy. Water Resources Research, 58, e2022WR032404. https://doi.org/10.1029/2022WR032404
BibTeX
@article{https://doi.org/10.1029/2022WR032404, author = {Feng, Dapeng and Liu, Jiangtao and Lawson, Kathryn and Shen, Chaopeng}, title = {Differentiable, Learnable, Regionalized Process-Based Models With Multiphysical Outputs can Approach State-Of-The-Art Hydrologic Prediction Accuracy}, journal = {Water Resources Research}, volume = {58}, number = {10}, pages = {e2022WR032404}, keywords = {rainfall runoff, differentiable programming, machine learning, physical model, differentiable hydrology, LSTM}, doi = {https://doi.org/10.1029/2022WR032404}, year = {2022}, }
-
(HBV Adj.) Song, Y., Knoben, W. J. M., Clark, M. P., Feng, D., Lawson, K., Sawadekar, K., and Shen, C.: When ancient numerical demons meet physics-informed machine learning: adjoint-based gradients for implicit differentiable modeling, Hydrol. Earth Syst. Sci., 28, 3051–3077, https://doi.org/10.5194/hess-28-3051-2024, 2024.
BibTeX
@Article{hess-28-3051-2024, AUTHOR = {Song, Y. and Knoben, W. J. M. and Clark, M. P. and Feng, D. and Lawson, K. and Sawadekar, K. and Shen, C.}, TITLE = {When ancient numerical demons meet physics-informed machine learning: adjoint-based gradients for implicit differentiable modeling}, JOURNAL = {Hydrology and Earth System Sciences}, VOLUME = {28}, YEAR = {2024}, NUMBER = {13}, PAGES = {3051--3077}, URL = {https://hess.copernicus.org/articles/28/3051/2024/}, DOI = {10.5194/hess-28-3051-2024} }
-
(HBV 1.1p) Yalan Song, Kamlesh Sawadekar, Jonathan M Frame, et al. Physics-informed, Differentiable Hydrologic Models for Capturing Unseen Extreme Events . ESS Open Archive . March 14, 2025. https://doi.org/10.22541/essoar.172304428.82707157/v2 [Accepted]
BibTeX
@article{https://doi.org/10.22541/essoar.172304428.82707157/v2, author = {Song, Yalan and Sawadekar, Kamlesh and Frame, Jonathan and Pan, Ming and Clark, Martyn and Knoben, Wouter J. M. and Wood W., Andrew and Lawson E., Kathryn and Patel, Trupesh and Shen, Chaopeng}, title = {Physics-informed, Differentiable Hydrologic Models for Capturing Unseen Extreme Events}, journal = {ESS Open Archive}, volume = {}, number = {}, pages = {}, keywords = {hydrology, differentiable modeling, extremes, physics-informed machine learning, streamflow, streamflow regime}, doi = {https://doi.org/10.22541/essoar.172304428.82707157/v2}, year = {2025},
-
(HBV 2.0) Song, Y., Bindas, T., Shen, C., Ji, H., Knoben, W. J. M., Lonzarich, L., et al. (2025). High-resolution national-scale water modeling is enhanced by multiscale differentiable physics-informed machine learning. Water Resources Research, 61, e2024WR038928. https://doi.org/10.1029/2024WR038928
BibTeX
@article{https://doi.org/10.1029/2024WR038928, author = {Song, Yalan and Bindas, Tadd and Shen, Chaopeng and Ji, Haoyu and Knoben, Wouter J. M. and Lonzarich, Leo and Clark, Martyn P. and Liu, Jiangtao and van Werkhoven, Katie and Lamont, Sam and Denno, Matthew and Pan, Ming and Yang, Yuan and Rapp, Jeremy and Kumar, Mukesh and Rahmani, Farshid and Thébault, Cyril and Adkins, Richard and Halgren, James and Patel, Trupesh and Patel, Arpita and Sawadekar, Kamlesh Arun and Lawson, Kathryn}, title = {High-Resolution National-Scale Water Modeling Is Enhanced by Multiscale Differentiable Physics-Informed Machine Learning}, journal = {Water Resources Research}, volume = {61}, number = {4}, pages = {e2024WR038928}, keywords = {differentiable modeling, physics-informed machine learning, National Water Model, routing, Muskingum Cunge, multiscale training}, doi = {https://doi.org/10.1029/2024WR038928}, year = {2025}, }
-
(HBV 2.0 MTS) Yang, W., Ji, H., Lonzarich, L., Song, Y., Shen, C. (2025). Diffusion-Based Probabilistic Modeling for Hourly Streamflow Prediction and Assimilation. arXiv. https://arxiv.org/abs/2510.08488 [Under Review]
BibTeX
@misc{yang2025diffusionbasedprobabilisticmodelinghourly, title={Diffusion-Based Probabilistic Modeling for Hourly Streamflow Prediction and Assimilation}, author={Wencong Yang and Haoyu Ji and Leo Lonzarich and Yalan Song and Chaopeng Shen}, year={2025}, eprint={2510.08488}, archivePrefix={arXiv}, primaryClass={physics.geo-ph}, url={https://arxiv.org/abs/2510.08488}, }
Contributing
We welcome contributions! See CONTRIBUTING.md for details.
Please submit an issue to report any questions, concerns, or bugs.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file hydrodl2-1.3.3.tar.gz.
File metadata
- Download URL: hydrodl2-1.3.3.tar.gz
- Upload date:
- Size: 2.5 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
722962ba396bf480579294a63998f79ed45d5265078e6bf3a868419eb4d721fc
|
|
| MD5 |
6f832f25ad965aacfc1e27a281ce389b
|
|
| BLAKE2b-256 |
9e00bad1d8e9b5631e81124aaef5b1e81e494a8f05b117477f971df931552d24
|
Provenance
The following attestation bundles were made for hydrodl2-1.3.3.tar.gz:
Publisher:
build-wheels.yaml on mhpi/hydrodl2
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
hydrodl2-1.3.3.tar.gz -
Subject digest:
722962ba396bf480579294a63998f79ed45d5265078e6bf3a868419eb4d721fc - Sigstore transparency entry: 1312443116
- Sigstore integration time:
-
Permalink:
mhpi/hydrodl2@2051e61b02182cbac8efb48c37cfa6f5be856bed -
Branch / Tag:
refs/tags/v1.3.3 - Owner: https://github.com/mhpi
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
build-wheels.yaml@2051e61b02182cbac8efb48c37cfa6f5be856bed -
Trigger Event:
release
-
Statement type:
File details
Details for the file hydrodl2-1.3.3-py3-none-any.whl.
File metadata
- Download URL: hydrodl2-1.3.3-py3-none-any.whl
- Upload date:
- Size: 53.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
35197b7b9fc5c96390c7199775eb5ebd8793650d4d2832d10a33a892d01ff60e
|
|
| MD5 |
807b32506ba69fb27511475c9c56b69d
|
|
| BLAKE2b-256 |
e298e6015640f27c8b1e1c7d71942ffe94169fae6ffa250bc2a8900af2e9da0a
|
Provenance
The following attestation bundles were made for hydrodl2-1.3.3-py3-none-any.whl:
Publisher:
build-wheels.yaml on mhpi/hydrodl2
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
hydrodl2-1.3.3-py3-none-any.whl -
Subject digest:
35197b7b9fc5c96390c7199775eb5ebd8793650d4d2832d10a33a892d01ff60e - Sigstore transparency entry: 1312443202
- Sigstore integration time:
-
Permalink:
mhpi/hydrodl2@2051e61b02182cbac8efb48c37cfa6f5be856bed -
Branch / Tag:
refs/tags/v1.3.3 - Owner: https://github.com/mhpi
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
build-wheels.yaml@2051e61b02182cbac8efb48c37cfa6f5be856bed -
Trigger Event:
release
-
Statement type: