/usr/include/InsightToolkit/Common/itkSegmentationLevelSetFunction.h is in libinsighttoolkit3-dev 3.20.1+git20120521-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 | /*=========================================================================
Program: Insight Segmentation & Registration Toolkit
Module: itkSegmentationLevelSetFunction.h
Language: C++
Date: $Date$
Version: $Revision$
Copyright (c) Insight Software Consortium. All rights reserved.
See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notices for more information.
=========================================================================*/
#ifndef __itkSegmentationLevelSetFunction_h
#define __itkSegmentationLevelSetFunction_h
#include "itkLevelSetFunction.h"
#include "itkLinearInterpolateImageFunction.h"
#include "itkVectorLinearInterpolateImageFunction.h"
#include "itkVectorCastImageFilter.h"
namespace itk {
/** \class SegmentationLevelSetFunction
\par
This object defines the API for a class of function objects which perform
level set based segmentations. The SegmentationLevelSetImageFilter objects
use these SegmentationLevelSetFunction objects to perform the numerical
calculations which move a level set front to lock onto image features.
\par
In order to create a working function object, you must subclass the
CalculateSpeedImage method to produce a "feature image" that is used by the
parent LevelSetFunction class as the PropagationSpeed for its calculations.
\sa SegmentationLevelSetImageFilter
\sa LevelSetFunction
*/
template <class TImageType, class TFeatureImageType = TImageType>
class ITK_EXPORT SegmentationLevelSetFunction
: public LevelSetFunction<TImageType>
{
public:
/** Standard class typedefs. */
typedef SegmentationLevelSetFunction Self;
typedef LevelSetFunction<TImageType> Superclass;
typedef SmartPointer<Self> Pointer;
typedef SmartPointer<const Self> ConstPointer;
/** Run-time type information (and related methods) */
itkTypeMacro( SegmentationLevelSetFunction, LevelSetFunction );
/** Extract some parameters from the superclass. */
typedef typename Superclass::ImageType ImageType;
typedef typename Superclass::RadiusType RadiusType;
typedef typename Superclass::PixelRealType PixelRealType;
typedef TFeatureImageType FeatureImageType;
typedef typename Superclass::FloatOffsetType FloatOffsetType;
typedef typename Superclass::ScalarValueType ScalarValueType;
typedef typename Superclass::NeighborhoodType NeighborhoodType;
typedef typename FeatureImageType::PixelType FeatureScalarType;
typedef typename ImageType::IndexType IndexType;
typedef typename Superclass::VectorType VectorType;
typedef typename Superclass::GlobalDataStruct GlobalDataStruct;
/** Extract some parameters from the superclass. */
itkStaticConstMacro(ImageDimension, unsigned int,Superclass::ImageDimension);
/** Define an image type for the advection field. */
typedef Image<VectorType, itkGetStaticConstMacro(ImageDimension)> VectorImageType;
/** Define a scalar interpolator */
typedef LinearInterpolateImageFunction<ImageType> InterpolatorType;
/** Define a vector interpolator */
typedef VectorLinearInterpolateImageFunction<VectorImageType> VectorInterpolatorType;
/** Continuous index type recognized by the interpolator */
typedef typename InterpolatorType::ContinuousIndexType ContinuousIndexType;
/** Set/Get the image which will be used to calculate the speed function. */
virtual const FeatureImageType *GetFeatureImage() const
{ return m_FeatureImage.GetPointer(); }
virtual void SetFeatureImage(const FeatureImageType *f)
{ m_FeatureImage = f; }
/** Get/Set the image used as the speed function in the level set equation */
virtual ImageType *GetSpeedImage()
{ return m_SpeedImage.GetPointer(); }
void SetSpeedImage( ImageType *s );
/** Get/Set the image used as the advection field in the level set equation */
virtual VectorImageType *GetAdvectionImage() const
{ return m_AdvectionImage.GetPointer(); }
void SetAdvectionImage( VectorImageType *s );
/** This method creates the appropriate member variable operators for the
* level-set calculations. The argument to this function is a the radius
* necessary for performing the level-set calculations. */
virtual void Initialize(const RadiusType &r);
/** This method must be defined in a subclass to implement a working function
* object. This method is called before the solver begins its work to
* produce the speed image used as the level set function's Propagation speed
* term. See LevelSetFunction for more information. */
virtual void CalculateSpeedImage() {}
/** This method must be defined in a subclass to implement a working function
* object. This method is called before the solver begins its work to
* produce the speed image used as the level set function's Advection field
* term. See LevelSetFunction for more information. */
virtual void CalculateAdvectionImage() {}
/** Allocates the image that will be used for the level set function's
* Propagation Speed term. See LevelSetFunction for more information. */
virtual void AllocateSpeedImage();
/** Allocates the image that will be used for the level set function's
* Advection field term. See LevelSetFunction for more information. */
virtual void AllocateAdvectionImage();
/** Determines whether Positive or Negative speed terms will cause surface
* expansion. This method flips the sign of all of the speed, advection, etc
* terms. By convention, filters should be written so that POSITIVE speed
* terms cause surface expansion. Calling this method will
* toggle between the standard POSITIVE EXPANSION convention and the
* nonstandard NEGATIVE EXPANSION convention.
*
* IMPORTANT: When adding terms to the level-set equation through
* subclassing you may need to override this function so that your new terms
* will be properly adjusted. */
virtual void ReverseExpansionDirection();
protected:
/** The image whose features will be used to create a speed image */
typename FeatureImageType::ConstPointer m_FeatureImage;
/** The image holding the speed values for front propagation */
typename ImageType::Pointer m_SpeedImage;
/** The image holding the advection field for front propation */
typename VectorImageType::Pointer m_AdvectionImage;
/** A casting functor to convert between vector types. */
Functor::VectorCast< ITK_TYPENAME VectorInterpolatorType::OutputType,
VectorType > m_VectorCast;
/** Returns the propagation speed from the precalculated speed image.*/
virtual ScalarValueType PropagationSpeed(const NeighborhoodType &,
const FloatOffsetType &, GlobalDataStruct *gd) const;
/** Advection field. Returns a vector from the computed advectionfield.*/
virtual VectorType AdvectionField(const NeighborhoodType &,
const FloatOffsetType &, GlobalDataStruct *gd) const;
virtual ~SegmentationLevelSetFunction() {}
SegmentationLevelSetFunction()
{
m_SpeedImage = ImageType::New();
m_AdvectionImage = VectorImageType::New();
m_Interpolator = InterpolatorType::New();
m_VectorInterpolator = VectorInterpolatorType::New();
}
typename InterpolatorType::Pointer m_Interpolator;
typename VectorInterpolatorType::Pointer m_VectorInterpolator;
private:
SegmentationLevelSetFunction(const Self&); //purposely not implemented
void operator=(const Self&); //purposely not implemented
};
} // end namespace
// Define instantiation macro for this template.
#define ITK_TEMPLATE_SegmentationLevelSetFunction(_, EXPORT, x, y) namespace itk { \
_(2(class EXPORT SegmentationLevelSetFunction< ITK_TEMPLATE_2 x >)) \
namespace Templates { typedef SegmentationLevelSetFunction< ITK_TEMPLATE_2 x > \
SegmentationLevelSetFunction##y; } \
}
#if ITK_TEMPLATE_EXPLICIT
# include "Templates/itkSegmentationLevelSetFunction+-.h"
#endif
#if ITK_TEMPLATE_TXX
# include "itkSegmentationLevelSetFunction.txx"
#endif
#endif
|