28 #ifndef itkBSplineDecompositionImageFilter_h
29 #define itkBSplineDecompositionImageFilter_h
34 #include "vnl/vnl_matrix.h"
72 template<
typename TInputImage,
typename TOutputImage >
98 itkStaticConstMacro(ImageDimension,
unsigned int, TInputImage::ImageDimension);
99 itkStaticConstMacro(OutputImageDimension,
unsigned int,
100 TOutputImage::ImageDimension);
108 void SetSplineOrder(
unsigned int SplineOrder);
110 itkGetConstMacro(SplineOrder,
int);
112 #ifdef ITK_USE_CONCEPT_CHECKING
118 typename TOutputImage::PixelType > ) );
127 void PrintSelf(std::ostream & os,
Indent indent)
const ITK_OVERRIDE;
129 void GenerateData() ITK_OVERRIDE;
132 void GenerateInputRequestedRegion() ITK_OVERRIDE;
135 void EnlargeOutputRequestedRegion(
DataObject *output) ITK_OVERRIDE;
140 typename TInputImage::SizeType m_DataLength;
142 unsigned int m_SplineOrder;
144 double m_SplinePoles[3];
150 unsigned int m_IteratorDirection;
157 virtual
void SetPoles();
160 virtual
bool DataToCoefficients1D();
164 void DataToCoefficientsND();
167 virtual
void SetInitialCausalCoefficient(
double z);
171 virtual
void SetInitialAntiCausalCoefficient(
double z);
174 void CopyImageToImage();
181 void CopyScratchToCoefficients(OutputLinearIterator &);
185 #ifndef ITK_MANUAL_INSTANTIATION
186 #include "itkBSplineDecompositionImageFilter.hxx"
A multi-dimensional image iterator that visits image pixels within a region in a "scan-line" order...
ImageLinearIteratorWithIndex< TOutputImage > OutputLinearIterator
ImageToImageFilter< TInputImage, TOutputImage > Superclass
Base class for all process objects that output image data.
virtual ~BSplineDecompositionImageFilter()
BSplineDecompositionImageFilter Self
SmartPointer< Self > Pointer
itk::NumericTraits< typename TOutputImage::PixelType >::RealType CoeffType
Superclass::InputImagePointer InputImagePointer
SmartPointer< const Self > ConstPointer
Calculates the B-Spline coefficients of an image. Spline order may be from 0 to 5.
Superclass::InputImageType InputImageType
Base class for filters that take an image as input and produce an image as output.
Control indentation during Print() invocation.
Superclass::OutputImagePointer OutputImagePointer
#define itkConceptMacro(name, concept)
Superclass::InputImageConstPointer InputImageConstPointer
Base class for all data objects in ITK.