Calculate waterdepths for 3Di results.
Project description
threedidepth
Waterdepth
Calculate waterdepths for 3Di results. For results of type ‘raw’ the variable ‘s1’ is used as waterlevel. For results of type ‘aggregate’, the variable ‘s1_max’ is used as waterlevel.
Concentrations
Calculate concentrations for 3Di water quality results.
Features
Interpolated or gridcell-constant waterlevels or concentrations
Interfaces with threediresults via threedigrid
Progress indicator support
Low memory consumption
For the interpolated mode, the ‘lizard’-method is used. For a detailed description, read the docstring for the LizardLevelCalculator.
For the maximum waterlevel calculation, the maximum waterlevel for each point is taken before the interpolation is applied. This can lead to situations where the highest waterlevel for a pixel for a certain timestep is higher than the maximum waterlevel for the pixel.
Installation
Make sure GDAL is available as (from osgeo import gdal)
$ pip install threedidepth
Usage
From the cli:
$ threedidepth gridadmin.h5 results_3di.nc dem.tif waterdepth.tif $ threediwq gridadmin.h5 water_quality_results_3di.nc substance1 <xmin ymin xmax ymax> concentration.tif
Or python:
>>> threedidepth.calculate_waterdepth(...) >>> threedidepth.calculate_water_quality(...)
Development installation with Docker Compose
For development, clone the repository and use a docker compose setup:
$ docker compose build --build-arg uid=`id -u` --build-arg gid=`id -g` lib $ docker compose up --no-start $ docker compose start $ docker compose exec lib bash
Create a virtualenv:
# note that Dockerfile prepends .venv/bin to $PATH (docker)$ python3 -m venv .venv --system-site-packages
Install dependencies & package and run tests:
(docker)$ pip install -r requirements.txt (docker)$ pip install -e .[test] (docker)$ pytest
Update packages:
(docker)$ rm -rf .venv (docker)$ python3 -m venv .venv --system-site-packages (docker)$ pip install -e . (docker)$ pip freeze | grep -v threedidepth > requirements.txt
Changelog of threedidepth
0.7.1 (2025-09-24)
Keep old mode constants available for backwards compatibility.
0.7.0 (2025-09-23)
Add support for water quality results.
0.6.3 (2024-03-22)
Fix no_data_value is undefined.
0.6.2 (2024-03-14)
Assign a default value if no_data_value is undefined.
0.6.1 (2023-07-11)
Add release action for automatic upload to GitHub and PyPI.
0.6.0 (2023-07-10)
Update dependency versions
Add support for calculating maximum waterlevel as well as per timestep.
0.5 (2021-07-02)
Added support for result type ‘aggregate’.
Got rid of NetCDF4 dependency by using h5netcdf.
Fix coordinates of NetCDF output. (#17)
0.4 (2021-03-23)
Enabled multiple calculation steps.
Added netCDF output option.
0.3 (2021-02-10)
Reorder to match the lizard triangulation.
0.2 (2020-12-10)
Implemented lizard method and set it as default.
0.1.2 (2020-09-21)
Fix off-by-one-pixel nodgrid.
0.1.1 (2020-09-11)
Fix flipped nodgrid.
0.1 (2020-09-03)
First version.
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 threedidepth-0.7.1.tar.gz.
File metadata
- Download URL: threedidepth-0.7.1.tar.gz
- Upload date:
- Size: 23.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
06b9379401f6286cb391a6afebbb4076df9abb6e0bb8627fb51448e4e6aad2e5
|
|
| MD5 |
2eae88c86042b4987abcff6c00b66623
|
|
| BLAKE2b-256 |
36e27ad652d148fa5f2700ac37133278bf622847dbbf5b176eaf370b7d92343c
|
File details
Details for the file threedidepth-0.7.1-py3-none-any.whl.
File metadata
- Download URL: threedidepth-0.7.1-py3-none-any.whl
- Upload date:
- Size: 17.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2bf388c37dd11a7f4d439c10c6e04a73e50e0ed5c788877e0b4f6bd3e2083241
|
|
| MD5 |
2d3ce20695bc7a82d56a270bc388c855
|
|
| BLAKE2b-256 |
0603b701fb90008a9724aadfac3df4d7c92258df10f63b01b0c0dc0361ddf4c1
|