Difference between revisions of "Documentation:Nightly:Registration:RegistrationLibrary:RegLib C46"
From Slicer Wiki
m (Text replacement - "\[http:\/\/www\.slicer\.org\/slicerWiki\/index\.php\/([^ ]+) ([^]]+)]" to "$2") |
|||
(10 intermediate revisions by one other user not shown) | |||
Line 1: | Line 1: | ||
[[Documentation/Nightly/Registration/RegistrationLibrary|Back to Registration Library]] <br> | [[Documentation/Nightly/Registration/RegistrationLibrary|Back to Registration Library]] <br> | ||
− | + | = Slicer Registration Library Case #46: 2D Cine MRI of Breathing Cycle = | |
− | + | == Input == | |
{| style="color:#bbbbbb; " cellpadding="10" cellspacing="0" border="0" | {| style="color:#bbbbbb; " cellpadding="10" cellspacing="0" border="0" | ||
|[[Image:RegLib_C46_Thumb1.png|150px|lleft|this is the fixed reference image. All images are aligned into this space]] | |[[Image:RegLib_C46_Thumb1.png|150px|lleft|this is the fixed reference image. All images are aligned into this space]] | ||
Line 14: | Line 14: | ||
|} | |} | ||
− | == | + | == Description == |
− | + | We seek to study the motion of the lung during a breathing cycle by co-registering all of the images in a sequence with a reference, and then extract the motion from the registration displacement field. | |
− | == | + | == Modules Used == |
− | + | *[[Documentation/Nightly/Modules/BRAINSFit| ''General Registration (BRAINS)'']] | |
− | |||
− | |||
− | == | + | == Download (from NAMIC MIDAS) == |
− | * | + | <small>Note that the main registration processing for this case is done in batch mode via a shell script, and not in the main GUI. The mrb file below therefore includes only 2 out of the 200 frames of the whole series to illustrate the concept. To get the full dataset including solutions and script, download the zip file.</small> |
− | * | + | *[http://slicer.kitware.com/midas3/download/?items=119459 '''RegLib_C46.mrb'''] <br><small>(input data, reference + 1 slice only, Slicer mrb file. 0.6 MB) </small><br> |
+ | *[http://slicer.kitware.com/midas3/download/?items=119460 '''RegLib_C46_Data.zip''']<br><small>(input data + results, zip file with original DICOM + registration script. 65 MB). </small> | ||
− | == | + | == Keywords == |
− | + | MRI, lung, 2D, time-series, cine, deformation modeling | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | == | + | == Procedure == |
− | *'''Phase I: | + | *'''Phase I: run a pilot registration to determine optimal registration parameters''' |
#load reference image and one moving image from the series | #load reference image and one moving image from the series | ||
− | #open | + | #open the [[Documentation/Nightly/Modules/BRAINSFit|''General Registration (BRAINS)'' module]] |
− | + | ##set "ref_lung" as fixed and "moving_??" as moving image | |
− | ##set " | + | ###''Slicer BSpline Transform'' (create new transform, rename to: "Xf1_BSpline" or similar |
− | ### | + | ###''Output Image Volume'' create and rename new Volume, rename to "Moving_Xf1" |
− | + | ##''Initialization transform'': none | |
− | + | ##''Initialization transform mode'': off | |
− | ### | + | ##''Registration Phases'': select/check ''BSpline'' only |
− | ## | + | ##select/check ''Include BSpline registration phase'' |
− | ##Registration | + | ##''B-Spline Grid Size'': type "5,5,3" (note: even though we have a 2D image, we must select a grid size of at least 3 in the z-direction. But displacements will all be zero in that direction) |
##Leave all other settings at default | ##Leave all other settings at default | ||
− | ##click: Apply | + | ##click: Apply |
##adjust grid size until registration is acceptable | ##adjust grid size until registration is acceptable | ||
− | ##you can see the commandline text of the registration performed by opening the ''Window/Error Log'' window and clicking on ''BRAINSfit commandline input'' | + | ##you can see the commandline text of the registration performed by opening the ''Window/Error Log'' window and clicking on ''BRAINSfit commandline input''. This will show you how the text in the script should look like to replicate the registration in batch mode |
*'''Phase II: Batch Run''' | *'''Phase II: Batch Run''' | ||
+ | #check the provided bash shell script ("RegLib_C46_BatchReg.sh") | ||
+ | #via a TextEditor, modify the script to match your parameters. The default script looks like this: | ||
+ | #!/bin/bash | ||
+ | export SLICER4CLI=/Applications/Slicer.app/Contents/lib/Slicer-4.3/cli-modules | ||
+ | for aFile in "$@" | ||
+ | do | ||
+ | ROOT=${aFile%.*} | ||
+ | aMovingXForm=${ROOT}_BSpline.tfm | ||
+ | aMovingReg=${ROOT}_reg.nrrd | ||
+ | echo "registering $1 <-- $aFile via $aMovingXForm --> $aMovingReg" | ||
+ | ${SLICER4CLI}/BRAINSFit --fixedVolume $1 --movingVolume $aFile --outputVolume $aMovingReg --bsplineTransform $aMovingXForm --useBSpline --splineGridSize 5,5,3 --numberOfIterations 1500 | ||
+ | done | ||
+ | #replace the ''SLICER4CLI'' variable with your path to the Slicer application (shown is typical for MacOS) | ||
+ | #This script expects as the 1st argument the reference image "ref_lung" and all the moving images as subsequent arguments. Note that because we have DICOM images as input, each slice needs to be in a separate directory to be interpreted as separate images (by default, Slicer will interpret multiple DICOM files in the same directory as slices of a single image). | ||
#open a terminal window | #open a terminal window | ||
− | # | + | #call the script via (assuming directories are called "Reference" and "Moving_001" etc. : |
− | / | + | cd PATH/TO/DIRECTORY/WITH/DATA/AND/SCRIPT |
− | + | ./RegLib_C46_BatchReg.sh Reference/refLung_001.dcm Moving/*/*.dcm | |
− | + | #the script will write result transforms and images into the same moving directories | |
− | # | ||
− | |||
− | |||
− | |||
*'''Phase III: Evaluate Transform files''' | *'''Phase III: Evaluate Transform files''' | ||
− | ##upon completion, read the transform files with an editor and extract the displacements of interest | + | ##upon completion, read the transform files with an editor or prototyping platform (e.g. Matlab) and extract the displacements of interest |
##The ITK transform files describe displacements at the grid nodes, many of which are outside the region of interest. Because BRAINSfit pads the grid with 1 voxel, the grid returned is actually 8x8x8. We use only the plane (*,*,4) for analysis and discard the y-direction displacements, which as expected are all zero. | ##The ITK transform files describe displacements at the grid nodes, many of which are outside the region of interest. Because BRAINSfit pads the grid with 1 voxel, the grid returned is actually 8x8x8. We use only the plane (*,*,4) for analysis and discard the y-direction displacements, which as expected are all zero. | ||
− | ##for details on the ITK transform format see the [ | + | ##for details on the ITK transform format see the [[Slicer-3-6-FAQ#What_is_the_Meaning_of_.27Fixed_Parameters.27_in_the_transform_file_.28.tfm.29_of_a_BSpline_registration_.3F|'''FAQ''' here]] |
− | ##To obtain displacements at arbitrary coordinates, interpolate the transform into a deformation field, e.g. using this module (details [ | + | ##To obtain displacements at arbitrary coordinates, interpolate the transform into a deformation field, e.g. using this module (details [[Slicer-3-6-FAQ#How_can_I_convert_a_BSpline_transform_into_a_deformation_field.3F|FAQ here]]): |
− | |||
=== Registration Results=== | === Registration Results=== | ||
{| style="color:#bbbbbb; " cellpadding="10" cellspacing="0" border="0" | {| style="color:#bbbbbb; " cellpadding="10" cellspacing="0" border="0" | ||
|[[Image:RegLib_C46_Thumb2.gif|300px|lleft|moving input]] | |[[Image:RegLib_C46_Thumb2.gif|300px|lleft|moving input]] | ||
− | |[[Image: | + | |[[Image:RegLib_C46_registered.gif|300px|lleft|moving input after registration (only frames 1-27 shown)]] |
− | |||
|- | |- | ||
|unregistered moving series | |unregistered moving series | ||
|moving input after registration (only frames 1-27 shown) | |moving input after registration (only frames 1-27 shown) | ||
+ | |- | ||
+ | |[[Image:RegLib_C46_DisplacementField.gif|300px|lleft|deformation shown as displacement vectors (only frames 35-60 shown)]] | ||
+ | |[[Image:RegLib_C46_Displacements.png|300px|lleft|displacements]] | ||
+ | |- | ||
+ | |deformation shown as displacement vectors (only frames 35-60 shown) | ||
|[[Media:RegLib_C46_Displacements.pdf|displacements (PDF)]] | |[[Media:RegLib_C46_Displacements.pdf|displacements (PDF)]] | ||
|} | |} | ||
+ | == Discussion / Overall Strategy == | ||
+ | *because the torso is already well registered and does not move across the sequence, a global affine/rigid registration is of no use. Instead we seek to assess the internal displacements caused across the breathing cycle. We therefore choose a low-DOF BSpline model. | ||
+ | *Because the implementation of the BRAINSfit module used here expects a 3D volume, we choose a slightly larger grid and make it isotropic, although the 3rd dimension of the grid is not used. We expect the optimizer in the registration to not move outside the slice plane and simply return 0 deformations there. | ||
+ | *An alternative strategy would be to register each image to its immediate previous timepoint, and then integrating the displacements. This has the advantage that nonrigid registration tends to be better for smaller differences, but it bears the risk of accumulating error and hence a lower robustness. | ||
+ | *A related option to improve precision would be to initialize each registration with the result of the previous one. Unfortunately the BRAINSfit registration modules do not (yet) allow to initialize with anything other than an affine. | ||
+ | *The additional information/constraint, that the displacements defined by the series of registrations should describe a smooth motion that is contiguous and differentiable, has not been exploited in this approach. This could be done a posteriori by applying a temporal filter across the transforms or fitting an appropriate model curve to each node displacement. | ||
+ | *Overall strategy: | ||
+ | :#select one frame within the breathing cycle as reference frame | ||
+ | :#compute non-rigid BSpline registration of all images to the reference frame | ||
+ | :#extract the displacements of indiv. grid nodes and plot over time | ||
− | + | == Acknowledgments == | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
Thanks to Amir Owrangi and [http://www.imaging.robarts.ca/~gep Dr.Grace Parraga] from the [http://www.robarts.ca Robarts Institute] for sharing the registration problem and data. | Thanks to Amir Owrangi and [http://www.imaging.robarts.ca/~gep Dr.Grace Parraga] from the [http://www.robarts.ca Robarts Institute] for sharing the registration problem and data. |
Latest revision as of 02:34, 27 November 2019
Home < Documentation:Nightly:Registration:RegistrationLibrary:RegLib C46Contents
Slicer Registration Library Case #46: 2D Cine MRI of Breathing Cycle
Input
fixed image/target | moving image |
Description
We seek to study the motion of the lung during a breathing cycle by co-registering all of the images in a sequence with a reference, and then extract the motion from the registration displacement field.
Modules Used
Download (from NAMIC MIDAS)
Note that the main registration processing for this case is done in batch mode via a shell script, and not in the main GUI. The mrb file below therefore includes only 2 out of the 200 frames of the whole series to illustrate the concept. To get the full dataset including solutions and script, download the zip file.
- RegLib_C46.mrb
(input data, reference + 1 slice only, Slicer mrb file. 0.6 MB) - RegLib_C46_Data.zip
(input data + results, zip file with original DICOM + registration script. 65 MB).
Keywords
MRI, lung, 2D, time-series, cine, deformation modeling
Procedure
- Phase I: run a pilot registration to determine optimal registration parameters
- load reference image and one moving image from the series
- open the General Registration (BRAINS) module
- set "ref_lung" as fixed and "moving_??" as moving image
- Slicer BSpline Transform (create new transform, rename to: "Xf1_BSpline" or similar
- Output Image Volume create and rename new Volume, rename to "Moving_Xf1"
- Initialization transform: none
- Initialization transform mode: off
- Registration Phases: select/check BSpline only
- select/check Include BSpline registration phase
- B-Spline Grid Size: type "5,5,3" (note: even though we have a 2D image, we must select a grid size of at least 3 in the z-direction. But displacements will all be zero in that direction)
- Leave all other settings at default
- click: Apply
- adjust grid size until registration is acceptable
- you can see the commandline text of the registration performed by opening the Window/Error Log window and clicking on BRAINSfit commandline input. This will show you how the text in the script should look like to replicate the registration in batch mode
- set "ref_lung" as fixed and "moving_??" as moving image
- Phase II: Batch Run
- check the provided bash shell script ("RegLib_C46_BatchReg.sh")
- via a TextEditor, modify the script to match your parameters. The default script looks like this:
#!/bin/bash export SLICER4CLI=/Applications/Slicer.app/Contents/lib/Slicer-4.3/cli-modules for aFile in "$@" do ROOT=${aFile%.*} aMovingXForm=${ROOT}_BSpline.tfm aMovingReg=${ROOT}_reg.nrrd echo "registering $1 <-- $aFile via $aMovingXForm --> $aMovingReg" ${SLICER4CLI}/BRAINSFit --fixedVolume $1 --movingVolume $aFile --outputVolume $aMovingReg --bsplineTransform $aMovingXForm --useBSpline --splineGridSize 5,5,3 --numberOfIterations 1500 done
- replace the SLICER4CLI variable with your path to the Slicer application (shown is typical for MacOS)
- This script expects as the 1st argument the reference image "ref_lung" and all the moving images as subsequent arguments. Note that because we have DICOM images as input, each slice needs to be in a separate directory to be interpreted as separate images (by default, Slicer will interpret multiple DICOM files in the same directory as slices of a single image).
- open a terminal window
- call the script via (assuming directories are called "Reference" and "Moving_001" etc. :
cd PATH/TO/DIRECTORY/WITH/DATA/AND/SCRIPT ./RegLib_C46_BatchReg.sh Reference/refLung_001.dcm Moving/*/*.dcm
- the script will write result transforms and images into the same moving directories
- Phase III: Evaluate Transform files
- upon completion, read the transform files with an editor or prototyping platform (e.g. Matlab) and extract the displacements of interest
- The ITK transform files describe displacements at the grid nodes, many of which are outside the region of interest. Because BRAINSfit pads the grid with 1 voxel, the grid returned is actually 8x8x8. We use only the plane (*,*,4) for analysis and discard the y-direction displacements, which as expected are all zero.
- for details on the ITK transform format see the FAQ here
- To obtain displacements at arbitrary coordinates, interpolate the transform into a deformation field, e.g. using this module (details FAQ here):
Registration Results
unregistered moving series | moving input after registration (only frames 1-27 shown) |
deformation shown as displacement vectors (only frames 35-60 shown) | displacements (PDF) |
Discussion / Overall Strategy
- because the torso is already well registered and does not move across the sequence, a global affine/rigid registration is of no use. Instead we seek to assess the internal displacements caused across the breathing cycle. We therefore choose a low-DOF BSpline model.
- Because the implementation of the BRAINSfit module used here expects a 3D volume, we choose a slightly larger grid and make it isotropic, although the 3rd dimension of the grid is not used. We expect the optimizer in the registration to not move outside the slice plane and simply return 0 deformations there.
- An alternative strategy would be to register each image to its immediate previous timepoint, and then integrating the displacements. This has the advantage that nonrigid registration tends to be better for smaller differences, but it bears the risk of accumulating error and hence a lower robustness.
- A related option to improve precision would be to initialize each registration with the result of the previous one. Unfortunately the BRAINSfit registration modules do not (yet) allow to initialize with anything other than an affine.
- The additional information/constraint, that the displacements defined by the series of registrations should describe a smooth motion that is contiguous and differentiable, has not been exploited in this approach. This could be done a posteriori by applying a temporal filter across the transforms or fitting an appropriate model curve to each node displacement.
- Overall strategy:
- select one frame within the breathing cycle as reference frame
- compute non-rigid BSpline registration of all images to the reference frame
- extract the displacements of indiv. grid nodes and plot over time
Acknowledgments
Thanks to Amir Owrangi and Dr.Grace Parraga from the Robarts Institute for sharing the registration problem and data.