Skip to main content

A package for solving geophysical inference and inverse problems

Project description

pygeoinf: A Python Library for Geophysical Inference

Build Status PyPI version License: BSD-3-Clause Documentation Status

pygeoinf is a Python library for solving geophysical inference and inverse problems in a coordinate-free, abstract framework. It leverages the mathematics of Hilbert spaces to provide a robust and flexible foundation for Bayesian and optimisation-based inference.

Overview

The core philosophy of pygeoinf is to separate the abstract mathematical structure of an inverse problem from its concrete numerical implementation. Instead of manipulating NumPy arrays directly, you work with high-level objects like HilbertSpace, LinearOperator, and GaussianMeasure. This allows you to write code that is more readable, less error-prone, and closer to the underlying mathematics.

The library is built on a few key concepts:

  • HilbertSpace: The foundational class. It represents a vector space with an inner product, but it abstracts away the specific representation of vectors (e.g., NumPy arrays, pyshtools grids).
  • LinearOperator: Represents linear mappings between Hilbert spaces. These are the workhorses of the library, supporting composition, adjoints, and matrix representations.
  • GaussianMeasure: Generalizes the multivariate normal distribution to abstract Hilbert spaces, providing a way to define priors and noise models.
  • ForwardProblem: Encapsulates the mathematical model d = A(u) + e, linking the unknown model u to the observed data d.
  • Inversion Classes: High-level classes like LinearBayesianInversion and LinearLeastSquaresInversion provide ready-to-use algorithms for solving the inverse problem.

Key Features

  • Abstract Coordinate-Free Formulation: Write elegant code that mirrors the mathematics of inverse problems.
  • Bayesian Inference: Solve inverse problems in a probabilistic framework to obtain posterior distributions over models.
  • Optimisation Methods: Includes Tikhonov-regularized least-squares and minimum-norm solutions.
  • Extensive Solver Suite: Choose from direct factorisations or matrix-free iterative solvers (e.g., CG, MINRES, LSQR, BiCGStab, FCG) designed for abstract vectors.
  • Coupled Systems: Effortlessly build block matrices and direct sum spaces using HilbertSpaceDirectSum for joint inversions.
  • Geometric Constraints: Constrain your inversions using affine subspaces, bounds, and convex sublevel sets.
  • Probabilistic Modelling: Define priors and noise models using GaussianMeasure objects on abstract spaces.
  • Randomized Algorithms: Utilizes randomized SVD and Cholesky decompositions for efficient low-rank approximations of large operators.
  • Specialized Operator Variants: Efficient implementations for SparseMatrixLinearOperator and DiagonalSparseMatrixLinearOperator
  • Application-Specific Spaces: Provides concrete HilbertSpace implementations for functions on a line, circle, and the two-sphere.
  • High-Quality Visualisation: Built-in plotting methods for functions on symmetric spaces, now featuring multi-dimensional corner plots for joint posterior distributions.

Advanced Features

  • Block Operators: Construct complex operators from smaller components using BlockLinearOperator, ColumnLinearOperator, and RowLinearOperator. This is ideal for coupled inverse problems.
  • Parallelisation: Many expensive operations are parallelized with joblib, including dense matrix construction and randomized algorithms.

Installation

The package can be installed directly using pip. By default, this will perform a minimal installation.

    # Minimal installation
    pip install pygeoinf

To include the functionality for functions on the sphere, you can install the sphere extra. This provides support for pyshtools and Cartopy.

    # Installation with sphere-related features
    pip install pygeoinf[sphere]

For development, you can clone the repository and install using Poetry:

    git clone https://github.com/da380/pygeoinf.git
    cd pygeoinf
    poetry install

You can install all optional dependencies for development—including tools for running the test suite, building the documentation, and running the Jupyter tutorials—by using the --with flag and specifying the dev group.

    # Install all development dependencies (for tests, docs, and tutorials)
    poetry install --with dev

Documentation

The full documentation for the library, including the API reference and tutorials, is available at pygeoinf.readthedocs.io.

Tutorials

You can run the interactive tutorials directly in Google Colab to get started with the core concepts of the library.

Tutorial Name Link to Colab
Tutorial 1 - A first example Open In Colab
Tutorial 2 - Hilbert spaces Open In Colab
Tutorial 3 - Dual spaces Open In Colab
Tutorial 4 - Linear operators Open In Colab
Tutorial 5 - Linear solvers Open In Colab
Tutorial 6 - Gaussian measures Open In Colab
Tutorial 7 - Minimum norm inversions Open In Colab
Tutorial 8 - Bayesian inversions Open In Colab
Tutorial 9 - Direct sums Open In Colab
Tutorial 10 - Symmetric spaces Open In Colab

Contributing

Contributions are welcome! If you would like to contribute, please feel free to fork the repository, make your changes, and submit a pull request. For major changes, please open an issue first to discuss what you would like to change.

License

This project is licensed under the BSD-3-Clause License - see the LICENSE file for details.

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

pygeoinf-1.7.3.tar.gz (167.7 kB view details)

Uploaded Source

Built Distribution

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

pygeoinf-1.7.3-py3-none-any.whl (196.5 kB view details)

Uploaded Python 3

File details

Details for the file pygeoinf-1.7.3.tar.gz.

File metadata

  • Download URL: pygeoinf-1.7.3.tar.gz
  • Upload date:
  • Size: 167.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.4 CPython/3.12.13 Linux/6.17.0-1010-azure

File hashes

Hashes for pygeoinf-1.7.3.tar.gz
Algorithm Hash digest
SHA256 683d4fcefb14ba5b84deeffd5f43df125d8db31778c7b49320a0e35c8a7b200f
MD5 71742ee7d36bd7f4d79f24a09e7759da
BLAKE2b-256 249d44afa5313edddd8448d608e99829f74b583dc51ea429b3c84797183b9cb6

See more details on using hashes here.

File details

Details for the file pygeoinf-1.7.3-py3-none-any.whl.

File metadata

  • Download URL: pygeoinf-1.7.3-py3-none-any.whl
  • Upload date:
  • Size: 196.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.4 CPython/3.12.13 Linux/6.17.0-1010-azure

File hashes

Hashes for pygeoinf-1.7.3-py3-none-any.whl
Algorithm Hash digest
SHA256 f32dea63f7b22f013c5b967646dfccd644630bea3a4cfa654a1140750753dfd6
MD5 a3aa8f16665ccce0ee3d4d62fda6bc92
BLAKE2b-256 4e2d9753056f946d414fd64d79be7db1ea0a52b6ca35dbcf8150024ff3a55c2f

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