Side outputs#
There are cases where the output of a method is needed as the value of a parameter for a method further down the pipeline. For example, the output of a method that calculates the Centre of Rotation (CoR), that is required for a reconstruction method.
HTTomo provides a special syntax (loosely based on the syntax for references in GitHub Actions) for how such an output of a method needs to be defined and how to refer to that special output later.
Specifying the side output#
The output of some methods isn’t processed data, but rather supplementary
information to be used later in the pipeline. The given term for that supplementary
data is “side outputs”, and is what the side_outputs
parameter is for. As
an example, let us consider the following centering algorithm:
- method: find_center_vo
module_path: httomolibgpu.recon.rotation
parameters:
ind: null
smin: -50
smax: 50
srad: 6.0
step: 0.25
ratio: 0.5
drop: 20
id: centering
side_outputs:
cor: centre_of_rotation
One can see that side_outputs
here includes a single value cor
with
the centre_of_rotation
reference. The id
parameter here is needed to
refer to the method later.
Referring to the side output#
The purpose of side_outputs
is to refer to it later, when some method(s)
require the contained information in the reference. Consider this example where the
reconstruction method refers to the centering method’s side outputs. The required
information of Centre of Rotation (CoR) is stored in the reference
${{centering.side_outputs.centre_of_rotation}}
.
- method: FBP
module_path: httomolibgpu.recon.algorithm
parameters:
center: ${{centering.side_outputs.centre_of_rotation}}
filter_freq_cutoff: 1.1
recon_size: null
recon_mask_radius: null
There could be various configurations when this reference is required from other methods as well. We present more verbose Example of side outputs below.
Note
Side outputs and references to them are generated automatically with the YAML generator. Usually there is no need to modify them when editing a process list.
Example of side outputs#
Pipeline overview#
This pipeline is for reconstructing DFoV data which needs to be stitched into the traditional 180 degrees data. It demonstrates three cases where a method produces one or more side outputs, and a method later in the pipeline references them.
A rough outline of the three side outputs being used is:
the 360 centering method produces an “overlap” value as a side output, for the stitching method to use
the 360 centering method also produces a CoR value as a side output, for the recon method to use
the stats calculator method produces a global stats value as a side output, for the image saver method to use
Detailed look at side outputs usage#
Parameters for stitching are generated by find_center_360
, stored in side
outputs, and then used later in the sino_360_to_180
method. The
reconstruction method FBP
then refers to the found Centre of Rotation (CoR) for the
stitched dataset produced by find_center_360
. Finally, we also need to
extract the global statistics for normalisation of the data using the
calculate_stats
method when saving into images with the
save_to_images
method.
# Standard tomography loader for NeXus files
#-----------------------------------------------#
- method: standard_tomo
module_path: httomo.data.hdf.loaders
parameters:
data_path: entry1/tomo_entry/data/data
image_key_path: entry1/tomo_entry/instrument/detector/image_key
rotation_angles:
data_path: /entry1/tomo_entry/data/rotation_angle
# Automatic search for the centre of rotation and overlap to perform 360 to 180 degrees data stitching
#-----------------------------------------------#
- method: find_center_360
module_path: httomolibgpu.recon.rotation
parameters:
ind: mid # specify the vertical index (slice) for calculation. mid - middle
win_width: 10
side: null
denoise: true
norm: false
use_overlap: false
id: centering # method's id for future referencing (see reconstruction)
side_outputs: # method's side outputs include scalars and/or some auxiliary data output
cor: centre_of_rotation
overlap: overlap
side: side
overlap_position: overlap_position
# Remove dezingers (outliers) in the data
#-----------------------------------------------#
- method: remove_outlier
module_path: httomolibgpu.misc.corr
parameters:
dif: 0.1 # this might require optimisation
kernel_size: 3
# Normalisation of projection data with collected flats/darks.
#-----------------------------------------------#
- method: normalize
module_path: httomolibgpu.prep.normalize
parameters:
cutoff: 10.0
minus_log: true # set to false if Paganin method is used
nonnegativity: false
remove_nans: false
# Remove stripes in the data that can lead to ring artefacts in reconstruction
#-----------------------------------------------#
- method: remove_stripe_based_sorting
module_path: httomolibgpu.prep.stripe
parameters:
size: 11
dim: 1
# Convert 360 degrees data into 180 degrees data
#-----------------------------------------------#
- method: sino_360_to_180
module_path: httomolibgpu.misc.morph
parameters:
overlap: ${{centering.side_outputs.overlap}} # the reference to the found CoR.
rotation: right
- method: FBP
module_path: httomolibgpu.recon.algorithm
parameters:
center: ${{centering.side_outputs.centre_of_rotation}}
filter_freq_cutoff: 0.35
recon_size: null
recon_mask_radius: 0.95
save_result: true # save the hdf5 array
# Downsample the reconstructed data to smaller data
#-----------------------------------------------#
- method: data_resampler
module_path: httomolibgpu.misc.morph
parameters:
newshape: [500, 500]
axis: auto
interpolation: linear
# Calculate global statistics on the reconstructed volume (min/max needed specifically)
#-----------------------------------------------#
- method: calculate_stats
module_path: httomo.methods
parameters: {}
id: statistics
side_outputs:
glob_stats: glob_stats
# Rescaling the data into 8-bit unsigned integer for saving into tiffs
#-----------------------------------------------#
- method: rescale_to_int
module_path: httomolibgpu.misc.rescale
parameters:
perc_range_min: 5.0
perc_range_max: 95.0
bits: 8
glob_stats: ${{statistics.side_outputs.glob_stats}} # referring to min/max values of statistics
# Saving the rescaled data into tiffs
#-----------------------------------------------#
- method: save_to_images
module_path: httomolib.misc.images
parameters:
subfolder_name: images
axis: auto
file_format: tif
Please see below for a concise description of how each of the individual side outputs of methods are connected to the method using them:
find_center_360
produces a side output calledoverlap
that thesino_360_to_180
method uses.find_center_360
produces another side output calledcentre_of_rotation
that theFBP
method uses.calculate_stats
produces a side output calledglob_stats
that therescale_to_int
method uses.