go home Home | Main Page | Modules | Namespace List | Class Hierarchy | Alphabetical List | Data Structures | File List | Namespace Members | Data Fields | Globals | Related Pages
elxNearestNeighborResampleInterpolator.h
Go to the documentation of this file.
1/*=========================================================================
2 *
3 * Copyright UMC Utrecht and contributors
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 * http://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 elxNearestNeighborResampleInterpolator_h
19#define elxNearestNeighborResampleInterpolator_h
20
21#include "elxIncludes.h" // include first to avoid MSVS warning
22#include "itkNearestNeighborInterpolateImageFunction.h"
23
24namespace elastix
25{
26
43template <class TElastix>
44class ITK_TEMPLATE_EXPORT NearestNeighborResampleInterpolator
45 : public itk::NearestNeighborInterpolateImageFunction<typename ResampleInterpolatorBase<TElastix>::InputImageType,
46 typename ResampleInterpolatorBase<TElastix>::CoordRepType>
47 , public ResampleInterpolatorBase<TElastix>
48{
49public:
51
55 itk::NearestNeighborInterpolateImageFunction<typename ResampleInterpolatorBase<TElastix>::InputImageType,
58 using Pointer = itk::SmartPointer<Self>;
59 using ConstPointer = itk::SmartPointer<const Self>;
60
62 itkNewMacro(Self);
63
65 itkTypeMacro(NearestNeighborResampleInterpolator, NearestNeighborInterpolateImageFunction);
66
71 elxClassNameMacro("FinalNearestNeighborInterpolator");
72
74 itkStaticConstMacro(ImageDimension, unsigned int, Superclass1::ImageDimension);
75
77 using typename Superclass1::OutputType;
78 using typename Superclass1::InputImageType;
79 using typename Superclass1::IndexType;
80 using typename Superclass1::ContinuousIndexType;
81
83 using typename Superclass2::ElastixType;
84 using typename Superclass2::RegistrationType;
86
87protected:
92
93private:
95};
96
97} // end namespace elastix
98
99#ifndef ITK_MANUAL_INSTANTIATION
100# include "elxNearestNeighborResampleInterpolator.hxx"
101#endif
102
103#endif // end elxNearestNeighborResampleInterpolator_h
~NearestNeighborResampleInterpolator() override=default
ITK_DISALLOW_COPY_AND_MOVE(NearestNeighborResampleInterpolator)
itk::NearestNeighborInterpolateImageFunction< typename ResampleInterpolatorBase< TElastix >::InputImageType, typename ResampleInterpolatorBase< TElastix >::CoordRepType > Superclass1
elxClassNameMacro("FinalNearestNeighborInterpolator")
itkStaticConstMacro(ImageDimension, unsigned int, Superclass1::ImageDimension)
This class is the elastix base class for all ResampleInterpolators.
itk::InterpolateImageFunction< InputImageType, CoordRepType > ITKBaseType
typename ElastixType::RegistrationBaseType RegistrationType


Generated on 2023-01-13 for elastix by doxygen 1.9.6 elastix logo