18#ifndef itkGradientImageFilter_h
19#define itkGradientImageFilter_h
31template <
typename TPixelType,
unsigned int VImageDimension>
63template <
typename TInputImage,
64 typename TOperatorValueType = float,
65 typename TOutputValueType = float,
66 typename TOutputImageType =
118 itkSetMacro(UseImageSpacing,
bool);
119 itkGetConstMacro(UseImageSpacing,
bool);
120 itkBooleanMacro(UseImageSpacing);
123#if !defined(ITK_FUTURE_LEGACY_REMOVE)
128 SetUseImageSpacingOn()
137 SetUseImageSpacingOff()
139 this->SetUseImageSpacing(
false);
160 itkSetMacro(UseImageDirection,
bool);
161 itkGetConstMacro(UseImageDirection,
bool);
162 itkBooleanMacro(UseImageDirection);
191 template <
typename TValue>
198 it.GetImage()->TransformLocalVectorToPhysicalVector(gradient, physicalGradient);
207 template <
typename T>
214 it.
GetImage()->TransformLocalVectorToPhysicalVector(gradient, it.
Value());
218 it.
Value() = gradient;
231 std::make_unique<ZeroFluxNeumannBoundaryCondition<TInputImage>>()
236#ifndef ITK_MANUAL_INSTANTIATION
237# include "itkGradientImageFilter.hxx"
A templated class holding a n-Dimensional covariant vector.
ValueType * GetDataPointer()
TOperatorValueType OperatorValueType
TOutputValueType OutputValueType
typename OutputImageType::Pointer OutputImagePointer
void GenerateInputRequestedRegion() override
std::unique_ptr< ImageBoundaryCondition< TInputImage, TInputImage > > m_BoundaryCondition
void OverrideBoundaryCondition(ImageBoundaryCondition< TInputImage > *boundaryCondition)
typename OutputImageType::RegionType OutputImageRegionType
typename OutputImageType::PixelType OutputPixelType
void PrintSelf(std::ostream &os, Indent indent) const override
CovariantVector< OutputValueType, Self::OutputImageDimension > CovariantVectorType
virtual void SetUseImageSpacing(bool _arg)
ImageToImageFilter< InputImageType, OutputImageType > Superclass
SmartPointer< const Self > ConstPointer
void SetOutputPixel(ImageRegionIterator< T > &it, CovariantVectorType &gradient)
TOutputImageType OutputImageType
SmartPointer< Self > Pointer
void DynamicThreadedGenerateData(const OutputImageRegionType &outputRegionForThread) override
void GenerateOutputInformation() override
typename InputImageType::PixelType InputPixelType
TInputImage InputImageType
~GradientImageFilter() override=default
static constexpr unsigned int InputImageDimension
void SetOutputPixel(ImageRegionIterator< VectorImage< TValue, OutputImageDimension > > &it, CovariantVectorType &gradient)
static constexpr unsigned int OutputImageDimension
typename InputImageType::Pointer InputImagePointer
A virtual base object that defines an interface to a class of boundary condition objects for use by n...
const ImageType * GetImage() const
A multi-dimensional iterator templated over image type that walks a region of pixels.
Templated n-dimensional image class.
Control indentation during Print() invocation.
Implements transparent reference counting.
Templated n-dimensional vector image class.
#define itkConceptMacro(name, concept)
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....