ITK  5.3.0
Insight Toolkit
itkConstrainedRegionBasedLevelSetFunctionSharedData.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  * 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 itkConstrainedRegionBasedLevelSetFunctionSharedData_h
19 #define itkConstrainedRegionBasedLevelSetFunctionSharedData_h
20 
22 
23 namespace itk
24 {
60 template <typename TInputImage, typename TFeatureImage, typename TSingleData>
62  : public RegionBasedLevelSetFunctionSharedData<TInputImage, TFeatureImage, TSingleData>
63 {
64 public:
65  ITK_DISALLOW_COPY_AND_MOVE(ConstrainedRegionBasedLevelSetFunctionSharedData);
66 
71 
72  static constexpr unsigned int ImageDimension = TFeatureImage::ImageDimension;
73 
75  itkNewMacro(Self);
76 
78 
79  using InputImageType = TInputImage;
80  using typename Superclass::InputImagePointer;
82  using typename Superclass::InputPixelType;
83  using typename Superclass::InputRegionType;
84  using typename Superclass::InputSizeType;
85  using typename Superclass::InputSizeValueType;
86  using typename Superclass::InputSpacingType;
87  using typename Superclass::InputIndexType;
88  using typename Superclass::InputIndexValueType;
89  using typename Superclass::InputPointType;
90 
91  using FeatureImageType = TFeatureImage;
92  using typename Superclass::FeatureImagePointer;
94  using typename Superclass::FeaturePixelType;
95  using typename Superclass::FeatureRegionType;
96  using typename Superclass::FeatureSizeType;
97  using typename Superclass::FeatureSizeValueType;
98  using typename Superclass::FeatureSpacingType;
99  using typename Superclass::FeatureIndexType;
100  using typename Superclass::FeaturePointType;
101 
102  using typename Superclass::ListPixelType;
103  using typename Superclass::ListImageType;
104  using typename Superclass::ListImagePointer;
105  using typename Superclass::ListImageConstPointer;
106  using typename Superclass::ListRegionType;
107  using typename Superclass::ListSizeType;
108  using typename Superclass::ListSizeValueType;
109  using typename Superclass::ListSpacingType;
110  using typename Superclass::ListIndexType;
111  using typename Superclass::ListIndexValueType;
112  using typename Superclass::ListPointType;
113  using typename Superclass::ListIteratorType;
114 
115  using typename Superclass::CentroidVectorType;
116  using typename Superclass::SampleType;
117  using typename Superclass::TreeGeneratorType;
118  using typename Superclass::TreePointer;
119  using typename Superclass::TreeType;
120  using typename Superclass::KdTreePointer;
121 
122  using LevelSetDataType = TSingleData;
123  using typename Superclass::LevelSetDataPointer;
126 
127  void
128  PopulateListImage() override
129  {
130  ListSpacingType spacing = this->m_NearestNeighborListImage->GetSpacing();
131 
132  ListRegionType region = this->m_NearestNeighborListImage->GetLargestPossibleRegion();
133 
134  ListIteratorType lIt(this->m_NearestNeighborListImage, region);
135 
136  if (this->m_KdTree.IsNotNull())
137  {
138  for (lIt.GoToBegin(); !lIt.IsAtEnd(); ++lIt)
139  {
140  ListIndexType ind = lIt.GetIndex();
141 
142  float queryPoint[ImageDimension];
143  for (unsigned int i = 0; i < ImageDimension; ++i)
144  {
145  queryPoint[i] = ind[i] * spacing[i];
146  }
147 
148  typename TreeType::InstanceIdentifierVectorType neighbors;
149  this->m_KdTree->Search(queryPoint, this->m_NumberOfNeighbors, neighbors);
150 
151  ListPixelType L;
152  for (unsigned int i = 0; i < this->m_NumberOfNeighbors; ++i)
153  {
154  if (this->m_LevelSetDataPointerVector[i]->VerifyInsideRegion(ind))
155  {
156  L.push_back(neighbors[i]);
157  }
158  }
159  lIt.Set(L);
160  }
161  }
162  else
163  {
164  for (lIt.GoToBegin(); !lIt.IsAtEnd(); ++lIt)
165  {
166  ListIndexType ind = lIt.GetIndex();
167  ListPixelType L;
168  for (unsigned int i = 0; i < this->m_FunctionCount; ++i)
169  {
170  if (this->m_LevelSetDataPointerVector[i]->VerifyInsideRegion(ind))
171  {
172  L.push_back(i);
173  }
174  }
175  lIt.Set(L);
176  }
177  }
178  }
179 
180 protected:
182  : Superclass()
183  {}
185 };
186 } // end namespace itk
187 
188 #endif
itk::RegionBasedLevelSetFunctionSharedData::m_NumberOfNeighbors
unsigned int m_NumberOfNeighbors
Definition: itkRegionBasedLevelSetFunctionSharedData.h:178
itk::RegionBasedLevelSetFunctionSharedData::m_KdTree
KdTreePointer m_KdTree
Definition: itkRegionBasedLevelSetFunctionSharedData.h:180
itk::RegionBasedLevelSetFunctionSharedData::FeatureIndexType
typename FeatureImageType::IndexType FeatureIndexType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:102
itk::ConstrainedRegionBasedLevelSetFunctionSharedData::LevelSetDataType
TSingleData LevelSetDataType
Definition: itkConstrainedRegionBasedLevelSetFunctionSharedData.h:122
itk::RegionBasedLevelSetFunctionSharedData::ListPixelType
std::list< unsigned int > ListPixelType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:105
itk::ConstrainedRegionBasedLevelSetFunctionSharedData::ImageDimension
static constexpr unsigned int ImageDimension
Definition: itkConstrainedRegionBasedLevelSetFunctionSharedData.h:72
itk::RegionBasedLevelSetFunctionSharedData::m_NearestNeighborListImage
ListImagePointer m_NearestNeighborListImage
Definition: itkRegionBasedLevelSetFunctionSharedData.h:179
itk::RegionBasedLevelSetFunctionSharedData::InputImageConstPointer
typename InputImageType::ConstPointer InputImageConstPointer
Definition: itkRegionBasedLevelSetFunctionSharedData.h:84
itk::RegionBasedLevelSetFunctionSharedData::m_FunctionCount
unsigned int m_FunctionCount
Definition: itkRegionBasedLevelSetFunctionSharedData.h:177
itk::RegionBasedLevelSetFunctionSharedData::ListSizeType
typename ListImageType::SizeType ListSizeType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:110
itk::RegionBasedLevelSetFunctionSharedData::ListSizeValueType
typename ListSizeType::SizeValueType ListSizeValueType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:111
itk::RegionBasedLevelSetFunctionSharedData::FeatureSizeValueType
typename FeatureSizeType::SizeValueType FeatureSizeValueType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:100
itk::RegionBasedLevelSetFunctionSharedData::InputSizeValueType
typename InputSizeType::SizeValueType InputSizeValueType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:88
itk::RegionBasedLevelSetFunctionSharedData::TreePointer
typename TreeGeneratorType::Pointer TreePointer
Definition: itkRegionBasedLevelSetFunctionSharedData.h:121
itk::SmartPointer< Self >
itk::RegionBasedLevelSetFunctionSharedData::KdTreePointer
typename TreeType::Pointer KdTreePointer
Definition: itkRegionBasedLevelSetFunctionSharedData.h:123
itk::RegionBasedLevelSetFunctionSharedData::TreeType
typename TreeGeneratorType::KdTreeType TreeType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:122
itk::ImageConstIteratorWithIndex::GetIndex
const IndexType & GetIndex() const
Definition: itkImageConstIteratorWithIndex.h:220
itk::RegionBasedLevelSetFunctionSharedData::InputIndexValueType
typename InputIndexType::IndexValueType InputIndexValueType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:91
itk::ConstrainedRegionBasedLevelSetFunctionSharedData
Helper class used to share data in the ScalarChanAndVeseLevelSetFunction.
Definition: itkConstrainedRegionBasedLevelSetFunctionSharedData.h:61
itk::RegionBasedLevelSetFunctionSharedData::TreeGeneratorType
itk::Statistics::KdTreeGenerator< SampleType > TreeGeneratorType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:120
itk::RegionBasedLevelSetFunctionSharedData::FeaturePixelType
typename FeatureImageType::PixelType FeaturePixelType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:97
itk::RegionBasedLevelSetFunctionSharedData::InputImagePointer
typename InputImageType::Pointer InputImagePointer
Definition: itkRegionBasedLevelSetFunctionSharedData.h:83
itk::RegionBasedLevelSetFunctionSharedData::FeatureSizeType
typename FeatureImageType::SizeType FeatureSizeType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:99
itkRegionBasedLevelSetFunctionSharedData.h
itk::RegionBasedLevelSetFunctionSharedData::ListImageConstPointer
typename ListImageType::ConstPointer ListImageConstPointer
Definition: itkRegionBasedLevelSetFunctionSharedData.h:108
itk::ConstrainedRegionBasedLevelSetFunctionSharedData::PopulateListImage
void PopulateListImage() override
Definition: itkConstrainedRegionBasedLevelSetFunctionSharedData.h:128
itk::RegionBasedLevelSetFunctionSharedData::ListSpacingType
typename ListImageType::SpacingType ListSpacingType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:112
itk::RegionBasedLevelSetFunctionSharedData::ListIteratorType
ImageRegionIteratorWithIndex< ListImageType > ListIteratorType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:116
itk::LightObject
Light weight base class for most itk classes.
Definition: itkLightObject.h:59
itk::RegionBasedLevelSetFunctionSharedData::InputSpacingType
typename InputImageType::SpacingType InputSpacingType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:89
itk::RegionBasedLevelSetFunctionSharedData::FeatureImagePointer
typename FeatureImageType::Pointer FeatureImagePointer
Definition: itkRegionBasedLevelSetFunctionSharedData.h:95
itk::RegionBasedLevelSetFunctionSharedData::InputIndexType
typename InputImageType::IndexType InputIndexType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:90
itk::RegionBasedLevelSetFunctionSharedData::InputPixelType
typename InputImageType::PixelType InputPixelType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:85
itk::RegionBasedLevelSetFunctionSharedData::ListImageType
Image< ListPixelType, Self::ImageDimension > ListImageType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:106
itk::RegionBasedLevelSetFunctionSharedData::InputPointType
typename InputImageType::PointType InputPointType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:92
itk::RegionBasedLevelSetFunctionSharedData::CentroidVectorType
Vector< float, Self::ImageDimension > CentroidVectorType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:118
itk::RegionBasedLevelSetFunctionSharedData::InputSizeType
typename InputImageType::SizeType InputSizeType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:87
itk::RegionBasedLevelSetFunctionSharedData::ListIndexType
typename ListImageType::IndexType ListIndexType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:113
itk::ImageRegionIteratorWithIndex::Set
void Set(const PixelType &value) const
Definition: itkImageRegionIteratorWithIndex.h:109
itk::RegionBasedLevelSetFunctionSharedData::FeaturePointType
typename FeatureImageType::PointType FeaturePointType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:103
itk::RegionBasedLevelSetFunctionSharedData::ListPointType
typename ListImageType::PointType ListPointType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:115
itk::RegionBasedLevelSetFunctionSharedData::FeatureImageConstPointer
typename FeatureImageType::ConstPointer FeatureImageConstPointer
Definition: itkRegionBasedLevelSetFunctionSharedData.h:96
itk::ConstrainedRegionBasedLevelSetFunctionSharedData::~ConstrainedRegionBasedLevelSetFunctionSharedData
~ConstrainedRegionBasedLevelSetFunctionSharedData() override=default
itk::ImageRegionIteratorWithIndex
A multi-dimensional iterator templated over image type that walks pixels within a region and is speci...
Definition: itkImageRegionIteratorWithIndex.h:73
itk::RegionBasedLevelSetFunctionSharedData::ListRegionType
typename ListImageType::RegionType ListRegionType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:109
itk::RegionBasedLevelSetFunctionSharedData::InputRegionType
typename InputImageType::RegionType InputRegionType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:86
itk::ConstrainedRegionBasedLevelSetFunctionSharedData::FeatureImageType
TFeatureImage FeatureImageType
Definition: itkConstrainedRegionBasedLevelSetFunctionSharedData.h:91
itk::ImageConstIteratorWithIndex::GoToBegin
void GoToBegin()
itk::RegionBasedLevelSetFunctionSharedData::LevelSetDataPointerVectorIterator
typename LevelSetDataPointerVector::iterator LevelSetDataPointerVectorIterator
Definition: itkRegionBasedLevelSetFunctionSharedData.h:128
itk::RegionBasedLevelSetFunctionSharedData::FeatureRegionType
typename FeatureImageType::RegionType FeatureRegionType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:98
itk::ImageConstIteratorWithIndex::IsAtEnd
bool IsAtEnd() const
Definition: itkImageConstIteratorWithIndex.h:276
itk::RegionBasedLevelSetFunctionSharedData
Helper class used to share data in the ScalarChanAndVeseLevelSetFunction.
Definition: itkRegionBasedLevelSetFunctionSharedData.h:68
itk
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
Definition: itkAnnulusOperator.h:24
itk::ConstrainedRegionBasedLevelSetFunctionSharedData::InputImageType
TInputImage InputImageType
Definition: itkConstrainedRegionBasedLevelSetFunctionSharedData.h:79
itk::RegionBasedLevelSetFunctionSharedData::ListImagePointer
typename ListImageType::Pointer ListImagePointer
Definition: itkRegionBasedLevelSetFunctionSharedData.h:107
itk::RegionBasedLevelSetFunctionSharedData::m_LevelSetDataPointerVector
LevelSetDataPointerVector m_LevelSetDataPointerVector
Definition: itkRegionBasedLevelSetFunctionSharedData.h:175
itk::RegionBasedLevelSetFunctionSharedData::SampleType
itk::Statistics::ListSample< CentroidVectorType > SampleType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:119
itk::RegionBasedLevelSetFunctionSharedData::LevelSetDataPointer
typename LevelSetDataType::Pointer LevelSetDataPointer
Definition: itkRegionBasedLevelSetFunctionSharedData.h:126
itk::RegionBasedLevelSetFunctionSharedData::ListIndexValueType
typename ListIndexType::IndexValueType ListIndexValueType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:114
itk::RegionBasedLevelSetFunctionSharedData::FeatureSpacingType
typename FeatureImageType::SpacingType FeatureSpacingType
Definition: itkRegionBasedLevelSetFunctionSharedData.h:101
itk::RegionBasedLevelSetFunctionSharedData::LevelSetDataPointerVector
std::vector< LevelSetDataPointer > LevelSetDataPointerVector
Definition: itkRegionBasedLevelSetFunctionSharedData.h:127
itk::ConstrainedRegionBasedLevelSetFunctionSharedData::ConstrainedRegionBasedLevelSetFunctionSharedData
ConstrainedRegionBasedLevelSetFunctionSharedData()
Definition: itkConstrainedRegionBasedLevelSetFunctionSharedData.h:181