ITK
5.0.0
Insight Segmentation and Registration Toolkit
|
#include <itkInverseDisplacementFieldImageFilter.h>
Computes the inverse of a displacement field.
InverseDisplacementFieldImageFilter takes a displacement field as input and computes the displacement field that is its inverse. If the input displacement field was mapping coordinates from a space A into a space B, the output of this filter will map coordinates from the space B into the space A.
Given that both the input and output displacement field are represented as discrete images with pixel type vector, the inverse will be only an estimation and will probably not correspond to a perfect inverse. The precision of the inverse can be improved at the price of increasing the computation time and memory consumption in this filter.
The method used for computing the inverse displacement field is to subsample the input field using a regular grid and create Kerned-Base Spline in which the reference landmarks are the coordinates of the deformed point and the target landmarks are the negative of the displacement vectors. The kernel-base spline is then used for regularly sampling the output space and recover vector values for every single pixel.
The subsampling factor used for the regular grid of the input field will determine the number of landmarks in the KernelBased spline and therefore it will have a dramatic effect on both the precision of output displacement field and the computational time required for the filter to complete the estimation. A large subsampling factor will result in few landmarks in the KernelBased spline, therefore on fast computation and low precision. A small subsampling factor will result in a large number of landmarks in the KernelBased spline, therefore a large memory consumption, long computation time and high precision for the inverse estimation.
This filter expects both the input and output images to be of pixel type Vector.
Definition at line 65 of file itkInverseDisplacementFieldImageFilter.h.
Public Types | |
using | ConstPointer = SmartPointer< const Self > |
using | IndexType = typename OutputImageType::IndexType |
using | InputImageConstPointer = typename InputImageType::ConstPointer |
using | InputImagePointer = typename InputImageType::Pointer |
using | InputImageRegionType = typename InputImageType::RegionType |
using | InputImageType = TInputImage |
using | KernelTransformPointerType = typename KernelTransformType::Pointer |
using | KernelTransformType = KernelTransform< double, Self::ImageDimension > |
using | OriginPointType = typename TOutputImage::PointType |
using | OutputImagePointer = typename OutputImageType::Pointer |
using | OutputImageRegionType = typename TOutputImage::RegionType |
using | OutputImageType = TOutputImage |
using | OutputPixelComponentType = typename OutputPixelType::ValueType |
using | OutputPixelType = typename TOutputImage::PixelType |
using | Pointer = SmartPointer< Self > |
using | Self = InverseDisplacementFieldImageFilter |
using | SizeType = typename OutputImageType::SizeType |
using | SpacingType = typename TOutputImage::SpacingType |
using | Superclass = ImageToImageFilter< TInputImage, TOutputImage > |
Public Types inherited from itk::ImageToImageFilter< TInputImage, TOutputImage > | |
using | ConstPointer = SmartPointer< const Self > |
using | InputImageConstPointer = typename InputImageType::ConstPointer |
using | InputImagePixelType = typename InputImageType::PixelType |
using | InputImagePointer = typename InputImageType::Pointer |
using | InputImageRegionType = typename InputImageType::RegionType |
using | InputImageType = TInputImage |
using | OutputImagePixelType = typename Superclass::OutputImagePixelType |
using | OutputImageRegionType = typename Superclass::OutputImageRegionType |
using | Pointer = SmartPointer< Self > |
using | Self = ImageToImageFilter |
using | Superclass = ImageSource< TOutputImage > |
Public Types inherited from itk::ImageSource< TOutputImage > | |
using | ConstPointer = SmartPointer< const Self > |
using | DataObjectIdentifierType = Superclass::DataObjectIdentifierType |
using | DataObjectPointer = DataObject::Pointer |
using | DataObjectPointerArraySizeType = Superclass::DataObjectPointerArraySizeType |
using | OutputImagePixelType = typename OutputImageType::PixelType |
using | OutputImagePointer = typename OutputImageType::Pointer |
using | OutputImageRegionType = typename OutputImageType::RegionType |
using | OutputImageType = TOutputImage |
using | Pointer = SmartPointer< Self > |
using | Self = ImageSource |
using | Superclass = ProcessObject |
Public Types inherited from itk::ProcessObject | |
using | ConstPointer = SmartPointer< const Self > |
using | DataObjectIdentifierType = DataObject::DataObjectIdentifierType |
using | DataObjectPointer = DataObject::Pointer |
using | DataObjectPointerArray = std::vector< DataObjectPointer > |
using | DataObjectPointerArraySizeType = DataObjectPointerArray::size_type |
using | MultiThreaderType = MultiThreaderBase |
using | NameArray = std::vector< DataObjectIdentifierType > |
using | Pointer = SmartPointer< Self > |
using | Self = ProcessObject |
using | Superclass = Object |
Public Types inherited from itk::Object | |
using | ConstPointer = SmartPointer< const Self > |
using | Pointer = SmartPointer< Self > |
using | Self = Object |
using | Superclass = LightObject |
Public Types inherited from itk::LightObject | |
using | ConstPointer = SmartPointer< const Self > |
using | Pointer = SmartPointer< Self > |
using | Self = LightObject |
Static Public Member Functions | |
static Pointer | New () |
Static Public Member Functions inherited from itk::Object | |
static bool | GetGlobalWarningDisplay () |
static void | GlobalWarningDisplayOff () |
static void | GlobalWarningDisplayOn () |
static Pointer | New () |
static void | SetGlobalWarningDisplay (bool flag) |
Static Public Member Functions inherited from itk::LightObject | |
static void | BreakOnError () |
static Pointer | New () |
Static Public Attributes | |
static constexpr unsigned int | ImageDimension = TOutputImage::ImageDimension |
Static Public Attributes inherited from itk::ImageToImageFilter< TInputImage, TOutputImage > | |
static constexpr unsigned int | InputImageDimension = TInputImage::ImageDimension |
static constexpr unsigned int | OutputImageDimension = TOutputImage::ImageDimension |
Static Public Attributes inherited from itk::ImageSource< TOutputImage > | |
static constexpr unsigned int | OutputImageDimension = TOutputImage::ImageDimension |
Private Attributes | |
KernelTransformPointerType | m_KernelTransform |
OriginPointType | m_OutputOrigin |
SpacingType | m_OutputSpacing |
SizeType | m_Size |
unsigned int | m_SubsamplingFactor |
Additional Inherited Members | |
Protected Types inherited from itk::ImageToImageFilter< TInputImage, TOutputImage > | |
using | InputToOutputRegionCopierType = ImageToImageFilterDetail::ImageRegionCopier< Self::OutputImageDimension, Self::InputImageDimension > |
using | OutputToInputRegionCopierType = ImageToImageFilterDetail::ImageRegionCopier< Self::InputImageDimension, Self::OutputImageDimension > |
Static Protected Member Functions inherited from itk::ImageSource< TOutputImage > | |
static const ImageRegionSplitterBase * | GetGlobalDefaultSplitter () |
static ITK_THREAD_RETURN_FUNCTION_CALL_CONVENTION | ThreaderCallback (void *arg) |
Protected Attributes inherited from itk::ImageSource< TOutputImage > | |
bool | m_DynamicMultiThreading |
Protected Attributes inherited from itk::ProcessObject | |
TimeStamp | m_OutputInformationMTime |
bool | m_Updating |
Protected Attributes inherited from itk::LightObject | |
std::atomic< int > | m_ReferenceCount |
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::ConstPointer = SmartPointer< const Self > |
Definition at line 75 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::IndexType = typename OutputImageType::IndexType |
Image index type alias.
Definition at line 105 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::InputImageConstPointer = typename InputImageType::ConstPointer |
Definition at line 79 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::InputImagePointer = typename InputImageType::Pointer |
Definition at line 78 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::InputImageRegionType = typename InputImageType::RegionType |
Definition at line 80 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::InputImageType = TInputImage |
Definition at line 77 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::KernelTransformPointerType = typename KernelTransformType::Pointer |
Definition at line 99 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::KernelTransformType = KernelTransform< double, Self::ImageDimension > |
Transform type alias.
Definition at line 98 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::OriginPointType = typename TOutputImage::PointType |
Definition at line 116 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::OutputImagePointer = typename OutputImageType::Pointer |
Definition at line 82 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::OutputImageRegionType = typename TOutputImage::RegionType |
Typedef to describe the output image region type.
Definition at line 112 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::OutputImageType = TOutputImage |
Definition at line 81 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::OutputPixelComponentType = typename OutputPixelType::ValueType |
Definition at line 109 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::OutputPixelType = typename TOutputImage::PixelType |
Image pixel value type alias.
Definition at line 108 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::Pointer = SmartPointer< Self > |
Definition at line 74 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::Self = InverseDisplacementFieldImageFilter |
Standard class type aliases.
Definition at line 72 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::SizeType = typename OutputImageType::SizeType |
Image size type alias.
Definition at line 102 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::SpacingType = typename TOutputImage::SpacingType |
Image spacing type alias
Definition at line 115 of file itkInverseDisplacementFieldImageFilter.h.
using itk::InverseDisplacementFieldImageFilter< TInputImage, TOutputImage >::Superclass = ImageToImageFilter< TInputImage, TOutputImage > |
Definition at line 73 of file itkInverseDisplacementFieldImageFilter.h.
|
protected |
|
overrideprotecteddefault |
|
virtual |
Create an object from an instance, potentially deferring to a factory. This method allows you to create an instance of an object that is exactly the same type as the referring object. This is useful in cases where an object has been cast back to a base class.
Reimplemented from itk::Object.
|
overrideprotectedvirtual |
GenerateData() computes the internal KernelBase spline and resamples the displacement field.
Reimplemented from itk::ImageSource< TOutputImage >.
|
overridevirtual |
InverseDisplacementFieldImageFilter needs a different input requested region than the output requested region. As such, InverseDisplacementFieldImageFilter needs to provide an implementation for GenerateInputRequestedRegion() in order to inform the pipeline execution model.
Reimplemented from itk::ImageToImageFilter< TInputImage, TOutputImage >.
|
overridevirtual |
InverseDisplacementFieldImageFilter produces an image which is a different size than its input. As such, it needs to provide an implementation for GenerateOutputInformation() in order to inform the pipeline execution model. The original documentation of this method is below.
Reimplemented from itk::ProcessObject.
|
virtual |
Get/Set the coordinate transformation. Set the KernelBase spline used for resampling the displacement grid.
|
virtual |
Get/Set the coordinate transformation. Set the KernelBase spline used for resampling the displacement grid.
|
overridevirtual |
Method Compute the Modified Time based on changed to the components.
Reimplemented from itk::Object.
|
virtual |
Run-time type information (and related methods).
Reimplemented from itk::ImageToImageFilter< TInputImage, TOutputImage >.
|
virtual |
Get the output image origin.
|
virtual |
Get the output image spacing.
|
virtual |
Get the size of the output image.
|
virtual |
Set/Get the factor used for subsampling the input displacement field. A large value in this factor will produce a fast computation of the inverse field but with low precision. A small value of this factor will produce a precise computation of the inverse field at the price of large memory consumption and long computational time.
|
static |
Method for creation through the object factory.
|
protected |
Subsample the input displacement field and generate the landmarks for the kernel base spline
|
overrideprotectedvirtual |
Methods invoked by Print() to print information about the object including superclasses. Typically not called by the user (use Print() instead) but used in the hierarchical print process to combine the output of several classes.
Reimplemented from itk::ImageToImageFilter< TInputImage, TOutputImage >.
|
virtual |
Get/Set the coordinate transformation. Set the KernelBase spline used for resampling the displacement grid.
|
virtual |
Set the output image origin.
|
virtual |
Set the output image origin.
|
virtual |
Set the output image spacing.
|
virtual |
Set the output image spacing.
|
virtual |
Set the size of the output image.
|
virtual |
Set/Get the factor used for subsampling the input displacement field. A large value in this factor will produce a fast computation of the inverse field but with low precision. A small value of this factor will produce a precise computation of the inverse field at the price of large memory consumption and long computational time.
|
static |
Number of dimensions.
Definition at line 91 of file itkInverseDisplacementFieldImageFilter.h.
|
private |
Definition at line 198 of file itkInverseDisplacementFieldImageFilter.h.
|
private |
Definition at line 201 of file itkInverseDisplacementFieldImageFilter.h.
|
private |
Definition at line 200 of file itkInverseDisplacementFieldImageFilter.h.
|
private |
Definition at line 197 of file itkInverseDisplacementFieldImageFilter.h.
|
private |
Definition at line 203 of file itkInverseDisplacementFieldImageFilter.h.