Computational Uncertainty Quantification for Inverse problems in Python
Project description
Computational Uncertainty Quantification for Inverse Problems in python
CUQIpy stands for Computational Uncertainty Quantification for Inverse Problems in python. It's a robust Python package designed for modeling and solving inverse problems using Bayesian inference. Here's what it brings to the table:
- A straightforward high-level interface for UQ analysis.
- Complete control over the models and methods.
- An array of predefined distributions, samplers, models, and test problems.
- Easy extendability for your unique needs.
CUQIpy is part of the CUQI project supported by the Villum Foundation.
📚 Resources
-
Documentation: CUQIpy website
-
Training: Demo & training notebooks
🚀 Quickstart
Install CUQIpy using pip:
pip install cuqipy
For more detailed instructions, see the Getting Started guide.
🧪 Quick Example - UQ in a few lines of code
Experience the simplicity and power of CUQIpy with this Image deconvolution example. Getting started with UQ takes just a few lines of code:
# Imports
import matplotlib.pyplot as plt
from cuqi.testproblem import Deconvolution2D
from cuqi.distribution import Gaussian, LMRF, Gamma
from cuqi.problem import BayesianProblem
# Step 1: Set up forward model and data, y = Ax
A, y_data, info = Deconvolution2D(dim=256, phantom="cookie").get_components()
# Step 2: Define distributions for parameters
d = Gamma(1, 1e-4)
s = Gamma(1, 1e-4)
x = LMRF(0, lambda d: 1/d, geometry=A.domain_geometry)
y = Gaussian(A@x, lambda s: 1/s)
# Step 3: Combine into Bayesian Problem and sample posterior
BP = BayesianProblem(y, x, d, s)
BP.set_data(y=y_data)
samples = BP.sample_posterior(200)
# Step 4: Analyze results
info.exactSolution.plot(); plt.title("Sharp image (exact solution)")
y_data.plot(); plt.title("Blurred and noisy image (data)")
samples["x"].plot_mean(); plt.title("Estimated image (posterior mean)")
samples["x"].plot_std(); plt.title("Uncertainty (posterior standard deviation)")
samples["s"].plot_trace(); plt.suptitle("Noise level (posterior trace)")
samples["d"].plot_trace(); plt.suptitle("Regularization parameter (posterior trace)")
🔌 Plugins
CUQIpy can be extended with additional functionality by installing optional plugins. We currently offer the following plugins:
-
CUQIpy-CIL A plugin for the Core Imaging Library (CIL) providing access to forward models for X-ray computed tomography.
-
CUQIpy-FEniCS: A plugin providing access to the finite element modelling tool FEniCS, which is used for solving PDE-based inverse problems.
-
CUQIpy-PyTorch: A plugin providing access to the automatic differentiation framework of PyTorch within CUQIpy. It allows gradient-based sampling methods without manually providing derivative information of distributions and forward models.
💻 Maintainers
🌟 Contributors
A big shoutout to our passionate team! Discover the talented individuals behind CUQIpy here.
🤝 Contributing
We welcome contributions to CUQIpy. Please see our contributing guidelines for more information.
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 cuqipy-1.0.0.post0.dev202.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | dee41e3d9e3f269e124248f41779ccac099acee33ec864b481cfd6a03f6e9742 |
|
MD5 | 365a904cfc6c64736fe81d0e09fddde7 |
|
BLAKE2b-256 | 0596d752c2f39b77d98968b7b52b1fadc33b69a02996fad4ea7ba925de917025 |
Hashes for CUQIpy-1.0.0.post0.dev202-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 15182eedd938122bce462f8dfd6b294e6a4c3ef2d98ce6ec7599aba0f22ef0fc |
|
MD5 | d58267bfd6f952f1b9487147a00983bc |
|
BLAKE2b-256 | 6c1ca3446ce8661dd422bba3d906ceccefff7f74348bb56eb2fffcd10c408c23 |