ITK  6.0.0
Insight Toolkit
itkCentralDifferenceImageFunction.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 itkCentralDifferenceImageFunction_h
19#define itkCentralDifferenceImageFunction_h
20
21#include "itkImageFunction.h"
22#include "itkCovariantVector.h"
25
26namespace itk
27{
73template <typename TInputImage,
74 typename TCoordinate = float,
75 typename TOutputType = CovariantVector<double, TInputImage::ImageDimension>>
76class ITK_TEMPLATE_EXPORT CentralDifferenceImageFunction : public ImageFunction<TInputImage, TOutputType, TCoordinate>
77{
78public:
79 ITK_DISALLOW_COPY_AND_MOVE(CentralDifferenceImageFunction);
80
82 static constexpr unsigned int ImageDimension = TInputImage::ImageDimension;
83
89
91 itkOverrideGetNameOfClassMacro(CentralDifferenceImageFunction);
92
94 itkNewMacro(Self);
95
97 using InputImageType = TInputImage;
98
100 using InputPixelType = typename InputImageType::PixelType;
101
104
106 using typename Superclass::OutputType;
107
110
113
116
118 using typename Superclass::IndexType;
119
121 using typename Superclass::ContinuousIndexType;
122
124 using typename Superclass::PointType;
125
127 using SpacingType = typename TInputImage::SpacingType;
128
132
134 void
135 SetInputImage(const TInputImage * inputData) override;
136
139 virtual void
141
143 itkGetModifiableObjectMacro(Interpolator, InterpolatorType);
144
156 EvaluateAtIndex(const IndexType & index) const override;
157
172 Evaluate(const PointType & point) const override;
173
186 EvaluateAtContinuousIndex(const ContinuousIndexType & cindex) const override;
187
202 itkSetMacro(UseImageDirection, bool);
203 itkGetConstMacro(UseImageDirection, bool);
204 itkBooleanMacro(UseImageDirection);
207protected:
210 void
211 PrintSelf(std::ostream & os, Indent indent) const override;
212
213private:
215 template <typename T>
217 {
218 using Type = T;
219 };
220
222 template <typename Type>
223 inline void
225 OutputType & orientedDerivative,
227
229 template <typename Type>
230 inline void
232 OutputType & derivative,
234
236 template <typename Type>
237 inline void
239 OutputType & orientedDerivative,
241
243 template <typename Type>
244 inline void
246 OutputType & derivative,
248
250 // NOTE: for some unknown reason, making these methods inline (as those above are inlined) makes them run *slower*.
251 template <typename Type>
252 void
254 OutputType & orientedDerivative,
256
258 template <typename Type>
259 void
261
262 // flag to take or not the image direction into account
263 // when computing the derivatives.
264 bool m_UseImageDirection{ true };
265
266 // interpolator
267 InterpolatorPointer m_Interpolator{};
268};
269} // end namespace itk
270
271#ifndef ITK_MANUAL_INSTANTIATION
272# include "itkCentralDifferenceImageFunction.hxx"
273#endif
274
275#endif
Calculate the derivative by central differencing.
OutputType EvaluateAtIndex(const IndexType &index) const override
OutputType EvaluateAtContinuousIndex(const ContinuousIndexType &cindex) const override
OutputType Evaluate(const PointType &point) const override
void EvaluateSpecialized(const PointType &point, OutputType &orientedDerivative, OutputTypeSpecializationStructType< OutputType >) const
~CentralDifferenceImageFunction() override=default
typename InputImageType::PixelType InputPixelType
typename InterpolatorType::Pointer InterpolatorPointer
virtual void SetInterpolator(InterpolatorType *interpolator)
void EvaluateSpecialized(const PointType &point, OutputType &derivative, OutputTypeSpecializationStructType< Type >) const
void EvaluateAtContinuousIndexSpecialized(const ContinuousIndexType &cindex, OutputType &derivative, OutputTypeSpecializationStructType< Type >) const
typename OutputConvertType::ComponentType OutputValueType
void EvaluateAtIndexSpecialized(const IndexType &index, OutputType &orientedDerivative, OutputTypeSpecializationStructType< OutputType >) const
void EvaluateAtContinuousIndexSpecialized(const ContinuousIndexType &cindex, OutputType &orientedDerivative, OutputTypeSpecializationStructType< OutputType >) const
void EvaluateAtIndexSpecialized(const IndexType &index, OutputType &derivative, OutputTypeSpecializationStructType< Type >) const
void PrintSelf(std::ostream &os, Indent indent) const override
void SetInputImage(const TInputImage *inputData) override
A templated class holding a n-Dimensional covariant vector.
Traits class used to by ConvertPixels to convert blocks of pixels.
typename PixelType::ComponentType ComponentType
Evaluates a function of an image at specified position.
Control indentation during Print() invocation.
Definition: itkIndent.h:50
Base class for all image interpolators.
Light weight base class for most itk classes.
A templated class holding a geometric point in n-Dimensional space.
Definition: itkPoint.h:54
SmartPointer< Self > Pointer
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
*par Constraints *The filter image with at least two dimensions and a vector *length of at least The theory supports extension to scalar but *the implementation of the itk vector classes do not **The template parameter TRealType must be floating point(float or double) or *a user-defined "real" numerical type with arithmetic operations defined *sufficient to compute derivatives. **\par Performance *This filter will automatically multithread if run with *SetUsePrincipleComponents