ITK  4.1.0
Insight Segmentation and Registration Toolkit
Public Types | Public Member Functions | Static Public Attributes | Protected Member Functions | Private Member Functions | Private Attributes
itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel > Class Template Reference

#include <itkMorphologyImageFilter.h>

+ Inheritance diagram for itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >:
+ Collaboration diagram for itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >:

List of all members.

Public Types

typedef SmartPointer< const SelfConstPointer
typedef
ConstantBoundaryCondition
< InputImageType
DefaultBoundaryConditionType
typedef ImageBoundaryCondition
< InputImageType > const * 
ImageBoundaryConditionConstPointerType
typedef ImageBoundaryCondition
< InputImageType > * 
ImageBoundaryConditionPointerType
typedef TInputImage::IndexType IndexType
typedef TInputImage InputImageType
typedef KernelType::ConstIterator KernelIteratorType
typedef TKernel KernelType
typedef
ConstNeighborhoodIterator
< TInputImage > 
NeighborhoodIteratorType
typedef
Superclass::OutputImageRegionType 
OutputImageRegionType
typedef TOutputImage OutputImageType
typedef TInputImage::PixelType PixelType
typedef SmartPointer< SelfPointer
typedef KernelType::SizeType RadiusType
typedef TInputImage::RegionType RegionType
typedef MorphologyImageFilter Self
typedef TInputImage::SizeType SizeType
typedef KernelImageFilter
< TInputImage, TOutputImage,
TKernel > 
Superclass

Public Member Functions

virtual const char * GetNameOfClass () const
void OverrideBoundaryCondition (const ImageBoundaryConditionPointerType i)
void ResetBoundaryCondition ()

Static Public Attributes

static const unsigned int ImageDimension = TInputImage::ImageDimension

Protected Member Functions

virtual PixelType Evaluate (const NeighborhoodIteratorType &nit, const KernelIteratorType kernelBegin, const KernelIteratorType kernelEnd)=0
void ThreadedGenerateData (const OutputImageRegionType &outputRegionForThread, ThreadIdType threadId)

Private Member Functions

 MorphologyImageFilter (const Self &)
void operator= (const Self &)

Private Attributes

ImageBoundaryConditionPointerType m_BoundaryCondition
DefaultBoundaryConditionType m_DefaultBoundaryCondition
virtual
ImageBoundaryConditionPointerType 
GetBoundaryCondition () const
 MorphologyImageFilter ()
 ~MorphologyImageFilter ()
void PrintSelf (std::ostream &os, Indent indent) const

Detailed Description

template<class TInputImage, class TOutputImage, class TKernel>
class itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >

Base class for the morphological operations such as erosion and dialation.

This class provides the infrastructure to support most morphological operations. Subclasses of MorphologyImageFilter implement specific "binary" and "grayscale" operations. The "binary" subclasses can operate on gray level data, where a specified a pixel value is consider the "foreground" and every other pixel value is considered the background. This is useful for operating on segment masks where all pixels assigned to segment #1 have value 1, all pixels assigned to segment #2 have value 2, etc. Here, a given segment can be dilated (expanded) while treating all other segment identifiers are background.

The "kernel" specified represents a morphology structuring element. The structuring element is a small Neighborhood with values indicating an element is "on" (value > 0) or "off" (value <=0). Morphological operations are defined by placing the structuring element over a pixel, and calculating a nonlinear function (min, max) over the pixels of the image that are under pixels in the structuring element that are "on". The result of this calculation is the value of the pixel in the output image. Under most circumstances, the "center pixel" of the structuring element -- or structuring element pixel over the input pixel under consideration -- is prescribed to be "on". This is not a strict requirement but the subclasses of this filter are not guarenteed to produce the correct result if the "center pixel" is not part of the structuring element.

Subclasses of this class can define their own operations by simply providing their own Evaluate() protected member function.

See also:
BinaryErodeImageFilter
BinaryDilateImageFilter
GrayScaleErodeImageFilter
GrayScaleDilateImageFilter
NeighborhoodIterator
Neighborhood

Definition at line 72 of file itkMorphologyImageFilter.h.


Member Typedef Documentation

template<class TInputImage , class TOutputImage , class TKernel >
typedef SmartPointer< const Self > itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::ConstPointer
template<class TInputImage , class TOutputImage , class TKernel >
typedef ConstantBoundaryCondition< InputImageType > itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::DefaultBoundaryConditionType
template<class TInputImage , class TOutputImage , class TKernel >
typedef ImageBoundaryCondition< InputImageType > const* itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::ImageBoundaryConditionConstPointerType

Definition at line 100 of file itkMorphologyImageFilter.h.

template<class TInputImage , class TOutputImage , class TKernel >
typedef ImageBoundaryCondition< InputImageType >* itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::ImageBoundaryConditionPointerType

Typedef for boundary conditions.

Definition at line 99 of file itkMorphologyImageFilter.h.

template<class TInputImage , class TOutputImage , class TKernel >
typedef TInputImage::IndexType itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::IndexType
template<class TInputImage , class TOutputImage , class TKernel >
typedef TInputImage itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::InputImageType

Image related typedefs.

Reimplemented from itk::KernelImageFilter< TInputImage, TOutputImage, TKernel >.

Definition at line 83 of file itkMorphologyImageFilter.h.

template<class TInputImage , class TOutputImage , class TKernel >
typedef KernelType::ConstIterator itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::KernelIteratorType
template<class TInputImage , class TOutputImage , class TKernel >
typedef TKernel itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::KernelType
template<class TInputImage , class TOutputImage , class TKernel >
typedef ConstNeighborhoodIterator< TInputImage > itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::NeighborhoodIteratorType
template<class TInputImage , class TOutputImage , class TKernel >
typedef Superclass::OutputImageRegionType itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::OutputImageRegionType

Superclass typedefs.

Reimplemented from itk::ImageToImageFilter< TInputImage, TOutputImage >.

Definition at line 92 of file itkMorphologyImageFilter.h.

template<class TInputImage , class TOutputImage , class TKernel >
typedef TOutputImage itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::OutputImageType

Some convenient typedefs.

Reimplemented from itk::KernelImageFilter< TInputImage, TOutputImage, TKernel >.

Definition at line 87 of file itkMorphologyImageFilter.h.

template<class TInputImage , class TOutputImage , class TKernel >
typedef TInputImage::PixelType itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::PixelType
template<class TInputImage , class TOutputImage , class TKernel >
typedef SmartPointer< Self > itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::Pointer
template<class TInputImage , class TOutputImage , class TKernel >
typedef KernelType::SizeType itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::RadiusType

n-dimensional Kernel radius.

Reimplemented from itk::KernelImageFilter< TInputImage, TOutputImage, TKernel >.

Definition at line 113 of file itkMorphologyImageFilter.h.

template<class TInputImage , class TOutputImage , class TKernel >
typedef TInputImage::RegionType itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::RegionType
template<class TInputImage , class TOutputImage , class TKernel >
typedef MorphologyImageFilter itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::Self
template<class TInputImage , class TOutputImage , class TKernel >
typedef TInputImage::SizeType itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::SizeType
template<class TInputImage , class TOutputImage , class TKernel >
typedef KernelImageFilter< TInputImage, TOutputImage, TKernel > itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::Superclass

Constructor & Destructor Documentation

template<class TInputImage , class TOutputImage , class TKernel >
itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::MorphologyImageFilter ( ) [protected]

Get the current boundary condition.

template<class TInputImage , class TOutputImage , class TKernel >
itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::~MorphologyImageFilter ( ) [inline, protected]

Get the current boundary condition.

Definition at line 135 of file itkMorphologyImageFilter.h.

template<class TInputImage , class TOutputImage , class TKernel >
itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::MorphologyImageFilter ( const Self ) [private]

Member Function Documentation

template<class TInputImage , class TOutputImage , class TKernel >
virtual PixelType itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::Evaluate ( const NeighborhoodIteratorType nit,
const KernelIteratorType  kernelBegin,
const KernelIteratorType  kernelEnd 
) [protected, pure virtual]

Evaluate image neighborhood with kernel to find the new value for the center pixel value.

template<class TInputImage , class TOutputImage , class TKernel >
virtual ImageBoundaryConditionPointerType itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::GetBoundaryCondition ( ) const [virtual]

Get the current boundary condition.

template<class TInputImage , class TOutputImage , class TKernel >
virtual const char* itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::GetNameOfClass ( ) const [virtual]
template<class TInputImage , class TOutputImage , class TKernel >
void itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::operator= ( const Self ) [private]
template<class TInputImage , class TOutputImage , class TKernel >
void itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::OverrideBoundaryCondition ( const ImageBoundaryConditionPointerType  i) [inline]

Allows a user to override the internal boundary condition. Care should be be taken to ensure that the overriding boundary condition is a persistent object during the time it is referenced. The overriding condition can be of a different type than the default type as long as it is a subclass of ImageBoundaryCondition.

Definition at line 120 of file itkMorphologyImageFilter.h.

template<class TInputImage , class TOutputImage , class TKernel >
void itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::PrintSelf ( std::ostream &  os,
Indent  indent 
) const [protected, virtual]

Get the current boundary condition.

Reimplemented from itk::KernelImageFilter< TInputImage, TOutputImage, TKernel >.

template<class TInputImage , class TOutputImage , class TKernel >
void itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::ResetBoundaryCondition ( ) [inline]

Rest the boundary condition to the default

Definition at line 126 of file itkMorphologyImageFilter.h.

template<class TInputImage , class TOutputImage , class TKernel >
void itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::ThreadedGenerateData ( const OutputImageRegionType outputRegionForThread,
ThreadIdType  threadId 
) [protected, virtual]

Multi-thread version GenerateData.

Reimplemented from itk::ImageSource< TOutputImage >.


Member Data Documentation

template<class TInputImage , class TOutputImage , class TKernel >
const unsigned int itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::ImageDimension = TInputImage::ImageDimension [static]

Image related typedefs.

Reimplemented from itk::KernelImageFilter< TInputImage, TOutputImage, TKernel >.

Definition at line 96 of file itkMorphologyImageFilter.h.

template<class TInputImage , class TOutputImage , class TKernel >
ImageBoundaryConditionPointerType itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::m_BoundaryCondition [private]

Pointer to a persistent boundary condition object used for the image iterator.

Definition at line 156 of file itkMorphologyImageFilter.h.

template<class TInputImage , class TOutputImage , class TKernel >
DefaultBoundaryConditionType itk::MorphologyImageFilter< TInputImage, TOutputImage, TKernel >::m_DefaultBoundaryCondition [private]

Default boundary condition

Definition at line 159 of file itkMorphologyImageFilter.h.


The documentation for this class was generated from the following file: