Checks validity of a 3Di schematisation
Project description
A tool to verify the correctness of a 3Di schematisation.
It asserts the correctness of a 3Di schematisation and provides detailed information about any potential errors in it.
This package only work against a specific schematisation version. Use https://pypi-hypernode.com/project/threedi-schema/ to upgrade a schematisation version. See also the 3Di documentation at https://docs.3di.lizard.net/en/stable/d_before_you_begin.html#database-overview
Note that the name “modelchecker” might be slightly confusing: the thing that is checked is a schematisation, and not a threedimodel. A schematisation is built interactively by the user and this schematisation will be converted to a 3Di-Model which can be used in simulations.
Installation
pip install threedi-modelchecker
Note that raster checks will be skipped unless GDAL is available. threedi-modelchecker is also integrated into the ThreediToolbox Qgis plugin: https://github.com/nens/ThreeDiToolbox
Example
The following code sample shows how you can use the modelchecker to run all configured checks and print an overview of all discovered errors:
from threedi_modelchecker.exporters import format_check_results from threedi_modelchecker import ThreediModelChecker from threedi_schema import ThreediDatabase sqlite_file = "<Path to your sqlite file>" database = ThreediDatabase(sqlite_file) model_checker = ThreediModelChecker(database) for check, error in model_checker.errors(level="WARNING"): print(format_check_results(check, error))
Command-line interface
Use the modelchecker from the command line as follows:
threedi_modelchecker check -s path/to/model.sqlite -l warning
By default, WARNING and INFO checks are ignored. To skip the beta features check, add the –allow-beta flag.
Development
A docker image has been created for easy development. It contains an postgis server with an empty 3Di database to allow for easy testing.
Build the image:
docker-compose build
Run the tests:
docker-compose run modelchecker pytest
See Creating revisions for instructions on how to change the 3Di model schematisation.
Release
Make sure you have zestreleaser installed.
fullrelease
When you created a tag, make sure to upload it to pypi.
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
Hashes for threedi_modelchecker-2.14.0.dev0.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 27ec1c006c41a05e422e807aa47e7f8d5f0f6ff90ca0add61a8a13b9720ce27f |
|
MD5 | 391553eba5c5b66b4cd5a08524cb5e86 |
|
BLAKE2b-256 | 5d326a655996ec4e2b73f6780e47fe90c73e8f8caa6a6a79236cf40111624a2b |
Hashes for threedi_modelchecker-2.14.0.dev0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 621dccf65327ccb938e5a26432a6d1584dbe900e4b79e8550bd5f622b1ff4e16 |
|
MD5 | 529b57b4acab1afd399c7a8f16c1635f |
|
BLAKE2b-256 | 2393f5ad777ca0c20ad7ed1659163301d4ff85708a9ef71cb31f90c342f09939 |