Statistical Toolkit for Reliability Assessment in NDT
Project description
digiqual
Statistical Toolkit for Reliability Assessment in NDT
digiqual is a Python library designed for Non-Destructive Evaluation (NDE) engineers. It implements the Generalised $\hat{a}$-versus-a Method, allowing users to perform reliability assessments without the rigid assumptions of linearity or constant variance found in standard methods.
Documentation: Read the full documentation here
Installation
You can install digiqual directly from PyPI.
Option 1: Install via uv (Recommended)
If you are managing a project with uv, add digiqual as a dependency:
# To install the latest stable release (v0.18.0):
uv add digiqual
# To install the latest development version (main branch from github):
uv add "digiqual @ git+https://github.com/JGIBristol/digiqual.git"
If you just want to install it into a virtual environment without modifying a project file (e.g., for a quick script), use pip interface:
uv pip install digiqual
Option 2: Install via standard pip
To install the latest stable release (v0.18.0):
pip install digiqual
To install the latest development version from github:
pip install "git+https://github.com/JGIBristol/digiqual.git"
Features
1. Experimental Design
Before running expensive Finite Element (FE) simulations, digiqual helps you design your experiment efficiently.
- Latin Hypercube Sampling (LHS): Generate space-filling experimental designs to cover your deterministic parameter space (e.g., defect size) and stochastic nuisance parameters (e.g., roughness, orientation).
- Scale & Bound: Automatically scale samples to your specific variable bounds.
2. Data Validation & Diagnostics
Ensure your simulation outputs are statistically valid before processing.
- Sanity Checks: Detects overlap between variables, type errors, and insufficient sample sizes.
- Sufficiency Diagnostics: rigorous statistical tests to flag issues like "Input Coverage Gaps" or "Model Instability" before you trust the results.
3. Adaptive Refinement (Active Learning)
digiqual closes the loop between analysis and design.
-
Smart Refinement: Use
refine()to identify specific weaknesses in your data. It uses bootstrap committees to find regions of high uncertainty and suggests new points exactly where the model is "confused". -
Automated Workflows: Use the
optimise()method to run a fully automated "Active Learning" loop. It generates an initial design, executes your external solver, checks diagnostics, and iteratively refines the model until statistical requirements are met.
4. Generalised Reliability Analysis
The package includes a full statistical engine for calculating Probability of Detection (PoD) curves.
- Relaxed Assumptions: Moves beyond the rigid constraints of the classical $\hat{a}$-versus-$a$ method by handling non-linear signal responses and heteroscedastic noise.
- Multi-Dimensional Active Marginalisation: Resolves multidimensional physics by integrating out stochastic nuisance parameters (like roughness) via Monte Carlo methods, outputting high-fidelity 2D PoD surface heatmaps alongside standard 1D curves.
- Robust Statistics: Automatically selects the best polynomial degree and error distribution (e.g., Normal, Gumbel, Logistic) based on data fit (AIC).
- Uncertainty Quantification: Uses bootstrap resampling to generate robust confidence bounds and $a_{90/95}$ estimates.
Development
If you want to contribute to digiqual or run the test suite locally, follow these steps.
- Clone and Install
This project uses uv for dependency management.
git clone https://github.com/JGIBristol/digiqual.git
cd digiqual
- Run Tests
The package includes a full test suite using pytest.
uv run pytest
- Build Documentation
To preview the documentation site locally:
uv run quarto preview
References
Malkiel, N., Croxford, A. J., & Wilcox, P. D. (2025). A generalized method for the reliability assessment of safety–critical inspection. Proceedings of the Royal Society A, 481: 20240654. https://doi.org/10.1098/rspa.2024.0654
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 digiqual-0.18.0.tar.gz.
File metadata
- Download URL: digiqual-0.18.0.tar.gz
- Upload date:
- Size: 828.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.24 {"installer":{"name":"uv","version":"0.9.24","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2513c44e7fcc748f1587d4ab938f2f5001db8e28261d2c65de5c346b93f4dfe5
|
|
| MD5 |
a041cf1025cd41d867e12538ed796090
|
|
| BLAKE2b-256 |
48a1725bc93ba17bda5e3ca717cb0d3e3fa869ba3e6e1d49f826970edb15bf41
|
File details
Details for the file digiqual-0.18.0-py3-none-any.whl.
File metadata
- Download URL: digiqual-0.18.0-py3-none-any.whl
- Upload date:
- Size: 184.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.24 {"installer":{"name":"uv","version":"0.9.24","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5dadd1ea65ad4ebdbab5300685b43fbd564df0cc0951ae81f4431a000b9d9c94
|
|
| MD5 |
0f074866a10315c4bbc5052a5dd44af7
|
|
| BLAKE2b-256 |
0475f90b0c705cd1496cf2dfab5f901d6b7e1778c1ec8352a3711dc2c7d31963
|