18#ifndef itkRayCastInterpolateImageFunction_h
19#define itkRayCastInterpolateImageFunction_h
40template <
typename TInputImage,
typename TCoordinate =
double>
69 using SizeType =
typename TInputImage::SizeType;
151 itkSetMacro(Threshold,
double);
152 itkGetConstMacro(Threshold,
double);
182 itkExceptionMacro(
"Input image required!");
184 return input->GetLargestPossibleRegion().GetSize();
234#ifndef ITK_MANUAL_INSTANTIATION
235# include "itkRayCastInterpolateImageFunction.hxx"
Contains all enum classes used by RayCastHelper class.
@ UNDEFINED_DIRECTION
Undefined.
typename InputImageType::PixelType InputPixelType
const InputImageType * GetInputImage() const
Control indentation during Print() invocation.
typename NumericTraits< typename TInputImage::PixelType >::RealType RealType
InterpolateImageFunction()=default
typename InputImageType::IndexType IndexType
Point< TCoordinate, Self::ImageDimension > PointType
SmartPointer< Self > Pointer
ContinuousIndex< TCoordinate, Self::ImageDimension > ContinuousIndexType
TInputImage InputImageType
static constexpr unsigned int ImageDimension
OutputType EvaluateAtContinuousIndex(const ContinuousIndexType &index) const override
ContinuousIndex< TCoordinate, Self::ImageDimension > ContinuousIndexType
Transform< TCoordinate, 3, 3 > TransformType
InterpolateImageFunction< TInputImage, TCoordinate > Superclass
TInputImage InputImageType
OutputType Evaluate(const PointType &point) const override
Interpolate the image at a point position.
SizeType GetRadius() const override
void PrintSelf(std::ostream &os, Indent indent) const override
Vector< TCoordinate, 3 > DirectionType
bool IsInsideBuffer(const PointType &) const override
RayCastInterpolateImageFunction Self
RayCastInterpolateImageFunction()
TransformPointer m_Transform
bool IsInsideBuffer(const IndexType &) const override
~RayCastInterpolateImageFunction() override=default
typename TInputImage::SizeType SizeType
typename InputImageType::IndexType IndexType
InterpolateImageFunction< TInputImage, TCoordinate > InterpolatorType
SmartPointer< Self > Pointer
typename TransformType::OutputPointType OutputPointType
static constexpr unsigned int ImageDimension
typename InterpolatorType::Pointer InterpolatorPointer
InputPointType m_FocalPoint
typename Superclass::InputPixelType PixelType
typename TransformType::ParametersType TransformParametersType
typename TransformType::JacobianType TransformJacobianType
SmartPointer< const Self > ConstPointer
InterpolatorPointer m_Interpolator
typename TransformType::Pointer TransformPointer
static constexpr unsigned int InputImageDimension
bool IsInsideBuffer(const ContinuousIndexType &) const override
Point< TCoordinate, Self::ImageDimension > PointType
typename TransformType::InputPointType InputPointType
Implements transparent reference counting.
A templated class holding a n-Dimensional vector.
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