18#ifndef itkDiscreteHessianGaussianImageFunction_h
19#define itkDiscreteHessianGaussianImageFunction_h
45template <
typename TInputImage,
typename TOutput =
double>
47 :
public ImageFunction<TInputImage, SymmetricSecondRankTensor<TOutput, TInputImage::ImageDimension>, TOutput>
102#if !defined(ITK_LEGACY_REMOVE)
105 InterpolationModeEnum::NearestNeighbourInterpolation;
106 static constexpr InterpolationModeEnum LinearInterpolation = InterpolationModeEnum::LinearInterpolation;
154 itkSetClampMacro(MaximumError,
double, 0.00001, 0.99999);
155 itkGetConstMacro(MaximumError,
double);
162 itkSetMacro(NormalizeAcrossScale,
bool);
163 itkGetConstMacro(NormalizeAcrossScale,
bool);
164 itkBooleanMacro(NormalizeAcrossScale);
169 itkSetMacro(UseImageSpacing,
bool);
170 itkGetConstMacro(UseImageSpacing,
bool);
171 itkBooleanMacro(UseImageSpacing);
179 itkSetMacro(MaximumKernelWidth,
unsigned int);
180 itkGetConstMacro(MaximumKernelWidth,
unsigned int);
257#ifndef ITK_MANUAL_INSTANTIATION
258# include "itkDiscreteHessianGaussianImageFunction.hxx"
GaussianDerivativeOperatorArrayType m_OperatorArray
typename OperatorImageFunctionType::Pointer OperatorImageFunctionPointer
static constexpr unsigned int ImageDimension2
InterpolationModeEnum m_InterpolationMode
SmartPointer< const Self > ConstPointer
SmartPointer< Self > Pointer
Neighborhood< TOutput, Self::ImageDimension2 > KernelType
DiscreteHessianGaussianImageFunction()
~DiscreteHessianGaussianImageFunction() override=default
DiscreteHessianGaussianImageFunction(const Self &)
virtual void SetVariance(double variance)
VarianceArrayType m_Variance
FixedArray< KernelType, Self::ImageDimension2 *(Self::ImageDimension2+1)/2 > KernelArrayType
void RecomputeGaussianKernel()
KernelArrayType m_KernelArray
SymmetricSecondRankTensor< TOutput, TInputImage::ImageDimension > TensorType
FixedArray< GaussianDerivativeOperatorType, 3 *Self::ImageDimension2 > GaussianDerivativeOperatorArrayType
void PrintSelf(std::ostream &os, Indent indent) const override
OutputType EvaluateAtContinuousIndex(const ContinuousIndexType &index) const override
itk::GaussianDerivativeOperator< TOutput, Self::ImageDimension2 > GaussianDerivativeOperatorType
bool m_NormalizeAcrossScale
void SetInputImage(const InputImageType *ptr) override
unsigned int m_MaximumKernelWidth
FixedArray< double, Self::ImageDimension2 > VarianceArrayType
OperatorImageFunctionPointer m_OperatorImageFunction
void operator=(const Self &)
NeighborhoodOperatorImageFunction< InputImageType, TOutput > OperatorImageFunctionType
virtual void SetVariance(VarianceArrayType _arg)
DiscreteHessianGaussianImageFunction Self
OutputType EvaluateAtIndex(const IndexType &index) const override
OutputType Evaluate(const PointType &point) const override
void SetSigma(const double sigma)
virtual void Initialize()
itk::GaussianDerivativeOperatorEnums::InterpolationMode InterpolationModeEnum
ImageFunction< TInputImage, SymmetricSecondRankTensor< TOutput, TInputImage::ImageDimension >, TOutput > Superclass
Simulate a standard C array with copy semantics.
static constexpr unsigned int Length
A NeighborhoodOperator whose coefficients are a one dimensional, discrete derivative Gaussian kernel.
typename InputImageType::PixelType InputPixelType
typename InputImageType::IndexValueType IndexValueType
typename InputImageType::IndexType IndexType
Point< TOutput, Self::ImageDimension > PointType
ContinuousIndex< TOutput, Self::ImageDimension > ContinuousIndexType
TInputImage InputImageType
Control indentation during Print() invocation.
Compute the convolution of a neighborhood operator with the image at a specific location in space,...
SmartPointer< Self > Pointer
A light-weight container object for storing an N-dimensional neighborhood of values.
virtual void Modified() const
Implements transparent reference counting.
Represent a symmetric tensor of second rank.
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....