Hydpy

Latest version: v6.1.4

Safety actively analyzes 724206 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

Page 3 of 5

4.0.0

It's been a while since we released *HydPy 3.1*, and much has happened since then. The following listing points out only the highlights of the improvements *HydPy 4.0* comes with.

Regarding the model collection:
* Our "old" LARSIM-like application models [lland_v1 (Turc-Wendling, Degree day)](https://hydpy-dev.github.io/hydpy/4.0/lland_v1.html) and [lland_v2 (External PET, Degree day)](https://hydpy-dev.github.io/hydpy/4.0/lland_v2.html) now include a wider range of the original LARSIM options (e.g. capillary rise).
* The new model [lland_v3 (Penman-Monteith, Knauf)](https://hydpy-dev.github.io/hydpy/4.0/lland_v3.html) includes LARSIM options frequently applied in the context of runoff forecasting in Germany (e.g. snow energy balance calculations after Knauf, 2006).
* [lland_v4 (Penman-Monteith, Knauf, snow interception)](https://hydpy-dev.github.io/hydpy/4.0/lland_v4.html) extends [lland_v3](https://hydpy-dev.github.io/hydpy/4.0/lland_v3.html) by the process of snow interception.
* [lstream_v001 (Kinematic Wave, Manning-Strickler)](https://hydpy-dev.github.io/hydpy/4.0/lstream_v001.html) now keeps the water-balance perfectly. We achieved this by implementing LARSIM's "kinematic wave approach" instead of its original (problematic) Williams-like approach.
* [lstream_v002 (Kinematic wave, External rating curve)](https://hydpy-dev.github.io/hydpy/4.0/lstream_v002.html) works like [lstream_v001](https://hydpy-dev.github.io/hydpy/4.0/lstream_v001.html) but expects the relationship between water-stage and discharge to be calculated externally (e.g. by a hydrodynamical model).
* [dam_v006 (controlled lake)](https://hydpy-dev.github.io/hydpy/4.0/dam_v006.html), [dam_v007 (retention basin)](https://hydpy-dev.github.io/hydpy/4.0/dam_v007.html), and [dam_v008 (reservoir)](https://hydpy-dev.github.io/hydpy/4.0/dam_v008.html) are close emulations of the LARSIM models for representing lakes (SEEG), retention basins (RUEC) and reservoirs (TALS).
* [evap_v001 (FAO 56 PM)](https://hydpy-dev.github.io/hydpy/4.0/evap_v001.html) is our first pure "evaporation model" and implements the commonly applied [FAO guideline](http://www.fao.org/3/x0490e/x0490e00.htm) for calculating potential evapotranspiration.
* The "Converter" models [conv_v001 (Nearest Neighbour)](https://hydpy-dev.github.io/hydpy/4.0/conv_v001.html), [conv_v002 (Inverse Distance Weighting)](https://hydpy-dev.github.io/hydpy/4.0/conv_v002.html), and [conv_v003 (Inverse Distance Weighting with External Drift)](https://hydpy-dev.github.io/hydpy/4.0/conv_v003.html) work technically like all other models but are no hydrological models. You can apply them for interpolating input data (e.g. temperature) or the output data of arbitrary models (e.g. the potential evaporation calculated by [evap_v001](https://hydpy-dev.github.io/hydpy/4.0/evap_v001.html)).
* [wland_v001 (semi-distributed WALRUS model)](https://hydpy-dev.github.io/hydpy/4.0/wland_v001.html) is a (slightly extended) implementation of the [WALRUS](https://www.wur.nl/en/Research-Results/Chair-groups/Environmental-Sciences/Hydrology-and-Quantitative-Water-Management-Group/Research/WALRUS.htm) model, designed to simulate surface water fluxes in lowland catchments influenced by near-surface groundwater.
* [wland_v002 (experimental)](https://hydpy-dev.github.io/hydpy/4.0/wland_v002.html) is, as the name suggests, work in practice. So far, it simulates faster responses of the groundwater table than the original model due to more explicit considerations of the capillary fringe. We currently discuss other modifications to improve the WALRUS performance for "moderate-flat" catchments.

Note that, due to their extension, [lland_v1](https://hydpy-dev.github.io/hydpy/4.0/lland_v1.html) and [lland_v2](https://hydpy-dev.github.io/hydpy/4.0/lland_v2.html) now require some additional parameters.

Be aware that we might change some aspects of [lland_v3](https://hydpy-dev.github.io/hydpy/4.0/lland_v3.html) later. We will probably unify some parameter names and possibly even modify some equations.

General features:
* We now test *HydPy* from Python 3.6 to 3.9 (we think about dropping 3.6, but postpone this for the sake of keeping compatibility with the arcpy library of ArcGIS).
* The command "pip install hydpy" now installs *HydPy* and all its requirements in one step.
* Our AppVeyor workflow now creates an "HydPy-Installer" based on Python 3.9 for Windows. This is for users who want to experiment with *HydPy* without installing a complete Python environment or want to have a robust executable for just executing certain tasks (e.g. flood forecasting).
* We improved many features of the online documentation. Many new automatically generated links help to browse through the different pages (for example, to directly jump from a parameter to the methods/equation requiring this parameter). Additionally, we start providing the documentation of several *HydPy* versions in parallel (for now, version 4.0 and our current development status, the "master branch"; others will follow).
* *HydPy* now provides some [server functionalities](https://hydpy-dev.github.io/hydpy/4.0/servertools.html). The reason is to simplify the online coupling to non-Python software like [OpenDA](https://www.openda.org/) (for more information, see the separate documentation of our [OpenDA-Adapter](https://github.com/hydpy-dev/OpenDA)).
* We added and extended lots of "user-comfort" functionalities concerning [calibration](https://hydpy-dev.github.io/hydpy/4.0/calibtools.html), [evaluation](https://hydpy-dev.github.io/hydpy/4.0/statstools.html), [plotting](https://hydpy-dev.github.io/hydpy/4.0/devicetools.html#hydpy.core.devicetools.Element.plot_inputseries), and much more.

Scientifical and technical aspects:
* We finally achieved a test coverage of 100 %. Our Travis-CI workflow does not accept any changes with incomplete coverage. And everything is tested "publically" in the HTML documentation (using doctests). This is a really significant milestone, as it makes introducing bugs much harder and allows the hydrological community to check all implemented equations easily "by hand". We are not aware of any other hydrological modelling system with such an eager and transparent test system.
* We improved the tables and figures showing the results of the model integration tests. We hope they now better guide us into the depth of such huge models as [lland_v3](https://hydpy-dev.github.io/hydpy/4.0/lland_v3.html) and help to understand their details and possible implementation deficits. Our Travis-CI workflow automatically recreates all figures for each new release, so you can always be sure they are up-to-date.
* The source code is now consistently formatted with [black](https://github.com/psf/black).
* We started to add type hints to the source code following [PEP 484](https://www.python.org/dev/peps/pep-0484/). These improve the readability for code-analysis tools (and often also for humans) and improve IDE functions like auto-completion and bug-analysis. So far, these cover most of the features directly accessible to the user. We continue working on this.
* We increased the performance of *HydPy*, mainly regarding initialisation. Two examples are the "lazy importing" of optional site packages that are seldom required (finished) and the caching of pre-compiled byte-code (still room for improvements).

Most of the listed (and unlisted) improvements were implemented on behalf of the [German Federal Institute of Hydrology](https://www.bafg.de/EN/Home/homepage_en_node.html) and the [Forecasting Centre of the German federal state of Saxony (Landeshochwasserzentrum)](https://www.umwelt.sachsen.de/umwelt/infosysteme/lhwz/index.html).

3.1.1

*HydPy* informs the user when trying to read missing or incomplete observed or simulated time series data into *Node* objects. Due to some recent changes, this feature became unreliable. Version 3.1.1 fixes this problem and adds explanations and tests to the online documentation, to (hopefully) prevent this from happening again.

3.1.0

*HydPy* now checks for missing values in e. g. meteorological input time series data. This behaviour can be enabled/disabled by setting option *checkseries* to True/False.

Additionally, XML file implementations of the XML schema file *config.xsd* are now easier to maintain regarding version changes and general options like *checkseries*.

3.0.5

From now on, installing `matplotlib` is not required for using (most features of) `HydPy` anymore.

3.0.4

For convenience, XML namespaces are now valid download links, and some name discrepancies result in warnings only instead of errors.

3.0.3

One can now manually define the name and style of log files when executing workflows based on XML configuration files.

From now on, version specific XML schema files will be part of each new HydPy release, making referencing them more comfortable.

These changes do not fix actual bugs but simplify coupling with Delft-FEWS.

Page 3 of 5

© 2025 Safety CLI Cybersecurity Inc. All Rights Reserved.