ITK  6.0.0
Insight Toolkit
itkGaborKernelFunction.h
Go to the documentation of this file.
1 /*=========================================================================
2  *
3  * Copyright NumFOCUS
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  * https://www.apache.org/licenses/LICENSE-2.0.txt
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  *=========================================================================*/
18 #ifndef itkGaborKernelFunction_h
19 #define itkGaborKernelFunction_h
20 
21 #include "itkKernelFunctionBase.h"
22 #include <cmath>
23 
24 namespace itk
25 {
50 template <typename TRealValueType>
51 class ITK_TEMPLATE_EXPORT GaborKernelFunction : public KernelFunctionBase<TRealValueType>
52 {
53 public:
54  ITK_DISALLOW_COPY_AND_MOVE(GaborKernelFunction);
55 
60 
62  itkNewMacro(Self);
63 
65  itkOverrideGetNameOfClassMacro(GaborKernelFunction);
66 
68  TRealValueType
69  Evaluate(const TRealValueType & u) const override
70  {
71  TRealValueType parameter = itk::Math::sqr(u / this->m_Sigma);
72  TRealValueType envelope = std::exp(TRealValueType{ -0.5 } * parameter);
73  TRealValueType phase = TRealValueType{ 2.0 * itk::Math::pi } * this->m_Frequency * u + this->m_PhaseOffset;
76  if (this->m_CalculateImaginaryPart)
77  {
78  return envelope * std::sin(phase);
79  }
80 
81  return envelope * std::cos(phase);
82  }
83 
85  itkSetMacro(Sigma, TRealValueType);
86  itkGetConstMacro(Sigma, TRealValueType);
90  itkSetMacro(Frequency, TRealValueType);
91  itkGetConstMacro(Frequency, TRealValueType);
95  itkSetMacro(PhaseOffset, TRealValueType);
96  itkGetConstMacro(PhaseOffset, TRealValueType);
101  itkSetMacro(CalculateImaginaryPart, bool);
102  itkGetConstMacro(CalculateImaginaryPart, bool);
103  itkBooleanMacro(CalculateImaginaryPart);
106 protected:
108  {
109  this->m_CalculateImaginaryPart = false;
110  this->m_Sigma = TRealValueType{ 1.0 };
111  this->m_Frequency = TRealValueType{ 0.4 };
112  this->m_PhaseOffset = TRealValueType{ 0.0 };
113  }
114  ~GaborKernelFunction() override = default;
115  void
116  PrintSelf(std::ostream & os, Indent indent) const override
117  {
118  Superclass::PrintSelf(os, indent);
119 
120  os << indent << "Sigma: " << this->GetSigma() << std::endl;
121  os << indent << "Frequency: " << this->GetFrequency() << std::endl;
122  os << indent << "PhaseOffset: " << this->GetPhaseOffset() << std::endl;
123  os << indent << "CalculateImaginaryPart: " << this->GetCalculateImaginaryPart() << std::endl;
124  }
125 
126 private:
127  TRealValueType m_Sigma{};
128 
129  TRealValueType m_Frequency{};
130 
131  TRealValueType m_PhaseOffset{};
132 
133  bool m_CalculateImaginaryPart{};
134 };
135 } // end namespace itk
136 
137 #endif
itk::KernelFunctionBase
Kernel used for density estimation and nonparametric regression.
Definition: itkKernelFunctionBase.h:43
itkKernelFunctionBase.h
itk::SmartPointer< Self >
itk::Indent
Control indentation during Print() invocation.
Definition: itkIndent.h:49
itk::GaborKernelFunction::PrintSelf
void PrintSelf(std::ostream &os, Indent indent) const override
Definition: itkGaborKernelFunction.h:116
itk::GaborKernelFunction::Evaluate
TRealValueType Evaluate(const TRealValueType &u) const override
Definition: itkGaborKernelFunction.h:69
itk::GaborKernelFunction
Gabor kernel used for various computer vision tasks.
Definition: itkGaborKernelFunction.h:51
itk::FunctionBase< TRealValueType, TRealValueType >
itk
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
Definition: itkAnatomicalOrientation.h:29
itk::Math::pi
static constexpr double pi
Definition: itkMath.h:66
itk::GaborKernelFunction::GaborKernelFunction
GaborKernelFunction()
Definition: itkGaborKernelFunction.h:107