Skip to main content

Python bindings for OpenImpala — transport-property computation on 3-D voxel images

Project description

OpenImpala

Banner

Open In Colab PyPI License: BSD-3-Clause DOI GitHub release Build and Test codecov

OpenImpala is a high-performance framework for computing effective transport properties — tortuosity, effective diffusivity tensors, and effective conductivity — directly from 3D voxel images of porous media (X-ray CT, FIB-SEM, synthetic microstructures). It solves the governing PDEs on the Cartesian voxel grid using finite differences, bypassing mesh generation, and scales across MPI ranks and CUDA GPUs via AMReX and HYPRE.

Outputs parameterise continuum-scale models such as PyBaMM.

📖 Documentation: https://base-laboratory.github.io/OpenImpala/ 📓 Tutorials: tutorials/ (runnable on Google Colab)

Quick example

import numpy as np
import openimpala as oi

image = np.zeros((64, 64, 64), dtype=np.int32)
image[:, :, 16:48] = 1   # solid slab through the middle

with oi.Session():
    vf  = oi.volume_fraction(image, phase=0)
    tau = oi.tortuosity(image, phase=0, direction="z", solver="mlmg")
    print(f"Volume fraction: {vf.value:.4f}")
    print(f"Tortuosity:      {tau.value:.4f}")

Install

Python (recommended)

pip install openimpala            # CPU + optional CuPy GPU acceleration
pip install openimpala-cuda       # compiled HYPRE/AMReX CUDA wheel (Linux x86_64)

OpenImpala uses MPI for distributed parallelism — install an MPI runtime (libopenmpi-dev, openmpi, brew install open-mpi, or conda install -c conda-forge openmpi) before pip install. See Getting Started for full details.

Container (HPC)

Pre-built Apptainer/Singularity images are attached to each GitHub Release:

apptainer exec -B "$(pwd):/data" openimpala-vX.Y.Z.sif \
    /usr/local/bin/Diffusion /data/inputs

For batch SLURM scripts, see HPC Usage.

Build from source

See CONTRIBUTING.md for the native and containerised developer build, code style, and test workflow.

Features

  • Steady-state diffusion / conduction on segmented 3D voxel images
  • Tortuosity factor, full 3×3 effective diffusivity tensor, multi-phase transport
  • Microstructural metrics: volume fraction, percolation, particle size, specific surface area
  • TIFF / HDF5 / RAW / DAT image input; JSON output compatible with BPX / BattINFO
  • Solvers: HYPRE (PCG, FlexGMRES, BiCGSTAB; SMG / PFMG preconditioners) and AMReX MLMG (matrix-free, GPU-native)
  • MPI + OpenMP + CUDA parallelism — scales from a laptop to multi-node HPC

Citation

If you use OpenImpala in published work, please cite:

@article{LeHoux2021OpenImpala,
  title   = {{OpenImpala}: {OPEN} source {IMage} based {PArallisable} {Linear} {Algebra} solver},
  author  = {Le Houx, James and Kramer, Denis},
  year    = {2021},
  journal = {SoftwareX},
  volume  = {15},
  pages   = {100729},
  doi     = {10.1016/j.softx.2021.100729},
}

If you use the homogenisation-based effective diffusivity workflow, additionally cite Le Houx et al., Transport in Porous Media 150, 71–88 (2023), doi:10.1007/s11242-023-01993-7.

License

BSD 3-Clause. See LICENSE.

Acknowledgements

This work was financially supported by the EPSRC Centre for Doctoral Training in Energy Storage and its Applications [EP/R021295/1]; the Ada Lovelace Centre (STFC) project CANVAS-NXtomo; the EPSRC prosperity partnership with Imperial College, INFUSE [EP/V038044/1]; the Rutherford Appleton Laboratory; the Faraday Institution Emerging Leader Fellowship [FIELF001]; and Research England's Expanding Excellence in England grant at the University of Greenwich via the M34Impact programme. We acknowledge the use of the IRIDIS HPC facility, Diamond Light Source's Wilson cluster, STFC SCARF, and the University of Greenwich M34Impact cluster, and thank the developers of AMReX, HYPRE, libtiff, and HDF5.

Contact

Issues and feature requests: https://github.com/BASE-Laboratory/OpenImpala/issues. Questions: GitHub Discussions.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

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

openimpala-4.4.5-cp312-cp312-manylinux_2_28_x86_64.whl (6.9 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.28+ x86-64

openimpala-4.4.5-cp311-cp311-manylinux_2_28_x86_64.whl (6.9 MB view details)

Uploaded CPython 3.11manylinux: glibc 2.28+ x86-64

openimpala-4.4.5-cp310-cp310-manylinux_2_28_x86_64.whl (6.9 MB view details)

Uploaded CPython 3.10manylinux: glibc 2.28+ x86-64

openimpala-4.4.5-cp39-cp39-manylinux_2_28_x86_64.whl (6.9 MB view details)

Uploaded CPython 3.9manylinux: glibc 2.28+ x86-64

File details

Details for the file openimpala-4.4.5-cp312-cp312-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for openimpala-4.4.5-cp312-cp312-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 5b4c07a0c20c1640febfa7965159d0fd190c1e5f2507613ec27c4ef9f5000b58
MD5 9b2924478f87d1d1976bc2a90afda60b
BLAKE2b-256 9db30a1971a29e426bad3b763d7beba0620bb95861347604581d7d4ef6228d7c

See more details on using hashes here.

Provenance

The following attestation bundles were made for openimpala-4.4.5-cp312-cp312-manylinux_2_28_x86_64.whl:

Publisher: pypi-wheels-cpu.yml on BASE-Laboratory/OpenImpala

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file openimpala-4.4.5-cp311-cp311-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for openimpala-4.4.5-cp311-cp311-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 a88d7ed3341cd01d9e9c253dc949639811cd43724d00137fe4acf3455e126612
MD5 4b082870dbf6d8ed0d6c60903dd84625
BLAKE2b-256 9ee05c91c83ac1b1692e8b3ab8dd9ba8174c89ed97351549c44c30a1258d89f4

See more details on using hashes here.

Provenance

The following attestation bundles were made for openimpala-4.4.5-cp311-cp311-manylinux_2_28_x86_64.whl:

Publisher: pypi-wheels-cpu.yml on BASE-Laboratory/OpenImpala

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file openimpala-4.4.5-cp310-cp310-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for openimpala-4.4.5-cp310-cp310-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 37d3778f4063fe36833a87470d834f8294b463403cba6f8dbf9e9df97bbc0ad9
MD5 d5c5e9a25930660ee1c386a136bca553
BLAKE2b-256 73f97a2ca24bc9da9d74e6f439354ec7f24faca50ce2ee50372a760170d6526e

See more details on using hashes here.

Provenance

The following attestation bundles were made for openimpala-4.4.5-cp310-cp310-manylinux_2_28_x86_64.whl:

Publisher: pypi-wheels-cpu.yml on BASE-Laboratory/OpenImpala

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file openimpala-4.4.5-cp39-cp39-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for openimpala-4.4.5-cp39-cp39-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 d685136ab7c2b9ab560101faa4b7ff6e06f8ad6977945e1fe49b736e9ac71761
MD5 86c7a0899c3cf548c092d0ee07d9b4ba
BLAKE2b-256 f576eb94804dda544363db84e1bac951aad5f9922b34e9b25e2d2a4b1a2d9210

See more details on using hashes here.

Provenance

The following attestation bundles were made for openimpala-4.4.5-cp39-cp39-manylinux_2_28_x86_64.whl:

Publisher: pypi-wheels-cpu.yml on BASE-Laboratory/OpenImpala

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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