Git Product home page Git Product logo

spdhg_pet's Introduction

Faster PET Reconstruction with Non-Smooth Priors by Randomization and Preconditioning

This repository code to reproduce the results in [1] which proposes the use of the Stochastic Primal-Dual Hybrid Gradient algorithm (SPDHG) [2] for PET imaging with non-smooth priors (see also [3]). The results are on real clinical PET data in span 1 from the Siemens Biograph mMR based at UCLH Macmillan Cancer Centre. SPDHG is a direct generalization of the popular Primal-Dual Hybrid Gradient algorithm (PDHG) also known as the Chambolle-Pock algorithm [4, 5].

[1] M. J. Ehrhardt, P. J. Markiewicz, and C.-B. Schönlieb, “Faster PET reconstruction with non-smooth priors by randomization and preconditioning,” Phys. Med. Biol., 2019. 10.1088/1361-6560/ab3d07

Example results for various priors on FDG data are shown below.

Installation of dependencies

You need to install ODL and NiPET [6] to run the examples.

We recommend to use conda to manage the correct versions of the packages. If you want to use conda, you could start like

conda create --name pet python=2.7
source activate pet

Then get some packages that nipet NiPET need.

pip2 install numpy dicom

Get PET data

Download the PET data set available here, e.g.

wget https://zenodo.org/record/1472951/files/amyloidPET_FBP_TP0.zip path_to_data

NiPET

Clone the GIT repository and install (use path_to_data/umap when asked for the attenuation maps)

git clone https://github.com/pjmark/NIPET.git path_to_nipet
cd path_to_nipet
pip2 install --no-binary :all: --verbose .

(most recent) ODL

Clone the GIT repository and install

git clone https://github.com/odlgroup/odl.git path_to_odl
cd path_to_odl
pip2 install -e .

The code might also be compatible with older versions of ODL which are slightly easier to install:

pip2 install odl

Examples

Assuming you have installed the dependencies as below, you can run various examples as outlined below.

The numerical examples in [1] can be reproduced with

and the figures be recreated with

References

[1] M. J. Ehrhardt, P. J. Markiewicz, and C.-B. Schönlieb, “Faster PET reconstruction with non-smooth priors by randomization and preconditioning,” Phys. Med. Biol., 2019. 10.1088/1361-6560/ab3d07

[2] A. Chambolle, M. J. Ehrhardt, P. Richtárik, and C.-B. Schönlieb, “Stochastic Primal-Dual Hybrid Gradient Algorithm with Arbitrary Sampling and Imaging Applications,” SIAM J. Optim., vol. 28, no. 4, pp. 2783–2808, 2018.

[3] M. J. Ehrhardt, P. J. Markiewicz, P. Richtárik, J. Schott, A. Chambolle, and C.-B. Schönlieb, “Faster PET Reconstruction with a Stochastic Primal-Dual Hybrid Gradient Method,” in Proceedings of SPIE, 2017, vol. 10394, pp. 1–12.

[4] A. Chambolle and T. Pock, “A First-Order Primal-Dual Algorithm for Convex Problems with Applications to Imaging,” J. Math. Imaging Vis., vol. 40, no. 1, pp. 120–145, Dec. 2011.

[5] T. Pock and A. Chambolle, “Diagonal Preconditioning for First Order Primal-Dual Algorithms in Convex Optimization,” in Proceedings of the IEEE International Conference on Computer Vision, 2011, pp. 1762–1769.

[6] P. J. Markiewicz et al., “NiftyPET: a High-throughput Software Platform for High Quantitative Accuracy and Precision PET Imaging and Analysis,” Neuroinformatics, vol. 16, no. 1, pp. 95–115, 2018.

spdhg_pet's People

Contributors

mehrhardt avatar

Watchers

James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.