an interface and some tools for computed tomography reconstruction
Project description
CTRECON: Some basic simulation tools for CT scanning
More than "fast" or "efficient", I'm trying to bolt an interface on that feels intuitive and reusable. Something I want to reach for when developing a question. The implemented math that backs this stuff should be swappable over time as better implementations are developed.
Environment setup
The package is available exclusively via pip. We strongly recommend using an environment manager (virtualenv, conda, micromamba, uv, etc.) to track and manage your dependencies.
pip install ctrecon
If you get a warning that matplotlib cannot show the window, you may also need
to install a different backend for matplotlib (e.g., pip install PtQt5).
Refer to the matplotlib
documentation
if you encounter any issues.
Hello world example
This example comes from the package's "unit tests". They're not actually unit tests because they're interactive, but they're great sanity checks to see if and how the package runs on your computer:
from ctrecon import phantoms, scanners, tools, images
if __name__ == "__main__":
target_support_size = 50 # cm
# These parameters are for a rough approximation
# of a clinical Definition AS 64
R_si = 59.5 # cm
R_sd = 109.5 # cm
n_channels = 736 # number of detector elements
det_size = target_support_size / n_channels
phantom = phantoms.DebugPhantom()
scanner = scanners.PencilBeamScanner(59.5, 109.5, n_channels, det_size)
sinogram, projection_metadata = scanner.scan(phantom)
center_x = 0.0
center_y = 0.0
fov = 30.0
N = 256
sinogram_noisy = tools.add_noise(sinogram, 1000)
image = images.DebugImage(center_x, center_x, fov, N)
image.set_debug_info(phantom, sinogram, sinogram_noisy, scanner)
image.reconstruct(scanner, sinogram, projection_metadata)
image.display()
The idea is to apply some sane logical structure the many components required to go from simulated phantom, to CT sinogram, and back to image. My hope is that using the library feels like describing the experiment you're doing with normal language, and your code makes it feel obvious what experiment is being done.
phantomscontains prebaked phantoms, as well as the tools to build your ownscannerscontains prebaked scan geometries, and the interface classes (ScanGeometry) to build your own (and preserve compatibility with the rest of the toolchain).imagescontains different image geometriestoolsonly containsadd_noisefor now, which may migrate elsewhere at some point
BYO Phantom
This is the full definition of our DebugPhantom:
class DebugPhantom(Phantom):
def __init__(self):
# tuneable elements, units are cm
bg_attenuation = 0.0192
ph_radius = 10.0
elements = []
bg = Circle(0, 0, ph_radius, bg_attenuation)
findable_insert_1 = Circle(0, 5, 3.0, 0.04)
findable_insert_2 = Circle(5, 0, 1.5, 0.04)
# Intuitively, we draw from "bg" -> "fg"
elements.append(bg)
elements.append(findable_insert_1)
elements.append(findable_insert_2)
# When raycasting, its most efficient to intersect the fg first
elements.reverse()
# Save the elements of the phantom
self.circles = elements
The concept is that we basically draw objects into the world space. We calculate sinograms via raycasting and each step iterates through the list of objects to check if we're inside. For that increment, we utilize the attenuation of the first object in the list that we encounter and move on.
The same phantom can be completely described via CSV as well. Note that the row order sets the object "precedence" in the sinogram generation process.
debug_phantom.csv:
5,0,1.5,0.04
0,5,3.0,0.04
0,0,10.0,0.0192
You can save a phantom a CSV file:
from ctrecon import phantoms
ph = phantoms.DebugPhantom()
ph.to_csv('debug_phantom.csv')
A phantom can be instantiate from such a CSV:
debug_ph = Phantom.from_csv("debug_phantom.csv")
This at least describes phantoms in a mostly portable manner. Free to use in other places and between research groups.
Only circles are supported for now. I hope to extend to other shapes in the near future.
Scanning a phantom
scanners provides basic geometries and specific implementations of some geometries.
In keeping with our goal of language-like interaction to perform a scan:
ph = phantoms.Debug()
scanner = scanners.PencilBeam(...)
sinogram, metadata = scanner.scan(ph)
If a scanner is implemented correctly within our library, these three lines (using any phantom we provide and any scanner) must produce a valid sinogram. Moreover, the defaults should hopefully suffice for many applications.
The reason this can work is that we follow the philosophy of "pick good
defaults" and require the scanner implementor to define a default_protocol.
class Scanner:
def default_protocol(self) -> Protocol:
raise NotYetImplemented
However specific scan protocols (including truncated scanning, sparse view, etc.) are among some of the most important ongoing research questions in the field.
Protocols
While scanners record physical details about the relationships between x-ray source and detector, as well as detector shape, etc., it doesn't desribe how that hardware should be used to scan an object.
How may projections we should acquire, at which angles, even "unconstrained"
acquisitions coming from random locations, etc. is all modeled via an
intermediate Trajectory data structure that represents a scans geometric
intent in an abstract sense so that it can be applied to multiple specific
geometries.
Fundamentally, the Scanner object represents the physical constraints between
the source and the detector.
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
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 ctrecon-0.1.2.tar.gz.
File metadata
- Download URL: ctrecon-0.1.2.tar.gz
- Upload date:
- Size: 40.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5dae691c721a810ec1bed2f47935f6595deeda42dbee5a3910114146f5dd94d3
|
|
| MD5 |
87d0a9ef9d8ce31e7b8866f30e383a5b
|
|
| BLAKE2b-256 |
10e58125567c712d7f616f8bcbfc830486bce9db8135c58d620505f21f9fa8dd
|
File details
Details for the file ctrecon-0.1.2-py3-none-any.whl.
File metadata
- Download URL: ctrecon-0.1.2-py3-none-any.whl
- Upload date:
- Size: 43.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4dfa2572aa95034ef5b5c1dde35e611333d5ad8332a4b4c2b9f5e61e5533e8cf
|
|
| MD5 |
05c1549c7f2ca17128b19f88c44552fd
|
|
| BLAKE2b-256 |
f14f19b44cecd6ff7401886e8d3c9b1d25fc6a1c94588612ef07db6e1a7eee5a
|