/usr/include/ITK-4.5/itkLevelSetFunction.h is in libinsighttoolkit4-dev 4.5.0-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 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 | /*=========================================================================
*
* Copyright Insight Software Consortium
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0.txt
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*=========================================================================*/
#ifndef __itkLevelSetFunction_h
#define __itkLevelSetFunction_h
#include "itkFiniteDifferenceFunction.h"
#include "vnl/vnl_matrix_fixed.h"
namespace itk
{
/** \class LevelSetFunction
* \brief The LevelSetFunction class is a generic function object which can be
* used to create a level set method filter when combined with an appropriate
* finite difference image filter. (See FiniteDifferenceImageFilter.)
*
* LevelSetFunction implements a generic level set function. This function is
* an expanded form of the basic equation developed in [1].
*
* \f$\phi_{t} + \alpha
* \stackrel{\rightharpoonup}{A}(\mathbf{x})\cdot\nabla\phi + \beta
* P(\mathbf{x})\mid\nabla\phi\mid = \gamma Z(\mathbf{x})\kappa\mid\nabla\phi\mid\f$
*
* where \f$ \stackrel{\rightharpoonup}{A} \f$ is an advection term, \f$ P \f$
* is a propagation (growth) term, and \f$ Z \f$ is a spatial modifier term for
* the mean curvature \f$ \kappa \f$. \f$ \alpha \f$, \f$ \beta \f$, and \f$
* \gamma \f$ are all scalar constants.
*
* Terms in the equation above are supplied through virtual methods, which must
* be subclassed to complete an implementation. Terms can be eliminated from
* the equation by setting the corresponding constants to zero. A wide variety
* of level set methods can be implemented by subclassing this basic equation.
*
* In ITK, the usual sign convention is that the INSIDE of a surface contains
* NEGATIVE values and the OUTSIDE of the surface contains POSITIVE values.
*
* \warning You MUST call Initialize() in the constructor of subclasses of this
* object to set it up properly to do level-set Calculations. The argument
* that you pass Initialize is the radius of the neighborhood needed to perform
* the calculations. If your subclass does not do any additional neighborhood
* processing, then the default radius should be 1 in each direction.
*
* \par REFERENCES
* \par
* [1] Sethian, J.A. Level Set Methods. Cambridge University Press. 1996.
*
* \ingroup FiniteDifferenceFunctions
* \ingroup Functions
* \ingroup ITKLevelSets
*/
template< typename TImageType >
class LevelSetFunction:
public FiniteDifferenceFunction< TImageType >
{
public:
/** Standard class typedefs. */
typedef LevelSetFunction Self;
typedef FiniteDifferenceFunction< TImageType > Superclass;
typedef SmartPointer< Self > Pointer;
typedef SmartPointer< const Self > ConstPointer;
/** Method for creation through the object factory. */
itkNewMacro(Self);
/** Run-time type information (and related methods) */
itkTypeMacro(LevelSetFunction, FiniteDifferenceFunction);
/** Extract some parameters from the superclass. */
itkStaticConstMacro(ImageDimension, unsigned int, Superclass::ImageDimension);
/** Convenient typedefs. */
typedef double TimeStepType;
typedef typename Superclass::ImageType ImageType;
typedef typename Superclass::PixelType PixelType;
typedef PixelType ScalarValueType;
typedef typename Superclass::PixelRealType PixelRealType;
typedef typename Superclass::RadiusType RadiusType;
typedef typename Superclass::NeighborhoodType NeighborhoodType;
typedef typename Superclass::NeighborhoodScalesType NeighborhoodScalesType;
typedef typename Superclass::FloatOffsetType FloatOffsetType;
/** The vector type that will be used in the calculations. */
// typedef
typedef FixedArray< ScalarValueType, itkGetStaticConstMacro(ImageDimension) > VectorType;
/** A global data type for this class of equations. Used to store
* values that are needed in calculating the time step and other intermediate
* products such as derivatives that may be used by virtual functions called
* from ComputeUpdate. Caching these values here allows the ComputeUpdate
* function to be const and thread safe. */
struct GlobalDataStruct {
ScalarValueType m_MaxAdvectionChange;
ScalarValueType m_MaxPropagationChange;
ScalarValueType m_MaxCurvatureChange;
/** Hessian matrix */
vnl_matrix_fixed< ScalarValueType,
itkGetStaticConstMacro(ImageDimension),
itkGetStaticConstMacro(ImageDimension) > m_dxy;
/** Array of first derivatives */
ScalarValueType m_dx[itkGetStaticConstMacro(ImageDimension)];
ScalarValueType m_dx_forward[itkGetStaticConstMacro(ImageDimension)];
ScalarValueType m_dx_backward[itkGetStaticConstMacro(ImageDimension)];
ScalarValueType m_GradMagSqr;
};
/** Advection field. Default implementation returns a vector of zeros. */
virtual VectorType AdvectionField(const NeighborhoodType &,
const FloatOffsetType &, GlobalDataStruct * = 0) const
{ return m_ZeroVectorConstant; }
/** Propagation speed. This term controls surface expansion/contraction.
* Default implementation returns zero. */
virtual ScalarValueType PropagationSpeed(
const NeighborhoodType &,
const FloatOffsetType &, GlobalDataStruct * = 0) const
{ return NumericTraits< ScalarValueType >::Zero; }
/** Curvature speed. Can be used to spatially modify the effects of
curvature . The default implementation returns one. */
virtual ScalarValueType CurvatureSpeed(const NeighborhoodType &,
const FloatOffsetType &, GlobalDataStruct * = 0
) const
{ return NumericTraits< ScalarValueType >::One; }
/** Laplacian smoothing speed. Can be used to spatially modify the
effects of laplacian smoothing of the level set function */
virtual ScalarValueType LaplacianSmoothingSpeed(
const NeighborhoodType &,
const FloatOffsetType &, GlobalDataStruct * = 0) const
{ return NumericTraits< ScalarValueType >::One; }
/** Alpha. Scales all advection term values. */
virtual void SetAdvectionWeight(const ScalarValueType a)
{ m_AdvectionWeight = a; }
ScalarValueType GetAdvectionWeight() const
{ return m_AdvectionWeight; }
/** Beta. Scales all propagation term values. */
virtual void SetPropagationWeight(const ScalarValueType p)
{ m_PropagationWeight = p; }
ScalarValueType GetPropagationWeight() const
{ return m_PropagationWeight; }
/** Gamma. Scales all curvature weight values */
virtual void SetCurvatureWeight(const ScalarValueType c)
{ m_CurvatureWeight = c; }
ScalarValueType GetCurvatureWeight() const
{ return m_CurvatureWeight; }
/** Weight of the laplacian smoothing term */
void SetLaplacianSmoothingWeight(const ScalarValueType c)
{ m_LaplacianSmoothingWeight = c; }
ScalarValueType GetLaplacianSmoothingWeight() const
{ return m_LaplacianSmoothingWeight; }
/** Epsilon. */
void SetEpsilonMagnitude(const ScalarValueType e)
{ m_EpsilonMagnitude = e; }
ScalarValueType GetEpsilonMagnitude() const
{ return m_EpsilonMagnitude; }
/** Compute the equation value. */
virtual PixelType ComputeUpdate( const NeighborhoodType & neighborhood,
void *globalData,
const FloatOffsetType & = FloatOffsetType(0.0) );
/** Computes the time step for an update given a global data structure.
* The data used in the computation may take different forms depending on
* the nature of the equations. This global data cannot be kept in the
* instance of the equation object itself since the equation object must
* remain stateless for thread safety. The global data is therefore managed
* for each thread by the finite difference solver filters. */
virtual TimeStepType ComputeGlobalTimeStep(void *GlobalData) const;
/** Returns a pointer to a global data structure that is passed to this
* object from the solver at each calculation. The idea is that the solver
* holds the state of any global values needed to calculate the time step,
* while the equation object performs the actual calculations. The global
* data should also be initialized in this method. Global data can be used
* for caching any values used or reused by the FunctionObject. Each thread
* should receive its own global data struct. */
virtual void * GetGlobalDataPointer() const
{
GlobalDataStruct *ans = new GlobalDataStruct();
ans->m_MaxAdvectionChange = NumericTraits< ScalarValueType >::Zero;
ans->m_MaxPropagationChange = NumericTraits< ScalarValueType >::Zero;
ans->m_MaxCurvatureChange = NumericTraits< ScalarValueType >::Zero;
return ans;
}
/** 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);
/** When the finite difference solver filter has finished using a global
* data pointer, it passes it to this method, which frees the memory.
* The solver cannot free the memory because it does not know the type
* to which the pointer points. */
virtual void ReleaseGlobalDataPointer(void *GlobalData) const
{ delete (GlobalDataStruct *)GlobalData; }
/** */
virtual ScalarValueType ComputeCurvatureTerm(const NeighborhoodType &,
const FloatOffsetType &,
GlobalDataStruct *gd = 0
);
virtual ScalarValueType ComputeMeanCurvature(const NeighborhoodType &,
const FloatOffsetType &,
GlobalDataStruct *gd = 0
);
virtual ScalarValueType ComputeMinimalCurvature(const NeighborhoodType &,
const FloatOffsetType &,
GlobalDataStruct *gd = 0
);
virtual ScalarValueType Compute3DMinimalCurvature(const NeighborhoodType &,
const FloatOffsetType &,
GlobalDataStruct *gd = 0
);
/** */
void SetUseMinimalCurvature(bool b)
{
m_UseMinimalCurvature = b;
}
bool GetUseMinimalCurvature() const
{
return m_UseMinimalCurvature;
}
void UseMinimalCurvatureOn()
{
this->SetUseMinimalCurvature(true);
}
void UseMinimalCurvatureOff()
{
this->SetUseMinimalCurvature(false);
}
/** Set/Get the maximum constraint for the curvature term factor in the time step
calculation. Changing this value from the default is not recommended or
necessary, but can be used to speed up the surface evolution at the risk
of creating an unstable solution. */
static void SetMaximumCurvatureTimeStep(double n)
{
m_DT = n;
}
static double GetMaximumCurvatureTimeStep()
{
return m_DT;
}
/** Set/Get the maximum constraint for the scalar/vector term factor of the time step
calculation. Changing this value from the default is not recommended or
necessary, but can be used to speed up the surface evolution at the risk
of creating an unstable solution. */
static void SetMaximumPropagationTimeStep(double n)
{
m_WaveDT = n;
}
static double GetMaximumPropagationTimeStep()
{
return m_WaveDT;
}
protected:
LevelSetFunction()
{
m_EpsilonMagnitude = static_cast< ScalarValueType >( 1.0e-5 );
m_AdvectionWeight = m_PropagationWeight =
m_CurvatureWeight = m_LaplacianSmoothingWeight =
NumericTraits< ScalarValueType >::Zero;
m_UseMinimalCurvature = false;
}
virtual ~LevelSetFunction() {}
void PrintSelf(std::ostream & s, Indent indent) const;
/** Constants used in the time step calculation. */
static double m_WaveDT;
static double m_DT;
/** Slices for the ND neighborhood. */
std::slice x_slice[itkGetStaticConstMacro(ImageDimension)];
/** The offset of the center pixel in the neighborhood. */
OffsetValueType m_Center;
/** Stride length along the y-dimension. */
OffsetValueType m_xStride[itkGetStaticConstMacro(ImageDimension)];
bool m_UseMinimalCurvature;
/** This method's only purpose is to initialize the zero vector
* constant. */
static VectorType InitializeZeroVectorConstant();
/** Zero vector constant. */
static VectorType m_ZeroVectorConstant;
/** Epsilon magnitude controls the lower limit for gradient magnitude. */
ScalarValueType m_EpsilonMagnitude;
/** Alpha. */
ScalarValueType m_AdvectionWeight;
/** Beta. */
ScalarValueType m_PropagationWeight;
/** Gamma. */
ScalarValueType m_CurvatureWeight;
/** Laplacean smoothing term */
ScalarValueType m_LaplacianSmoothingWeight;
private:
LevelSetFunction(const Self &); //purposely not implemented
void operator=(const Self &); //purposely not implemented
};
} // namespace itk
#ifndef ITK_MANUAL_INSTANTIATION
#include "itkLevelSetFunction.hxx"
#endif
#endif
|