OpenMP and CUDA libraries + python interface for 3D Joseph non-TOF and TOF forward and back projectors.
This project provides OpenMP and CUDA implementations and a python interface of 3D Joseph non-TOF and TOF forward and back projectors that can be e.g. used for image reconstruction. The input to the projectors are a list of start and end points for line of responses (LORs) such that they are very flexible and suitable for sinogram and listmode processing.
If you are using parallelproj, we recommend to read and cite our publication
- G. Schramm, K. Thielemans: "PARALLELPROJ - An open-source framework for fast calculation of projections in tomography", Front. Nucl. Med., Volume 3 - 2023, doi: 10.3389/fnume.2023.1324562, link to paper, link to arxiv version
Please refer to the official documentation here.
- cmake>=3.16 (3.16 version needed to detect CUDA correctly), we recommend to use cmake>=3.23
- a recent c compiler with OpenMP support (tested with gcc, msvc and clang)
- cuda toolkit (optional, tested with >= 10)
Notes
- If cuda is not available on the build system, the build of the cuda library is skipped (only the C/OpenMP library is build)
- If you are building on a recent version of Ubuntu with cuda, we recommend to use cuda >= 11.7. See here why.
We use CMake to auto generate a Makefile / Visual Studio project file which is used to compile the libraries. Make sure that cmake and the desired C compiler are on the PATH. The CMakeLists.txt is configured to search for CUDA. If CUDA is not present, compilation of the CUDA lib is skipped.
To build and install the libraries execute:
cd my_project_dir
mkdir build
cd build
cmake ..
cmake --build . --target install --config release
where my_project_dir
is the directory that contains this file and the CMakeLists.txt file.
Note that for the default installation directory, you usually need admin priviledges.
To change the install directory, replace the 1st call to cmake by
cmake -DCMAKE_INSTALL_PREFIX=/foo/bar/myinstalldir ..
To build the documentation (doxygen required) run
cmake --build . --target docs
To run all unit tests execute:
ctest -VV
To install the python wrappers, make sure that the environment variable linking to the installed path (/foo/bar/myinstalldir
) is added to the .profile
export PARALLELPROJ_C_LIB="/foo/bar/myinstalldir/lib/libparallelproj_c"
export PARALLELPROJ_CUDA_LIB="/foo/bar/myinstalldir/lib/libparallelproj_cuda"
And run the python script in the right python virtual environment, in this root folder (my_project_dir
)
pip install -e .
If you have CUDA available on your system (even if there is no physical CUDA GPU),
the default for CMAKE_CUDA_ARCHITECTURES
depends on the cmake version you are using.
-
cmake version >= 3.23: If you are using cmake >= 3.23, then by default
CMAKE_CUDA_ARCHITECTURES=all
which means that the code is build for all CUDA architectures. -
3.16 <= cmake version < 3.23: If you are using cmake < 3.23, then the default of
CMAKE_CUDA_ARCHITECTURES
is set to the architecture that is present on your system. This means that if you are compiling on a system without physical CUDA GPU and using cmake < v3.23, you have to set it manually, e.g. via-DCMAKE_CUDA_ARCHITECTURES=75
.