Skip to main content

Muon tomography data analysis library

Project description

Code style: black CI-tests CI-lints muograph python compatibility muograph license pypi muograph version

Muograph: muon tomography library

logo

This repository provides a library for muon scattering tomography and muon transmission tomography data analysis.

Overview

As a disclaimer, this library is more of an aggregate of muon tomography algorithms used throughtout PhD research rather than a polished product for the general public. As such, this repo targets mostly muon tomography reaserchers and enthousiasts.

Users can find ready to use scattering density algorihms as well as samples of simulated data.

While currently being at a preliminary stage, this library is designed to be extended by users, whom are invited to implement their favorite reconstruction, material inference or image processing algorithms.

If you are interested in using this library seriously, please contact us; we would love to hear if you have a specific use-case you wish to work on.

Installation

As a dependency

For a dependency usage, muograph can be instaled with pip within a Conda environment:

conda create -n muograph python=3.10
conda activate muograph
pip install muograph

Make sure everythings works by running:

pytest path_to_muograph/test

You can check the location where muograph is installed:

pip show muograph

For development

Clone the repository locally:

git clone git@github.com:MaximeLagrange/muograph.git
cd muograph

For development usage, we use poetry to handle dependency installation:

curl -sSL https://install.python-poetry.org | python3 -

To get started, you need Poetry's bin directory in your PATH environment variable. Add the export command to your shell's configuration file. For bash, add it to the ~/.bashrc file. For zsh, add it to the ~/.zshrc file.

export PATH="$HOME/.local/bin:$PATH"

then reload the configuration file:

source ~/.bashrc # or source ~/.zshrc

Poetry should now be accessible:

poetry self update

Muograph requires python >= 3.10. This can be installed with e.g pyenv.

curl https://pyenv.run | bash
pyenv update
pyenv install 3.10
pyenv local 3.10

Install the dependencies:

poetry install
poetry self add poetry-plugin-export
poetry config warnings.export false
poetry run pre-commit install

Finally, make sure everything is working as expected by running the tests:

poetry run pytest muograph/test/

For those unfamiliar with poetry, basically just prepend commands with poetry run to use the stuff installed within the local environment, e.g. poetry run jupyter notebook to start a jupyter notebook server. This local environment is basically a python virtual environment. To correctly set up the interpreter in your IDE, use poetry run which python to see the path to the correct python executable.

Tutorials

A few tutorials to introduce users to the package can be found in the tutorial/ folder. They are provied as Jupyter notebooks:

  • 00_Volume_of_interest.ipynb shows how to define a voxelized volume of interest, later used by the reconstruction algorithms.
  • 01_Hits.ipynb demonstrates how to load muon hits, and simulate detector spatial resolution and/or efficiency effects.
  • 02_Tracking.ipynb shows how to convert muon hits into muon tracks usable for image reconstruction purposes.
  • 03_Tracking_muon_Scattering_tomography.ipynb combines incoming and ougoing tracks to compute features relevant to muon scatering tomography.
  • 04_POCA.ipynb takes the user through the computation of voxel-wise density predictions based on the Point of Closest Approach.
  • 05_Binned_clustered_algorithm.ipynb demonstrates the Binned Clustered Algorithm, with and without muon momentum information.
  • 06_Angle_statistical_reconstruction.ipynb shows the Angle Statistical Reconstruction algorithm, with and without muon momentum information.

You can run the tutorials using poetry command:

poetry run jupyter notebook muograph/tutorials/05_Binned_clustered_algorithm.ipynb

Examples

More advanced examples are provided in the muograph/examples:

poetry run jupyter notebook muograph/examples/00_scattering_small_size_statue.ipynb

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

muograph-0.1.16.tar.gz (7.4 MB view details)

Uploaded Source

Built Distribution

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

muograph-0.1.16-py3-none-any.whl (7.5 MB view details)

Uploaded Python 3

File details

Details for the file muograph-0.1.16.tar.gz.

File metadata

  • Download URL: muograph-0.1.16.tar.gz
  • Upload date:
  • Size: 7.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.10.12 Linux/6.8.0-85-generic

File hashes

Hashes for muograph-0.1.16.tar.gz
Algorithm Hash digest
SHA256 9a6e955f2a68c1526abc0ec7d6778dbe9d896b1e737350933d211936a4fea8e5
MD5 dd4b6e16d994d043693880d9f86fef7b
BLAKE2b-256 972d5f520e1c1926c7a4d868cff76968ba59ab07203e034ad503a04b96a6d92f

See more details on using hashes here.

File details

Details for the file muograph-0.1.16-py3-none-any.whl.

File metadata

  • Download URL: muograph-0.1.16-py3-none-any.whl
  • Upload date:
  • Size: 7.5 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.10.12 Linux/6.8.0-85-generic

File hashes

Hashes for muograph-0.1.16-py3-none-any.whl
Algorithm Hash digest
SHA256 9946b091e3ce5641a6e0f3bfedc32c0ec9347b4891f23481ba2fc7d5f82d8fe0
MD5 2d9242fdd8e785cb62b423d5dd01e198
BLAKE2b-256 6f1fa9fa73281f64972d77b6820267b7a75603141b1348e37aee4836c0804b2b

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