reconstruction: reconstruction algorithm¶
Warning
This module is known to be buggy in version 0.6: Do NOT use it without having checked it provides proper results
- 
class 
silx.image.reconstruction.ReconstructionAlgorithm(sino_shape, slice_shape=None, axis_position=None, angles=None, ctx=None, devicetype='all', platformid=None, deviceid=None, profile=False)[source]¶ A parent class for all iterative tomographic reconstruction algorithms
Parameters: - sino_shape – shape of the sinogram. The sinogram is in the format (n_b, n_a) where n_b is the number of detector bins and n_a is the number of angles.
 - slice_shape – Optional, shape of the reconstructed slice. By default, it is a square slice where the dimension is the “x dimension” of the sinogram (number of bins).
 - axis_position – Optional, axis position. Default is (shape[1]-1)/2.0.
 - angles – Optional, a list of custom angles in radian.
 - ctx – actual working context, left to None for automatic initialization from device type or platformid/deviceid
 - devicetype – type of device, can be “CPU”, “GPU”, “ACC” or “ALL”
 - platformid – integer with the platform_identifier, as given by clinfo
 - deviceid – Integer with the device identifier, as given by clinfo
 - profile – switch on profiling to be able to profile at the kernel level, store profiling elements (makes code slightly slower)
 
- 
class 
silx.image.reconstruction.SIRT(sino_shape, slice_shape=None, axis_position=None, angles=None, ctx=None, devicetype='all', platformid=None, deviceid=None, profile=False)[source]¶ A class for the SIRT algorithm
Parameters: - sino_shape – shape of the sinogram. The sinogram is in the format (n_b, n_a) where n_b is the number of detector bins and n_a is the number of angles.
 - slice_shape – Optional, shape of the reconstructed slice. By default, it is a square slice where the dimension is the “x dimension” of the sinogram (number of bins).
 - axis_position – Optional, axis position. Default is (shape[1]-1)/2.0.
 - angles – Optional, a list of custom angles in radian.
 - ctx – actual working context, left to None for automatic initialization from device type or platformid/deviceid
 - devicetype – type of device, can be “CPU”, “GPU”, “ACC” or “ALL”
 - platformid – integer with the platform_identifier, as given by clinfo
 - deviceid – Integer with the device identifier, as given by clinfo
 - profile – switch on profiling to be able to profile at the kernel level, store profiling elements (makes code slightly slower)
 
Warning
This is a beta version of the SIRT algorithm. Reconstruction fails for at least on CPU (Xeon E3-1245 v5) using the AMD opencl implementation.
- 
compute_preconditioners()[source]¶ Create a diagonal preconditioner for the projection and backprojection operator. Each term of the diagonal is the sum of the projector/backprojector along rows [1], i.e the projection/backprojection of an array of ones.
- [1] Jens Gregor and Thomas Benson,
 - Computational Analysis and Improvement of SIRT, IEEE transactions on medical imaging, vol. 27, no. 7, 2008
 
- 
class 
silx.image.reconstruction.TV(sino_shape, slice_shape=None, axis_position=None, angles=None, ctx=None, devicetype='all', platformid=None, deviceid=None, profile=False)[source]¶ A class for reconstruction with Total Variation regularization using the Chambolle-Pock TV reconstruction algorithm.
Parameters: - sino_shape – shape of the sinogram. The sinogram is in the format (n_b, n_a) where n_b is the number of detector bins and n_a is the number of angles.
 - slice_shape – Optional, shape of the reconstructed slice. By default, it is a square slice where the dimension is the “x dimension” of the sinogram (number of bins).
 - axis_position – Optional, axis position. Default is (shape[1]-1)/2.0.
 - angles – Optional, a list of custom angles in radian.
 - ctx – actual working context, left to None for automatic initialization from device type or platformid/deviceid
 - devicetype – type of device, can be “CPU”, “GPU”, “ACC” or “ALL”
 - platformid – integer with the platform_identifier, as given by clinfo
 - deviceid – Integer with the device identifier, as given by clinfo
 - profile – switch on profiling to be able to profile at the kernel level, store profiling elements (makes code slightly slower)
 
Warning
This is a beta version of the Chambolle-Pock TV algorithm. Reconstruction fails for at least on CPU (Xeon E3-1245 v5) using the AMD opencl implementation.
- 
compute_preconditioners()[source]¶ Create a diagonal preconditioner for the projection and backprojection operator. Each term of the diagonal is the sum of the projector/backprojector along rows [2], i.e the projection/backprojection of an array of ones.
- [2] T. Pock, A. Chambolle,
 - Diagonal preconditioning for first order primal-dual algorithms in convex optimization, International Conference on Computer Vision, 2011