Skip to main content

Checks validity of a 3Di schematisation

Project description

https://img.shields.io/pypi/v/threedi-modelchecker.svg Github Actions status

Threedi-modelchecker is a tool to verify the correctness of a 3Di schematisation. The goal is to provide a tool for builders to quickly check if his/her schematisation is correct and can be converted to a 3Di-Model to run a 3Di simulation. It provides detailed information about any potential errors in the schematisation.

Threedi-modelchecks only work against the latest 3Di migration: https://docs.3di.lizard.net/en/stable/d_before_you_begin.html#database-overview

Note:

In 2021 we changed the naming within the 3Di realm. To better understand what users meant with ‘model’ we made a clear distinction between a schematisation and a model. A schematisation is build interactively by the user and this schematisation will be converted to a 3Di-Model which can be used in simulations. This repo is still called the threedi-modelchecker which might lead to confusion.

Installation:

pip install threedi-modelchecker

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_modelchecker 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 -s path/to/model.sqlite check -l warning

By default, WARNING and INFO checks are ignored.

Migrations

Migrate the schematisation file to the latest version as follows:

threedi_modelchecker -s path/to/model.sqlite migrate

The file will be change in-place.

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

This version

0.32

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

threedi-modelchecker-0.32.tar.gz (69.5 kB view details)

Uploaded Source

Built Distribution

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

threedi_modelchecker-0.32-py2.py3-none-any.whl (81.4 kB view details)

Uploaded Python 2Python 3

File details

Details for the file threedi-modelchecker-0.32.tar.gz.

File metadata

  • Download URL: threedi-modelchecker-0.32.tar.gz
  • Upload date:
  • Size: 69.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.15

File hashes

Hashes for threedi-modelchecker-0.32.tar.gz
Algorithm Hash digest
SHA256 439f53f7f76466a3d0e31798b310182fbfb092ecfca575a010d9696361967748
MD5 8dbdcdcb6bc8a514d7e706d9ec988131
BLAKE2b-256 61fc637263469c102abffd27c15d472d88347f0edfa33fd317a40dd7039a6d2e

See more details on using hashes here.

File details

Details for the file threedi_modelchecker-0.32-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for threedi_modelchecker-0.32-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 4a84f6ab3eff498aeba01f872c7d4e1c2c3b846ad5f535e86b4ced22694cf5b3
MD5 0328e846c01c105af08ab682566d34cb
BLAKE2b-256 26cd6878cf4f9f6e6fa92c762691a526af8c9baef6f14564c46d96d2f05276f4

See more details on using hashes here.

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