Skip to main content

Checks validity of a threedi-model

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.30

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.30.tar.gz (64.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.30-py2.py3-none-any.whl (75.7 kB view details)

Uploaded Python 2Python 3

File details

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

File metadata

  • Download URL: threedi-modelchecker-0.30.tar.gz
  • Upload date:
  • Size: 64.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.30.tar.gz
Algorithm Hash digest
SHA256 4ff5eb0f200ff6c3cbc42869a733bc59a9132bd8ba729a7137f396696ad1eb19
MD5 9ee17265579a912b3a8316f50992889b
BLAKE2b-256 30730264c79b1a9173eee35b299d5afe43608b561cae9c18b865e39ef5acfd61

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for threedi_modelchecker-0.30-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 0390b0e428b27c1ee6980223c882e82af10944b78bb9803757b8464e40b88b2c
MD5 798dc60b104cf7185bf743b181f53d5d
BLAKE2b-256 f052cf76e381797d7463e0c74f689a1c2f55e755adfe24d262be9f607655410d

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