Difference between revisions of "Registration:Resampling"
(28 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
+ | *[[Slicer3:Registration|back to Slicer Registration Portal Page]] | ||
+ | *[[Documentation-3.6|back to Slicer Documentation]] | ||
+ | *[http://na-mic.org/Wiki/index.php/Projects:RegistrationDocumentation:UseCaseInventory Back To Slicer Registration Case Library] | ||
+ | |||
+ | |||
= Resampling in 3D Slicer = | = Resampling in 3D Slicer = | ||
{| style="color:#000000; background-color:#aaaaaa;" cellpadding="10" cellspacing="0" border="0" | {| style="color:#000000; background-color:#aaaaaa;" cellpadding="10" cellspacing="0" border="0" | ||
Line 11: | Line 16: | ||
= What we mean by ''Resampling'' = | = What we mean by ''Resampling'' = | ||
− | Resampling builds a new dataset (image, surface, fiducials etc.) from an existing one, but with a different orientation, resolution, field of view or aspect ratio. For example the last step in registering two images consists of two main steps: finding the transform and resampling according to this transform. So the last step in registration will be to resample the moving data according to a spatial transform function, and thereby generate a new and aligned image. Or changing the voxel size to something larger or smaller involves resampling. | + | '''Resampling''' builds a new dataset (image, surface, fiducials etc.) from an existing one, but with a different orientation, resolution, field of view or aspect ratio. For example the last step in registering two images consists of two main steps: finding the transform and resampling according to this transform. So the last step in registration will be to resample the moving data according to a spatial transform function, and thereby generate a new and aligned image. Or changing the voxel size to something larger or smaller involves resampling. |
− | [http://en.wikipedia.org/wiki/Resampling See Wikipedia for a more detailed definition]. | + | [http://en.wikipedia.org/wiki/Resampling See Wikipedia for a more detailed definition].<br> |
+ | '''Interpolation''' is the process of estimating the value of the data based on surrounding values. This is necessary because spatial realignment is unlikely to be in exact multiples of voxel sizes. Please pay attention to selecting the proper interpolation method for your data-type. For more detail on ''interpolation'' we recommend this [http://en.wikipedia.org/wiki/Interpolation Wikipedia article]. | ||
+ | ---- | ||
+ | [[Image:Resampling DecisionMatrix.png|800px|left|Resampling Decision Matrix]] | ||
+ | <br> | ||
+ | ''Resampling decision matrix, use to find the appropriate resampling tool given your input-data and desired functionality. Note that some modules listed, although performing functions related to resampling, do '''not''' produce an output volume. | ||
+ | <br> | ||
= Resampling in Place: Change Resolution or Field of View= | = Resampling in Place: Change Resolution or Field of View= | ||
− | *The | + | *The [[Modules:CropVolume-Documentation-3.6|'''Crop Volume''']] module lets you clip away the image data outside an interactively defined 3D box. Such ''cropping'' is very useful to focus automated processing (e.g. registration, segmentation) onto a region of interest or reduce memory usage and speed up performance. The cropping includes a resampling that allows to change the resolution (''spacing'') of the result image at the same time. |
− | *The [[Modules:ResampleVolume-Documentation-3.6|'''Resample Scalar Volume''']] | + | *The [[Modules:ResampleVolume-Documentation-3.6|'''Resample Scalar Volume''']] module changes resolution (''spacing'') of an image, allowing several interpolation options for different data types. This is the method of choice if you wish to increase or decrease the number of voxels per mm or make the voxel size isotropic. You need to specify the desired voxel size in mm. If you do not know the current voxel size of your image, go to the ''Info'' tab in the [[Modules:Volumes-Documentation-3.6|Volumes]] module. |
+ | *The [[Modules:ResampleVolumeBatch-Documentation-3.6|'''Resample Scalar Volume Batch Make''']] module is the ''batch'' version of the above ''Resample Scalar Volume'' module. Use this if you have many image files that need to have their resolution changed/adjusted. The new resampled images will be written back out to a specified directory. | ||
+ | *The [[Modules:CastImage-Documentation-3.6|'''Cast Image''']] module lets you change the underlying '''datatype''' of your image, e.g. change from ''floating point'' to an ''integer'' or vice versa. This will not perform an interpolation, since the number of image voxels stays the same, but may be necessary to prepare the image for some modules or to reduce the image (file) size. For example an image stored as ''float'' will need twice as much disk space than one stored as ''short'' and four times as much as a ''char''. | ||
+ | *The [[Modules:DiffusionTensorEstimation-Documentation-3.6|'''Diffusion Tensor Estimation''']] module will produce a new tensor image from raw diffusion (DWI) MRI. The new volume will be in the same orientation and resolution as the input DWI. There are three estimation methods available: least squares, weigthed least squares and non-linear estimation. | ||
+ | *The [[Modules:Model_Into_Label_Volume_Documentation-3.6|'''Model Into Label Volume''']] module will do the inverse of the Model Maker and generate a binary 3D labelmap image with non-zero values at the location of the surface. This will let you bring the information from surface models back into an ''implicit'' image format. You set the resampling options, i.e. the resolution of the result via a reference image. Note that it will not fill a closed model, but produce points at the surface only. | ||
+ | *The [[Modules:OrientImages-Documentation-3.6|'''Orient Images''']] module will sample the image data along a specified orientation scheme, such as axial/sagittal/coronal planes or RAS or LPI etc. Note that the slices are '''not''' interpolated, they are just reordered and/or permuted. The resulting volume will cover the original volume. Because the display is in physical space, you will not see an effect of this resampling in the viewer. | ||
+ | *The [[Modules:Volumes-Documentation-3.6|'''Volumes''']] module lets you adjust the physical voxel size of an image (Info Tab), but will not generate a new volume. The changes will take effect immediately and you should see adjustments in your slice views. To obtain a new resampled volume, use the [[Modules:ResampleVolume-Documentation-3.6|Resample Scalar Volume]] module described above. | ||
+ | *The [[Modules:BRAINSResample|'''BRAINSresample''']] module lets you resample your image to a new resolution (specified implicitly via a reference image), with choice of interpolation method and output datatype. | ||
+ | |||
= Resampling via a spatial transform = | = Resampling via a spatial transform = | ||
− | *The [[Modules:ResampleScalarVectorDWIVolume-Documentation-3.6|'''Resample | + | *The [[Modules:ResampleScalarVectorDWIVolume-Documentation-3.6|'''Resample Scalar/Vector/DWI Volume''']] Module sends both scalar and vector images through a transform. Several interpolation options. |
− | *The ''Harden Transforms'' function in the Data Module | + | *The ''Harden Transforms'' function (context menu via the right mouse button) in the [[Modules:Data-Documentation-3.6|'''Data''' Module]] can also be used to resample an image or fiducial set through a '''linear''' transform. |
+ | *The [[Modules:ACPCTransform-Documentation-3.6|'''AC-PC Transform''']] module lets you realign your brain image along the anterior-posterior commissure and interhemispheral midline. You (manually) select fiducials to define these points. An output transform is generated that you can then apply to the image using the resampling tools described here. | ||
+ | *The main registration modules ( [[Modules:AffineRegistration-Documentation-3.6|Affine Registration]], [[Modules:RegisterImages-Documentation-3.6|Expert Automated Registration]], [[Modules:DeformableB-SplineRegistration-Documentation-3.6|Deformable B-Spline Registration]], [[Modules:RegisterImagesMultiRes-Documentation-3.6|Multires Affine Registration]], [[Modules:PythonSurfaceICPRegistration-Documentation-3.6|Surface Registration]], [[ Modules:TransformFromFiducials-Documentation-3.6|Fiducial Alignment]] etc. modules all contain a resampling option, i.e. they offer to produce a direct result volume, which includes a resampling step. In most cases the interpolation is linear. If you wish for more control over how the resampling is performed (e.g. select a different interpolator or output size or voxel size), select the registration module's option to generate an output/saved transform and then use one of the dedicated resampling modules described here to generate the new volume. The exception are modules which do '''not''' (yet) offer a transform output (e.g. Fast Nonrigid BSpline); for those you must use the module-specific resampling options to generate a result image. | ||
+ | *The [[Modules:BRAINSResample|'''BRAINSresample''']] module supports applying linear transforms and deformation fields to an image, with choice of interpolation method and output datatype. | ||
+ | *The [[Modules:RegisterImages-Documentation-3.6|'''Expert Automated Registration''']] module offers pure resampling from a given transform: select ''None'' for initialization and ''None'' for registration, specify the transform to apply under ''Load Transform'' and set the interpolation type under ''Advanced Registration Parameters''. | ||
+ | |||
= Resampling Vector- and Tensor-Data = | = Resampling Vector- and Tensor-Data = | ||
+ | *The [[Modules:ResampleScalarVectorDWIVolume-Documentation-3.6|'''Resample ResampleScalarVectorDWIVolume''']] Module is the method of choice to realign scalar, vector or diffusion weighted data along a given transform. It supports both linear and nonlinear transforms as well as deformation fields. Note that tensor data, such as DTI has a separate volume (below). | ||
+ | *The [[Modules:ResampleDTIVolume-Documentation-3.6|'''Resample DTI Volume''']] module is designed specifically for reorienting diffusion tensor MRI data. It supports both linear and nonlinear transforms as well as deformation fields. Note that simply sending each component of a DTI tensor through the transform separately would yield an '''incorrect''' result. This module will transform the vector/tensor data correctly. | ||
= Resampling Surface- and Model-Data = | = Resampling Surface- and Model-Data = | ||
− | *The [[Modules:ModelTransform-Documentation-3.6|'''Model Transform''']] Module reorients your surface model based on a transform. | + | *The [[Modules:ModelTransform-Documentation-3.6|'''Model Transform''']] Module reorients your surface model based on a transform. It creates a new model which is a transformed version of the input polygonal model |
− | + | *The [[Modules:Model Into Label Volume Documentation-3.6|'''Modules:Model Into Label Volume''']] module will resample a model back into a labelmap (outline, non-filled). | |
− | + | *The [[Modules:PolyDataToLabelmap-Documentation-3.6|'''PolyData To Labelmap''']] module will resample a model back into a labelmap while filling the interior. | |
− |
Latest revision as of 14:56, 18 May 2010
Home < Registration:Resampling- back to Slicer Registration Portal Page
- back to Slicer Documentation
- Back To Slicer Registration Case Library
Contents
Resampling in 3D Slicer
Several distinct tools are available within 3D Slicer for resampling image data to change orientation, resolution or field of view. The organization below is intended to help you choose the best module for your task Note that there are also many related functions that change aspects of the image without requiring a resampling, e.g. changing the aspect ratio or slice view orientation. They are listed in a separate category below. |
Consider adding your case to the library: If your resampling task is related to a registration problem, we can (for 2010-2011) offer you direct consulting: If we can add your (anonymized) case to the Library, we will assist you with registering/resampling by processing your case and providing step-by-step instructions and best-practice tips. See here for details. |
What we mean by Resampling
Resampling builds a new dataset (image, surface, fiducials etc.) from an existing one, but with a different orientation, resolution, field of view or aspect ratio. For example the last step in registering two images consists of two main steps: finding the transform and resampling according to this transform. So the last step in registration will be to resample the moving data according to a spatial transform function, and thereby generate a new and aligned image. Or changing the voxel size to something larger or smaller involves resampling.
See Wikipedia for a more detailed definition.
Interpolation is the process of estimating the value of the data based on surrounding values. This is necessary because spatial realignment is unlikely to be in exact multiples of voxel sizes. Please pay attention to selecting the proper interpolation method for your data-type. For more detail on interpolation we recommend this Wikipedia article.
Resampling decision matrix, use to find the appropriate resampling tool given your input-data and desired functionality. Note that some modules listed, although performing functions related to resampling, do not produce an output volume.
Resampling in Place: Change Resolution or Field of View
- The Crop Volume module lets you clip away the image data outside an interactively defined 3D box. Such cropping is very useful to focus automated processing (e.g. registration, segmentation) onto a region of interest or reduce memory usage and speed up performance. The cropping includes a resampling that allows to change the resolution (spacing) of the result image at the same time.
- The Resample Scalar Volume module changes resolution (spacing) of an image, allowing several interpolation options for different data types. This is the method of choice if you wish to increase or decrease the number of voxels per mm or make the voxel size isotropic. You need to specify the desired voxel size in mm. If you do not know the current voxel size of your image, go to the Info tab in the Volumes module.
- The Resample Scalar Volume Batch Make module is the batch version of the above Resample Scalar Volume module. Use this if you have many image files that need to have their resolution changed/adjusted. The new resampled images will be written back out to a specified directory.
- The Cast Image module lets you change the underlying datatype of your image, e.g. change from floating point to an integer or vice versa. This will not perform an interpolation, since the number of image voxels stays the same, but may be necessary to prepare the image for some modules or to reduce the image (file) size. For example an image stored as float will need twice as much disk space than one stored as short and four times as much as a char.
- The Diffusion Tensor Estimation module will produce a new tensor image from raw diffusion (DWI) MRI. The new volume will be in the same orientation and resolution as the input DWI. There are three estimation methods available: least squares, weigthed least squares and non-linear estimation.
- The Model Into Label Volume module will do the inverse of the Model Maker and generate a binary 3D labelmap image with non-zero values at the location of the surface. This will let you bring the information from surface models back into an implicit image format. You set the resampling options, i.e. the resolution of the result via a reference image. Note that it will not fill a closed model, but produce points at the surface only.
- The Orient Images module will sample the image data along a specified orientation scheme, such as axial/sagittal/coronal planes or RAS or LPI etc. Note that the slices are not interpolated, they are just reordered and/or permuted. The resulting volume will cover the original volume. Because the display is in physical space, you will not see an effect of this resampling in the viewer.
- The Volumes module lets you adjust the physical voxel size of an image (Info Tab), but will not generate a new volume. The changes will take effect immediately and you should see adjustments in your slice views. To obtain a new resampled volume, use the Resample Scalar Volume module described above.
- The BRAINSresample module lets you resample your image to a new resolution (specified implicitly via a reference image), with choice of interpolation method and output datatype.
Resampling via a spatial transform
- The Resample Scalar/Vector/DWI Volume Module sends both scalar and vector images through a transform. Several interpolation options.
- The Harden Transforms function (context menu via the right mouse button) in the Data Module can also be used to resample an image or fiducial set through a linear transform.
- The AC-PC Transform module lets you realign your brain image along the anterior-posterior commissure and interhemispheral midline. You (manually) select fiducials to define these points. An output transform is generated that you can then apply to the image using the resampling tools described here.
- The main registration modules ( Affine Registration, Expert Automated Registration, Deformable B-Spline Registration, Multires Affine Registration, Surface Registration, Fiducial Alignment etc. modules all contain a resampling option, i.e. they offer to produce a direct result volume, which includes a resampling step. In most cases the interpolation is linear. If you wish for more control over how the resampling is performed (e.g. select a different interpolator or output size or voxel size), select the registration module's option to generate an output/saved transform and then use one of the dedicated resampling modules described here to generate the new volume. The exception are modules which do not (yet) offer a transform output (e.g. Fast Nonrigid BSpline); for those you must use the module-specific resampling options to generate a result image.
- The BRAINSresample module supports applying linear transforms and deformation fields to an image, with choice of interpolation method and output datatype.
- The Expert Automated Registration module offers pure resampling from a given transform: select None for initialization and None for registration, specify the transform to apply under Load Transform and set the interpolation type under Advanced Registration Parameters.
Resampling Vector- and Tensor-Data
- The Resample ResampleScalarVectorDWIVolume Module is the method of choice to realign scalar, vector or diffusion weighted data along a given transform. It supports both linear and nonlinear transforms as well as deformation fields. Note that tensor data, such as DTI has a separate volume (below).
- The Resample DTI Volume module is designed specifically for reorienting diffusion tensor MRI data. It supports both linear and nonlinear transforms as well as deformation fields. Note that simply sending each component of a DTI tensor through the transform separately would yield an incorrect result. This module will transform the vector/tensor data correctly.
Resampling Surface- and Model-Data
- The Model Transform Module reorients your surface model based on a transform. It creates a new model which is a transformed version of the input polygonal model
- The Modules:Model Into Label Volume module will resample a model back into a labelmap (outline, non-filled).
- The PolyData To Labelmap module will resample a model back into a labelmap while filling the interior.