#include <itkGaussianOperator.h>
A NeighborhoodOperator whose coefficients are a one dimensional, discrete Gaussian kernel.
GaussianOperator can be used to perform Gaussian blurring by taking its inner product with a Neighborhood (NeighborhoodIterator) that is swept across an image region. It is a directional operator. N successive applications oriented along each dimensional direction will effect separable, efficient, N-D Gaussian blurring of an image region.
GaussianOperator takes two parameters:
(1) The floating-point variance of the desired Gaussian function.
(2) The "maximum error" allowed in the discrete Gaussian function. "Maximum error" is defined as the difference between the area under the discrete Gaussian curve and the area under the continuous Gaussian. Maximum error affects the Gaussian operator size. Care should be taken not to make this value too small relative to the variance lest the operator size become unreasonably large.
References: The Gaussian kernel contained in this operator was described in [67].
Definition at line 67 of file itkGaussianOperator.h.
Public Types | |
using | Self = GaussianOperator |
using | Superclass = NeighborhoodOperator<TPixel, VDimension, TAllocator> |
![]() | |
using | PixelRealType = typename NumericTraits<TPixel>::RealType |
using | PixelType = TPixel |
using | Self = NeighborhoodOperator |
using | SliceIteratorType = SliceIterator<TPixel, Self> |
using | Superclass = Neighborhood<TPixel, VDimension, TAllocator> |
![]() | |
using | AllocatorType = TAllocator |
using | ConstIterator = typename AllocatorType::const_iterator |
using | DimensionValueType = unsigned int |
using | Iterator = typename AllocatorType::iterator |
using | NeighborIndexType = SizeValueType |
using | OffsetType = Offset<VDimension> |
using | PixelType = TPixel |
using | RadiusType = itk::Size<VDimension> |
using | Self = Neighborhood |
using | SizeType = itk::Size<VDimension> |
using | SizeValueType = typename SizeType::SizeValueType |
using | SliceIteratorType = SliceIterator<TPixel, Self> |
Public Member Functions | |
void | DebugOff () const |
void | DebugOn () const |
bool | GetDebug () const |
double | GetMaximumError () |
unsigned int | GetMaximumKernelWidth () const |
const char * | GetNameOfClass () const override |
double | GetVariance () |
double | ModifiedBesselI (int, double) |
double | ModifiedBesselI0 (double) |
double | ModifiedBesselI1 (double) |
void | PrintSelf (std::ostream &os, Indent indent) const override |
void | SetDebug (bool debugFlag) const |
void | SetMaximumError (const double max_error) |
void | SetMaximumKernelWidth (unsigned int n) |
void | SetVariance (const double variance) |
![]() | |
virtual void | CreateDirectional () |
virtual void | CreateToRadius (const SizeType &) |
virtual void | CreateToRadius (const SizeValueType) |
virtual void | FlipAxes () |
unsigned int | GetDirection () const |
const char * | GetNameOfClass () const override |
void | PrintSelf (std::ostream &os, Indent indent) const override |
void | ScaleCoefficients (PixelRealType) |
void | SetDirection (const unsigned int direction) |
![]() | |
NeighborIndexType | GetCenterNeighborhoodIndex () const |
TPixel | GetCenterValue () const |
virtual NeighborIndexType | GetNeighborhoodIndex (const OffsetType &) const |
OffsetType | GetOffset (NeighborIndexType i) const |
const SizeType | GetRadius () const |
SizeValueType | GetRadius (DimensionValueType n) const |
SizeType | GetSize () const |
SizeValueType | GetSize (DimensionValueType n) const |
std::slice | GetSlice (unsigned int) const |
OffsetValueType | GetStride (DimensionValueType axis) const |
ITK_UNEQUAL_OPERATOR_MEMBER_FUNCTION (Self) | |
Neighborhood ()=default | |
Neighborhood (const Self &)=default | |
Neighborhood (Self &&)=default | |
Self & | operator= (const Self &)=default |
Self & | operator= (Self &&)=default |
bool | operator== (const Self &other) const |
void | Print (std::ostream &os) const |
void | SetRadius (const SizeType &) |
void | SetRadius (const SizeValueType) |
NeighborIndexType | Size () const |
virtual | ~Neighborhood ()=default |
Iterator | End () |
Iterator | Begin () |
ConstIterator | End () const |
ConstIterator | Begin () const |
TPixel & | operator[] (NeighborIndexType i) |
const TPixel & | operator[] (NeighborIndexType i) const |
TPixel & | GetElement (NeighborIndexType i) |
void | SetRadius (const SizeValueType *rad) |
AllocatorType & | GetBufferReference () |
const AllocatorType & | GetBufferReference () const |
TPixel & | operator[] (const OffsetType &o) |
const TPixel & | operator[] (const OffsetType &o) const |
Protected Types | |
using | CoefficientVector |
![]() | |
using | CoefficientVector = typename std::vector<PixelRealType> |
Protected Member Functions | |
void | Fill (const CoefficientVector &coeff) override |
CoefficientVector | GenerateCoefficients () override |
![]() | |
virtual void | FillCenteredDirectional (const CoefficientVector &) |
void | InitializeToZero () |
![]() | |
virtual void | Allocate (NeighborIndexType i) |
virtual void | ComputeNeighborhoodOffsetTable () |
virtual void | ComputeNeighborhoodStrideTable () |
void | SetSize () |
Private Attributes | |
bool | m_Debug { false } |
double | m_MaximumError { .01 } |
unsigned int | m_MaximumKernelWidth { 30 } |
double | m_Variance { 1 } |
Additional Inherited Members | |
![]() | |
static constexpr unsigned int | NeighborhoodDimension = VDimension |
|
protected |
Type alias support for coefficient vector type. Necessary to fix bug in the microsoft VC++ compiler.
Definition at line 153 of file itkNeighborhoodOperator.h.
using itk::GaussianOperator< TPixel, VDimension, TAllocator >::Self = GaussianOperator |
Standard class type aliases.
Definition at line 72 of file itkGaussianOperator.h.
using itk::GaussianOperator< TPixel, VDimension, TAllocator >::Superclass = NeighborhoodOperator<TPixel, VDimension, TAllocator> |
Definition at line 73 of file itkGaussianOperator.h.
|
inline |
Turn debugging output off.
Definition at line 162 of file itkGaussianOperator.h.
|
inline |
Turn debugging output on.
Definition at line 155 of file itkGaussianOperator.h.
|
inlineoverrideprotectedvirtual |
Arranges coefficients spatially in the memory buffer.
Implements itk::NeighborhoodOperator< TPixel, VDimension, TAllocator >.
Definition at line 200 of file itkGaussianOperator.h.
|
overrideprotectedvirtual |
Calculates operator coefficients.
Implements itk::NeighborhoodOperator< TPixel, VDimension, TAllocator >.
|
inline |
Get the value of the debug flag. Mimics the itk::Object interface so that itkDebugMacro can be used in selective printouts from Gaussian kernel generation.
Definition at line 148 of file itkGaussianOperator.h.
|
inline |
Returns the maximum error of the gaussian approximation. Maximum error is the difference between the area under the discrete Gaussian curve and the area under the continuous Gaussian. Maximum error affects the Gaussian operator size.
Definition at line 112 of file itkGaussianOperator.h.
|
inline |
Returns the maximum allowed kernel width.
Definition at line 129 of file itkGaussianOperator.h.
|
overridevirtual |
Reimplemented from itk::Neighborhood< TPixel, VDimension, TAllocator >.
|
inline |
Returns the variance of the Gaussian (scale) for the operator.
Definition at line 102 of file itkGaussianOperator.h.
double itk::GaussianOperator< TPixel, VDimension, TAllocator >::ModifiedBesselI | ( | int | , |
double | ) |
Returns the value of the modified Bessel function Ik(x) at a point x>=0, where k>=2.
double itk::GaussianOperator< TPixel, VDimension, TAllocator >::ModifiedBesselI0 | ( | double | ) |
Returns the value of the modified Bessel function I0(x) at a point x >= 0.
double itk::GaussianOperator< TPixel, VDimension, TAllocator >::ModifiedBesselI1 | ( | double | ) |
Returns the value of the modified Bessel function I1(x) at a point x, x real.
|
inlineoverridevirtual |
Standard itk object method.
Reimplemented from itk::Neighborhood< TPixel, VDimension, TAllocator >.
Definition at line 135 of file itkGaussianOperator.h.
|
inline |
Set the value of the debug flag. A non-zero value turns debugging on.
Definition at line 169 of file itkGaussianOperator.h.
|
inline |
Sets the desired maximum error of the gaussian approximation. Maximum error is the difference between the area under the discrete Gaussian curve and the area under the continuous Gaussian. Maximum error affects the Gaussian operator size. The value must be between 0.0 and 1.0.
Definition at line 90 of file itkGaussianOperator.h.
|
inline |
Sets a limit for growth of the kernel. Small maximum error values with large variances will yield very large kernel sizes. This value can be used to truncate a kernel in such instances. A warning will be given on truncation of the kernel.
Definition at line 122 of file itkGaussianOperator.h.
|
inline |
Sets the desired variance of the Gaussian kernel.
Definition at line 80 of file itkGaussianOperator.h.
|
mutableprivate |
Enable/disable kernel generation debug warnings
Definition at line 219 of file itkGaussianOperator.h.
|
private |
Difference between the areas under the curves of the continuous and discrete Gaussian functions.
Definition at line 211 of file itkGaussianOperator.h.
|
private |
Maximum kernel size allowed. This value is used to truncate a kernel that has grown too large. A warning is given when the specified maximum error causes the kernel to exceed this size.
Definition at line 216 of file itkGaussianOperator.h.
|
private |
Desired variance of the discrete Gaussian function.
Definition at line 207 of file itkGaussianOperator.h.