A CUDA-based library for computed tomography (CT) projection and reconstruction with differentiable operators
Project description
DiffCT: Differentiable Computed Tomography Operators
A high-performance, CUDA-accelerated library for circular orbits CT reconstruction with end-to-end differentiable operators, enabling advanced optimization and deep learning integration.
โญ Please star this project if you find it useful!
โจ Features
- Fast: CUDA-accelerated projection and backprojection operations
- Differentiable: End-to-end gradient propagation for deep learning workflows
๐ Supported Geometries
- Parallel Beam: 2D parallel-beam geometry
- Fan Beam: 2D fan-beam geometry
- Cone Beam: 3D cone-beam geometry
๐งฉ Code Structure
diffct/
โโโ diffct/
โ โโโ __init__.py # Package initialization
โ โโโ non_differentiable.py # CUDA implementation
โ โโโ differentiable.py # Differentiable implementation
โโโ examples/ # Example usages
โ โโโ non_differentiable # Non-differentiable examples
โ โ โโโ parallel.py
โ โ โโโ fan.py
โ โ โโโ cone.py
โ โโโ differentiable # Differentiable examples
โ โ โโโ parallel.py
โ โ โโโ fan.py
โ โ โโโ cone.py
โโโ pyproject.toml # Project metadata
โโโ README.md # README
โโโ LICENSE # License
โโโ requirements.txt # Dependencies
๐ Quick Start
Prerequisites
- CUDA-capable GPU
- Python 3.10+
- PyTorch, NumPy, Numba with CUDA support
Installation
# Create and activate environment
conda create -n diffct python=3.10
conda activate diffct
# Install CUDA support
conda install cudatoolkit
git clone https://github.com/sypsyp97/diffct.git
cd diffct
pip install -r requirements.txt
pip install diffct
๐ Usage Examples
Non-Differentiable CUDA Implementation
import torch
import numpy as np
from diffct.non_differentiable import forward_parallel_2d, back_parallel_2d
# Create phantom
phantom = shepp_logan_2d(256, 256)
# Configure geometry
angles = np.linspace(0, 2*np.pi, 360, endpoint=False)
# Forward projection
sinogram = forward_parallel_2d(
phantom,
num_views=360,
num_detectors=512,
detector_spacing=1.0,
angles=angles,
step=0.5
)
# Reconstruction
sinogram_filtered = ramp_filter(torch.from_numpy(sinogram)).numpy()
reconstruction = back_parallel_2d(
sinogram_filtered,
Nx=256, Ny=256,
detector_spacing=1.0,
angles=angles,
step=0.5
) / 360 # Normalize by number of angles
Differentiable Implementation
import torch
from diffct.differentiable import ParallelProjectorFunction, ParallelBackprojectorFunction
# Setup device
device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')
# Create phantom tensor with gradient tracking
phantom = torch.tensor(shepp_logan_2d(256, 256), device=device, requires_grad=True)
angles = torch.linspace(0, 2*np.pi, 360, device=device)
# Forward projection
sinogram = ParallelProjectorFunction.apply(
phantom,
angles,
num_detectors=512,
detector_spacing=1.0,
step_size=0.5
)
# Filtered backprojection
sinogram_filtered = ramp_filter(sinogram).requires_grad_(True)
reconstruction = ParallelBackprojectorFunction.apply(
sinogram_filtered,
angles,
detector_spacing=1.0,
step_size=0.5,
Nx=256, Ny=256
) / 360 # Normalize
# Compute loss and gradients
loss = torch.mean((reconstruction - phantom)**2)
loss.backward() # Gradients flow through the entire pipeline
๐ HU Calibration
-
With Original Image:
- Normalize image before forward projection
- Apply inverse transformation to restore HU range
- Consider histogram matching if needed
-
With Sinogram Only:
- Reconstruct to get raw values
- Calibrate using reference points (air โ -1000 HU, water โ 0 HU)
- Or use calibration markers with known attenuation coefficients
๐ Citation
If you use this library in your research, please cite:
@software{DiffCT2025,
author = {Yipeng Sun},
title = {DiffCT: Differentiable Computed Tomography
Reconstruction with CUDA},
year = 2025,
publisher = {Zenodo},
doi = {10.5281/zenodo.14999333},
url = {https://doi.org/10.5281/zenodo.14999333}
}
๐ License
This project is licensed under the Apache 2.0 - see the LICENSE file for details.
๐ Acknowledgements
This project was highly inspired by:
Issues and contributions are welcome!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file diffct-1.1.3.tar.gz.
File metadata
- Download URL: diffct-1.1.3.tar.gz
- Upload date:
- Size: 18.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.16
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bf7bf8402d1066003b11780410f6aaeb9dfa4b5414b63da3f8beb91b3f0101d3
|
|
| MD5 |
c7e72888b338f61fc14cf82bfe555b09
|
|
| BLAKE2b-256 |
4f5620ec912413a65c71de79374eb0eacc71cde2f163545cf9ddf89497edeb19
|
File details
Details for the file diffct-1.1.3-py2.py3-none-any.whl.
File metadata
- Download URL: diffct-1.1.3-py2.py3-none-any.whl
- Upload date:
- Size: 15.9 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.16
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3c89098f7cb0d866f82faaf20e3efa79c014c7cabac7f7a204917d5166e6908d
|
|
| MD5 |
f8af6aa1cfd56973c9b8a375c721cebf
|
|
| BLAKE2b-256 |
1f8eaa0f25b3ddb6c24d130dc0881dc53211e5e66a5a850ca986a5088af89b37
|