ITK
4.1.0
Insight Segmentation and Registration Toolkit
|
#include <itkMorphologicalWatershedFromMarkersImageFilter.h>
Public Types | |
typedef SmartPointer< const Self > | ConstPointer |
typedef LabelImageType::IndexType | IndexType |
typedef InputImageType::ConstPointer | InputImageConstPointer |
typedef InputImageType::PixelType | InputImagePixelType |
typedef InputImageType::Pointer | InputImagePointer |
typedef InputImageType::RegionType | InputImageRegionType |
typedef TInputImage | InputImageType |
typedef LabelImageType::ConstPointer | LabelImageConstPointer |
typedef LabelImageType::PixelType | LabelImagePixelType |
typedef LabelImageType::Pointer | LabelImagePointer |
typedef LabelImageType::RegionType | LabelImageRegionType |
typedef TLabelImage | LabelImageType |
typedef SmartPointer< Self > | Pointer |
typedef MorphologicalWatershedFromMarkersImageFilter | Self |
typedef ImageToImageFilter < TInputImage, TLabelImage > | Superclass |
Public Member Functions | |
virtual ::itk::LightObject::Pointer | CreateAnother (void) const |
const LabelImageType * | GetMarkerImage () const |
virtual const char * | GetNameOfClass () const |
void | SetInput1 (const TInputImage *input) |
void | SetInput2 (const TLabelImage *input) |
void | SetMarkerImage (const TLabelImage *input) |
virtual void | SetFullyConnected (bool _arg) |
virtual const bool & | GetFullyConnected () |
virtual void | FullyConnectedOn () |
virtual void | FullyConnectedOff () |
Static Public Member Functions | |
static Pointer | New () |
Static Public Attributes | |
static const unsigned int | ImageDimension = TInputImage::ImageDimension |
Protected Member Functions | |
void | EnlargeOutputRequestedRegion (DataObject *) |
void | GenerateData () |
void | GenerateInputRequestedRegion () |
Private Member Functions | |
MorphologicalWatershedFromMarkersImageFilter (const Self &) | |
void | operator= (const Self &) |
Private Attributes | |
bool | m_FullyConnected |
bool | m_MarkWatershedLine |
virtual void | SetMarkWatershedLine (bool _arg) |
virtual const bool & | GetMarkWatershedLine () |
virtual void | MarkWatershedLineOn () |
virtual void | MarkWatershedLineOff () |
MorphologicalWatershedFromMarkersImageFilter () | |
~MorphologicalWatershedFromMarkersImageFilter () | |
void | PrintSelf (std::ostream &os, Indent indent) const |
Morphological watershed transform from markers.
The watershed transform is a tool for image segmentation that is fast and flexible and potentially fairly parameter free. It was originally derived from a geophysical model of rain falling on a terrain and a variety of more formal definitions have been devised to allow development of practical algorithms. If an image is considered as a terrain and divided into catchment basins then the hope is that each catchment basin would contain an object of interest.
The output is a label image. A label image, sometimes referred to as a categorical image, has unique values for each region. For example, if a watershed produces 2 regions, all pixels belonging to one region would have value A, and all belonging to the other might have value B. Unassigned pixels, such as watershed lines, might have the background value (0 by convention).
The simplest way of using the watershed is to preprocess the image we want to segment so that the boundaries of our objects are bright (e.g apply an edge detector) and compute the watershed transform of the edge image. Watershed lines will correspond to the boundaries and our problem will be solved. This is rarely useful in practice because there are always more regional minima than there are objects, either due to noise or natural variations in the object surfaces. Therefore, while many watershed lines do lie on significant boundaries, there are many that don't. Various methods can be used to reduce the number of minima in the image, like thresholding the smallest values, filtering the minima and/or smoothing the image.
This filter use another approach to avoid the problem of over segmentation: it let the user provide a marker image which mark the minima in the input image and give them a label. The minima are imposed in the input image by the markers. The labels of the output image are the label of the marker image.
The morphological watershed transform algorithm is described in Chapter 9.2 of Pierre Soille's book "Morphological Image Analysis: Principles and Applications", Second Edition, Springer, 2003.
This code was contributed in the Insight Journal paper: "The watershed transform in ITK - discussion and new developments" by Beare R., Lehmann G. http://hdl.handle.net/1926/202 http://www.insight-journal.org/browse/publication/92
Definition at line 80 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
typedef SmartPointer< const Self > itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::ConstPointer |
Reimplemented from itk::ImageToImageFilter< TInputImage, TLabelImage >.
Definition at line 88 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
typedef LabelImageType::IndexType itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::IndexType |
Definition at line 102 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
typedef InputImageType::ConstPointer itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::InputImageConstPointer |
Reimplemented from itk::ImageToImageFilter< TInputImage, TLabelImage >.
Definition at line 94 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
typedef InputImageType::PixelType itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::InputImagePixelType |
Reimplemented from itk::ImageToImageFilter< TInputImage, TLabelImage >.
Definition at line 96 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
typedef InputImageType::Pointer itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::InputImagePointer |
Reimplemented from itk::ImageToImageFilter< TInputImage, TLabelImage >.
Definition at line 93 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
typedef InputImageType::RegionType itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::InputImageRegionType |
Reimplemented from itk::ImageToImageFilter< TInputImage, TLabelImage >.
Definition at line 95 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
typedef TInputImage itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::InputImageType |
Some convenient typedefs.
Reimplemented from itk::ImageToImageFilter< TInputImage, TLabelImage >.
Definition at line 91 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
typedef LabelImageType::ConstPointer itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::LabelImageConstPointer |
Definition at line 98 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
typedef LabelImageType::PixelType itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::LabelImagePixelType |
Definition at line 100 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
typedef LabelImageType::Pointer itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::LabelImagePointer |
Definition at line 97 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
typedef LabelImageType::RegionType itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::LabelImageRegionType |
Definition at line 99 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
typedef TLabelImage itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::LabelImageType |
Definition at line 92 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
typedef SmartPointer< Self > itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::Pointer |
Reimplemented from itk::ImageToImageFilter< TInputImage, TLabelImage >.
Definition at line 87 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
typedef MorphologicalWatershedFromMarkersImageFilter itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::Self |
Standard class typedefs.
Reimplemented from itk::ImageToImageFilter< TInputImage, TLabelImage >.
Definition at line 85 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
typedef ImageToImageFilter< TInputImage, TLabelImage > itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::Superclass |
Reimplemented from itk::ImageToImageFilter< TInputImage, TLabelImage >.
Definition at line 86 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::MorphologicalWatershedFromMarkersImageFilter | ( | ) | [protected] |
Set/Get whether the watershed pixel must be marked or not. Default is true. Set it to false do not only avoid writing watershed pixels, it also decrease algorithm complexity.
itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::~MorphologicalWatershedFromMarkersImageFilter | ( | ) | [inline, protected] |
Set/Get whether the watershed pixel must be marked or not. Default is true. Set it to false do not only avoid writing watershed pixels, it also decrease algorithm complexity.
Definition at line 162 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::MorphologicalWatershedFromMarkersImageFilter | ( | const Self & | ) | [private] |
virtual::itk::LightObject::Pointer itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::CreateAnother | ( | void | ) | const [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.
void itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::EnlargeOutputRequestedRegion | ( | DataObject * | ) | [protected, virtual] |
This filter will enlarge the output requested region to produce all of the output.
Reimplemented from itk::ProcessObject.
virtual void itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::FullyConnectedOff | ( | ) | [virtual] |
Set/Get whether the connected components are defined strictly by face connectivity or by face+edge+vertex connectivity. Default is FullyConnectedOff. For objects that are 1 pixel wide, use FullyConnectedOn.
virtual void itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::FullyConnectedOn | ( | ) | [virtual] |
Set/Get whether the connected components are defined strictly by face connectivity or by face+edge+vertex connectivity. Default is FullyConnectedOff. For objects that are 1 pixel wide, use FullyConnectedOn.
void itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::GenerateData | ( | ) | [protected, virtual] |
The filter is single threaded.
Reimplemented from itk::ImageSource< TLabelImage >.
void itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::GenerateInputRequestedRegion | ( | ) | [protected, virtual] |
MorphologicalWatershedFromMarkersImageFilter needs to request the entire input images.
Reimplemented from itk::ImageToImageFilter< TInputImage, TLabelImage >.
virtual const bool& itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::GetFullyConnected | ( | ) | [virtual] |
Set/Get whether the connected components are defined strictly by face connectivity or by face+edge+vertex connectivity. Default is FullyConnectedOff. For objects that are 1 pixel wide, use FullyConnectedOn.
const LabelImageType* itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::GetMarkerImage | ( | ) | const [inline] |
Get the marker image
Definition at line 123 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
References itk::ProcessObject::GetInput().
virtual const bool& itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::GetMarkWatershedLine | ( | ) | [virtual] |
Set/Get whether the watershed pixel must be marked or not. Default is true. Set it to false do not only avoid writing watershed pixels, it also decrease algorithm complexity.
virtual const char* itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::GetNameOfClass | ( | ) | const [virtual] |
Runtime information support.
Reimplemented from itk::ImageToImageFilter< TInputImage, TLabelImage >.
virtual void itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::MarkWatershedLineOff | ( | ) | [virtual] |
Set/Get whether the watershed pixel must be marked or not. Default is true. Set it to false do not only avoid writing watershed pixels, it also decrease algorithm complexity.
virtual void itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::MarkWatershedLineOn | ( | ) | [virtual] |
Set/Get whether the watershed pixel must be marked or not. Default is true. Set it to false do not only avoid writing watershed pixels, it also decrease algorithm complexity.
static Pointer itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::New | ( | ) | [static] |
Standard New method.
Reimplemented from itk::Object.
void itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::operator= | ( | const Self & | ) | [private] |
PushBackInput(), PushFronInput() in the public section force the input to be the type expected by an ImageToImageFilter. However, these methods end of "hiding" the versions from the superclass (ProcessObject) whose arguments are DataObjects. Here, we re-expose the versions from ProcessObject to avoid warnings about hiding methods from the superclass.
Reimplemented from itk::ImageToImageFilter< TInputImage, TLabelImage >.
void itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::PrintSelf | ( | std::ostream & | os, |
Indent | indent | ||
) | const [protected, virtual] |
Set/Get whether the watershed pixel must be marked or not. Default is true. Set it to false do not only avoid writing watershed pixels, it also decrease algorithm complexity.
Reimplemented from itk::ImageToImageFilter< TInputImage, TLabelImage >.
virtual void itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::SetFullyConnected | ( | bool | _arg | ) | [virtual] |
Set/Get whether the connected components are defined strictly by face connectivity or by face+edge+vertex connectivity. Default is FullyConnectedOff. For objects that are 1 pixel wide, use FullyConnectedOn.
void itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::SetInput1 | ( | const TInputImage * | input | ) | [inline] |
Set the input image
Definition at line 130 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
void itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::SetInput2 | ( | const TLabelImage * | input | ) | [inline] |
Set the marker image
Definition at line 136 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
void itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::SetMarkerImage | ( | const TLabelImage * | input | ) | [inline] |
Set the marker image
Definition at line 116 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
virtual void itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::SetMarkWatershedLine | ( | bool | _arg | ) | [virtual] |
Set/Get whether the watershed pixel must be marked or not. Default is true. Set it to false do not only avoid writing watershed pixels, it also decrease algorithm complexity.
const unsigned int itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::ImageDimension = TInputImage::ImageDimension [static] |
ImageDimension constants
Definition at line 106 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
bool itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::m_FullyConnected [private] |
Definition at line 184 of file itkMorphologicalWatershedFromMarkersImageFilter.h.
bool itk::MorphologicalWatershedFromMarkersImageFilter< TInputImage, TLabelImage >::m_MarkWatershedLine [private] |
Definition at line 186 of file itkMorphologicalWatershedFromMarkersImageFilter.h.