tomophantom.artefacts
#
Modules to generate different imaging artefacts.
- tomophantom.artefacts.artefacts_mix(data: <np.ndarray>, **artefacts_dict: ~typing.Any) <np.ndarray> | list [source]#
- A module to generate and apply a mix of various typical imaging artefacts to add to the simulated data.
One can build various dictionaries with keywords arguments specified bellow and pass it to the function as: artefacts_mix(data, **noise_dict, **zingers, **etc).
DISCLAIMER: Note that most of the features are experimental and do not always reflect the accurate modelling of the real imaging artefacts.
- Parameters:
data (3D projection) – 2D or 3D numpy array (sinogram or 3D projection data).
shape (The input data must be of the following) – 2D sinogram (anglesDim, DetectorsHoriz),
data
**artefacts_dict (dict) – A dictionary with keyword arguments related to different artefact type.
- Keyword Arguments:
noise_type (str) – Define noise type as ‘Poisson’ or ‘Gaussian’.
noise_amplitude (int, float) – Photon flux for Poisson or variance for Gaussian noise.
noise_seed (int) – Seeds for noise generator. ‘None’ defines random generation.
noise_prelog (bool) – Set to True if pre-log (raw) data required.
zingers_percentage (float) – The amount of zingers (dead pixels, outliers) to be added to the data.
zingers_modulus (int) – Modulus to control the amount of 4/6 pixel clusters to be added.
stripes_percentage (float) – The amount of stripes in the data (rings in reconstruction).
stripes_maxthickness (int) – Maxthickness defines the maximal thickness of a stripe.
stripes_intensity (float) – Controls the intensity levels of stripes.
stripe_type (str) – Stripe types can be ‘partial’ or ‘full’.
stripes_variability (float) – Variability multiplier to incorporate the change of intensity in stripe.
datashifts_maxamplitude_pixel (int) – Controls pixel-wise (integer) misalignment in data.
datashifts_maxamplitude_subpixel (float) – Controls subpixel misalignment in data.
pve_strength (int) – The strength of partial volume effect, responsible for the limited resolution of a scanner.
fresnel_dist_observation (int) – The distance for observation for fresnel propagator.
fresnel_scale_factor (float) – Fresnel propagator scaling.
fresnel_wavelenght (float) – Fresnel propagator wavelength.
verbose (bool) – Make the output of modules verbose.
- Returns:
2D/3D numpy array with artefacts applied to input data. [np.ndarray, shifts]: a list of 2D/3D numpy array and simulated shifts.
- Return type:
np.ndarray
- tomophantom.artefacts.datashifts(data: <np.ndarray>, maxamplitude: int) list [source]#
Function to add random pixel shifts to 3D or 3D data as an offset for each angular position.
- Parameters:
data (3D projection) – 2D sinogram or 3D projection data. The input data must be of the following shape: 2D sinogram (anglesDim, DetectorsHoriz),
data
maxamplitude (int) – The misilighnment ammplitude. Defines the maximal amplitude of each shift in pixels.
- Returns:
2D or 3d data with misalignment and shifts vectors [data, shifts].
- Return type:
list
- tomophantom.artefacts.datashifts_subpixel(data: <np.ndarray>, maxamplitude: float) list [source]#
Function to add random sub-pixel shifts to 3D or 3D data as an offset for each angular position.
- Parameters:
data (3D projection) – 2D sinogram or 3D projection data. The input data must be of the following shape: 2D sinogram (anglesDim, DetectorsHoriz),
data
maxamplitude (float) – The misilighnment ammplitude. Defines the maximal amplitude of each shift.
- Returns:
2D or 3d data with misalignment and shifts vectors [data, shifts].
- Return type:
list
- tomophantom.artefacts.fresnel_propagator(data: <np.ndarray>, dist_observation: int, scale_factor: float, wavelenght: float) <np.ndarray> [source]#
- Fresnel propagator applied to data.
Adapted from the script by Adrián Carbajal-Domínguez, adrian.carbajal@ujat.mx
- Parameters:
data (3D projection) – 2D sinogram or 3D projection data. The input data must be of the following shape: 2D sinogram (anglesDim, DetectorsHoriz),
data
dist_observation (int) – The distance for obervation for fresnel propagator.
scale_factor (float) – Scaling.
wavelenght (float) – Wavelength.
- Returns:
2D or 3D data with propagation.
- Return type:
np.ndarray
- tomophantom.artefacts.noise(data: <np.ndarray>, sigma: int | float, noisetype: str, seed: bool = True, prelog: bool = False) list | <np.ndarray> [source]#
Adding random noise to data (adapted from LD-CT simulator)
- Parameters:
data (np.ndarray) – N-d array
sigma (Union[int, float]) – int for Poisson or float for Gaussian
noisetype (str) – ‘Gaussian’ or ‘Poisson’
seed (bool, optional) – Initiate random seed with True. Defaults to True.
prelog (bool, optional) – get raw data if true, returns a list [noisy, raw]!. Defaults to False.
- Returns:
N-d array
- Return type:
np.ndarray
- tomophantom.artefacts.pve(data: <np.ndarray>, pve_strength: int) <np.ndarray> [source]#
Applying Partial Volume effect (smoothing) to data.
- Parameters:
data (3D projection) – 2D sinogram or 3D projection data. The input data must be of the following shape: 2D sinogram (anglesDim, DetectorsHoriz),
data
pve_strength (int) – The level of smoothing, defined by kernel size.
- Raises:
ValueError – Smoothing kernel must be positive
- Returns:
Smoothed 2D or 3D data.
- Return type:
np.ndarray
- tomophantom.artefacts.stripes(data: <np.ndarray>, percentage: float, maxthickness: int, intensity_thresh: float, stripe_type: str, variability: float) <np.ndarray> [source]#
Function to add stripes (constant offsets) to sinograms or 3D projection data which results in rings in the reconstructed image.
- Parameters:
data (np.ndarray) – 2D sinogram (anglesDim, DetectorsHoriz) or 3D projection data (DetectorsVert, anglesDim, DetectorsHoriz).
percentage (float) – Percentage defines the amount of stripes in the data.
maxthickness (int) – Defines the maximal thickness of a stripe.
intensity_thresh (float) – Controls the intensity levels of stripes.
stripe_type (str) – Choose between ‘partial’ or ‘full’.
variability (float) – Variability multiplier to incorporate change of intensity in the stripe.
- Raises:
ValueError – Percentage is out of range.
ValueError – Thickness is out of range.
- Returns:
2D sinogram or 3D projection data with stripes
- Return type:
np.ndarray
- tomophantom.artefacts.zingers(data: <np.ndarray>, percentage: float, modulus: int) <np.ndarray> [source]#
- Adding zingers (zero single pixels or small 4 pixels clusters)
to sinograms or 6 voxels to 3D projection data.
- Parameters:
data (3D projection) – 2D sinogram or 3D projection data. The input data must be of the following shape: 2D sinogram (anglesDim, DetectorsHoriz),
data
percentage (float) – The amount of zingers to be added to the data.
modulus (int) – Modulus to control the amount of 4/6 pixel clusters to be added.
- Raises:
ValueError – Percentage is out of range.
ValueError – Modulus must be positive.
- Returns:
2D or 3D array with zingers.
- Return type:
np.ndarray