Skip to main content

Data processing algorithms for tomography

Project description

Algotom

Data processing (ALGO)rithms for (TOM)ography.

GitHub Workflow Status Downloads Conda GitHub code size in bytes Conda GitHub issues Conda Coverage

logo

Algotom is a Python package designed for tomography data processing. It offers a complete data processing pipeline; including reading and writing data, pre-processing, tomographic reconstruction, post-processing, data simulation, and calibration techniques. The package provides many utility methods to assist users in constructing a pipeline for processing their own data or developing new methods. Key features of Algotom include a wide range of processing methods such as artifact removal, distortion correction, speckle-based phase-contrast imaging, data reduction; and the capability of processing non-standard tomography acquisitions such as grid scans or helical scans. The software stands out for its readability, minimal dependencies, and rich documentation. Developed specifically for synchrotron-based tomographic beamlines, Algotom aims to maximize data quality, enhance workflow throughput, and exploit full beamline capabilities.

Features

Algotom is a lightweight package. The software is built on top of a few core Python libraries to ensure its ease-of-installation. Methods distributed in Algotom have been developed and tested at synchrotron beamlines where massive datasets are produced. This factor drives the methods developed to be easy-to-use, robust, and practical. Algotom can be used on a normal computer to process large tomographic data. Some featuring methods in Algotom are as follows:

  • Methods in a full data processing pipeline: reading-writing data, pre-processing, tomographic reconstruction, and post-processing.

    pipe_line

  • Methods for processing grid scans (or tiled scans) with the offset rotation-axis to multiply double the field-of-view (FOV) of a parallel-beam tomography system. These techniques enable high-resolution tomographic scanning of large samples.

    grid_scan

  • Methods for processing helical scans (with/without the offset rotation-axis).

    helical_scan

  • Methods for determining the center-of-rotation (COR) and auto-stitching images in half-acquisition scans (360-degree acquisition with the offset COR).

  • Practical methods developed and implemented for the package: zinger removal, tilted sinogram generation, sinogram distortion correction, simplified form of Paganin's filter, beam hardening correction, DFI (direct Fourier inversion) reconstruction, FBP (filtered back-projection) reconstruction, BPF (back-projection filtering) reconstruction, and double-wedge filter for removing sample parts larger than the FOV in a sinogram.

    pipe_line

  • Utility methods for customizing ring/stripe artifact removal methods and parallelizing computational work.

  • Calibration methods for helical scans and tomography alignment.

  • Methods for generating simulation data: phantom creation, sinogram calculation based on the Fourier slice theorem, and artifact generation.

    simulation

  • Methods for phase-contrast imaging: phase unwrapping, speckle-based phase retrieval, image correlation, and image alignment.

    speckle

  • Methods for downsampling, rescaling, and reslicing (+rotating, cropping) 3D reconstructed image without large memory usage.

    reslicing

  • Direct vertical reconstruction for single slice, multiple slices, and multiple slices at different orientations.

    vertical_slice1

    vertical_slice1

Installation

  • https://algotom.readthedocs.io/en/latest/toc/section3.html
  • If users install Algotom to an existing environment and Numba fails to install due to the latest Numpy:
    • Downgrade Numpy and install Algotom/Numba again.
    • Create a new environment and install Algotom first, then other packages.
    • Use conda instead of pip.
  • Avoid using the latest version of Python or Numpy as the Python ecosystem taking time to keep up with these twos.

Usage

Development principles

  • While Algotom offers a complete set of tools for tomographic data processing covering pre-processing, reconstruction, post-processing, data simulation, and calibration techniques; its development strongly focuses on pre-processing techniques. This distinction makes it a prominent feature among other tomographic software.

  • To ensure that the software can work across platforms and is easy-to-install; dependencies are minimized, and only well-maintained Python libraries are used.

  • To achieve high-performance computing and leverage GPU utilization while ensuring ease of understanding, usage, and software maintenance, Numba is used instead of Cupy or PyCuda.

  • Methods are structured into modules and functions rather than classes to enhance usability, debugging, and maintenance.

  • Algotom is highly practical as it can run on computers with or without a GPU, multicore CPUs; and accommodates both small and large memory capacities.

Update notes

Author

  • Nghia T. Vo - NSLS-II, Brookhaven National Lab, USA; Diamond Light Source, UK.

Highlights

Algotom was used for some experiments featured on media:

Project details


Download files

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

Source Distribution

algotom-1.6.0.tar.gz (110.0 kB view details)

Uploaded Source

Built Distribution

algotom-1.6.0-py3-none-any.whl (118.9 kB view details)

Uploaded Python 3

File details

Details for the file algotom-1.6.0.tar.gz.

File metadata

  • Download URL: algotom-1.6.0.tar.gz
  • Upload date:
  • Size: 110.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.10.13

File hashes

Hashes for algotom-1.6.0.tar.gz
Algorithm Hash digest
SHA256 9b9f8a6fcd8d9ce9b8e6236d6181947d14b26aa3186cda0675c142ca3532417d
MD5 a3ef8f2c43b613408a707ea0ce1a377e
BLAKE2b-256 26f2ac34ac24f30ca5977f18e27efaf53076015f507ffe89a847d8cf64f81329

See more details on using hashes here.

File details

Details for the file algotom-1.6.0-py3-none-any.whl.

File metadata

  • Download URL: algotom-1.6.0-py3-none-any.whl
  • Upload date:
  • Size: 118.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.10.13

File hashes

Hashes for algotom-1.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 882948e0b249405e61fd4a9bb4016cd580e9de6c5b303efe84456067b2e7c200
MD5 df8bd12aea7f921fe57d6227b7275d13
BLAKE2b-256 3b85e1f320db66faea81c2ef1230f7057dfbb988795f3ce99b2a07663a48daed

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page