ITK 6.0.0
Insight Toolkit
 
Loading...
Searching...
No Matches
itkUnconstrainedRegionBasedLevelSetFunctionSharedData.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 itkUnconstrainedRegionBasedLevelSetFunctionSharedData_h
19#define itkUnconstrainedRegionBasedLevelSetFunctionSharedData_h
20
22
23namespace itk
24{
42template <typename TInputImage, typename TFeatureImage, typename TSingleData>
44 : public RegionBasedLevelSetFunctionSharedData<TInputImage, TFeatureImage, TSingleData>
45{
46public:
48
53
54 static constexpr unsigned int ImageDimension = TFeatureImage::ImageDimension;
55
57 itkNewMacro(Self);
58
60
61 using InputImageType = TInputImage;
62 using typename Superclass::InputImagePointer;
64 using typename Superclass::InputPixelType;
65 using typename Superclass::InputRegionType;
66 using typename Superclass::InputSizeType;
67 using typename Superclass::InputSizeValueType;
68 using typename Superclass::InputSpacingType;
69 using typename Superclass::InputIndexType;
71 using typename Superclass::InputPointType;
72
73 using FeatureImageType = TFeatureImage;
76 using typename Superclass::FeaturePixelType;
77 using typename Superclass::FeatureRegionType;
78 using typename Superclass::FeatureSizeType;
80 using typename Superclass::FeatureSpacingType;
81 using typename Superclass::FeatureIndexType;
82 using typename Superclass::FeaturePointType;
83
84 using typename Superclass::ListPixelType;
85 using typename Superclass::ListImageType;
86 using typename Superclass::ListImagePointer;
88 using typename Superclass::ListRegionType;
89 using typename Superclass::ListSizeType;
90 using typename Superclass::ListSizeValueType;
91 using typename Superclass::ListSpacingType;
92 using typename Superclass::ListIndexType;
93 using typename Superclass::ListIndexValueType;
94 using typename Superclass::ListPointType;
95 using typename Superclass::ListIteratorType;
96
97 using typename Superclass::CentroidVectorType;
98 using typename Superclass::SampleType;
99 using typename Superclass::TreeGeneratorType;
100 using typename Superclass::TreePointer;
101 using typename Superclass::TreeType;
102 using typename Superclass::KdTreePointer;
103
104 using LevelSetDataType = TSingleData;
105 using typename Superclass::LevelSetDataPointer;
108
109 void
111 {
113
114 for (unsigned int i = 0; i < this->m_FunctionCount; ++i)
115 {
116 L.push_back(i);
117 }
118 this->m_NearestNeighborListImage->FillBuffer(L);
119 }
120
121protected:
126};
127} // end namespace itk
128
129#endif
itk::Statistics::ListSample< CentroidVectorType > SampleType
typename LevelSetDataPointerVector::iterator LevelSetDataPointerVectorIterator
ImageRegionIteratorWithIndex< ListImageType > ListIteratorType
Image< ListPixelType, Self::ImageDimension > ListImageType
itk::Statistics::KdTreeGenerator< SampleType > TreeGeneratorType
Implements transparent reference counting.
RegionBasedLevelSetFunctionSharedData< TInputImage, TFeatureImage, TSingleData > Superclass
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....