ITK  6.0.0
Insight Toolkit
itkMultiphaseFiniteDifferenceImageFilter.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 itkMultiphaseFiniteDifferenceImageFilter_h
19#define itkMultiphaseFiniteDifferenceImageFilter_h
20
23#include "vnl/vnl_vector.h"
25
26#include "itkListSample.h"
27#include "itkKdTreeGenerator.h"
28
29namespace itk
30{
157template <typename TInputImage,
158 typename TFeatureImage,
159 typename TOutputImage,
160 typename TFiniteDifferenceFunction = FiniteDifferenceFunction<TOutputImage>,
161 typename TIdCell = unsigned int>
162class ITK_TEMPLATE_EXPORT MultiphaseFiniteDifferenceImageFilter : public InPlaceImageFilter<TFeatureImage, TOutputImage>
163{
164public:
165 ITK_DISALLOW_COPY_AND_MOVE(MultiphaseFiniteDifferenceImageFilter);
166
172
174 itkOverrideGetNameOfClassMacro(MultiphaseFiniteDifferenceImageFilter);
175
177 static constexpr unsigned int ImageDimension = TOutputImage::ImageDimension;
178
180 using InputImageType = TInputImage;
183 using InputCoordinateType = typename InputPointType::CoordinateType;
184#ifndef ITK_FUTURE_LEGACY_REMOVE
185 using InputCoordRepType ITK_FUTURE_DEPRECATED(
186 "ITK 6 discourages using `InputCoordRepType`. Please use `InputCoordinateType` instead!") = InputCoordinateType;
187#endif
193 using InputPixelType = typename InputImageType::PixelType;
194 using InputSpacingType = typename InputImageType::SpacingType;
196
197 using FeatureImageType = TFeatureImage;
201 using FeatureSpacingType = typename FeatureImageType::SpacingType;
203 using FeaturePixelType = typename FeatureImageType::PixelType;
204
205 using OutputImageType = TOutputImage;
207 using OutputPixelType = typename OutputImageType::PixelType;
213
214 using IdCellType = TIdCell;
215 using VectorIdCellType = std::vector<IdCellType>;
216
220 using FiniteDifferenceFunctionType = TFiniteDifferenceFunction;
222 using TimeStepType = typename FiniteDifferenceFunctionType::TimeStepType;
223 using TimeStepVectorType = typename std::vector<TimeStepType>;
224 using RadiusType = typename FiniteDifferenceFunctionType::RadiusType;
225
232
238 GetDifferenceFunction(const IdCellType & functionIndex) const
239 {
240 if (functionIndex < m_FunctionCount)
241 {
242 return (this->m_DifferenceFunctions[functionIndex]);
243 }
244 else
245 {
246 return nullptr;
247 }
248 }
255 virtual void
257 {
258 if (functionIndex < m_FunctionCount)
259 {
260 this->m_DifferenceFunctions[functionIndex] = function;
261 }
262 }
266 itkSetMacro(NumberOfIterations, unsigned int);
267 itkGetConstReferenceMacro(NumberOfIterations, unsigned int);
272 itkSetMacro(UseImageSpacing, bool);
273 itkBooleanMacro(UseImageSpacing);
274 itkGetConstReferenceMacro(UseImageSpacing, bool);
279 itkSetMacro(MaximumRMSError, double);
280 itkGetConstReferenceMacro(MaximumRMSError, double);
285 itkSetMacro(RMSChange, double);
286 itkGetConstReferenceMacro(RMSChange, double);
290 itkSetMacro(InitializedState, bool);
291 itkGetConstReferenceMacro(InitializedState, bool);
292 itkBooleanMacro(InitializedState);
297 itkSetMacro(ManualReinitialization, bool);
298 itkGetConstReferenceMacro(ManualReinitialization, bool);
299 itkBooleanMacro(ManualReinitialization);
303 itkSetMacro(ElapsedIterations, unsigned int);
304
306 itkGetConstReferenceMacro(ElapsedIterations, unsigned int);
307
308 void
309 SetLevelSet(const IdCellType & i, const InputImageType * levelSet)
310 {
311 m_LevelSet[i] = InputImageType::New();
312 m_LevelSet[i]->SetRequestedRegion(levelSet->GetRequestedRegion());
313 m_LevelSet[i]->SetBufferedRegion(levelSet->GetBufferedRegion());
314 m_LevelSet[i]->SetLargestPossibleRegion(levelSet->GetLargestPossibleRegion());
315 m_LevelSet[i]->Allocate();
316 m_LevelSet[i]->CopyInformation(levelSet);
317
318 ImageRegionConstIterator<InputImageType> in(levelSet, levelSet->GetBufferedRegion());
319 ImageRegionIterator<InputImageType> cp(m_LevelSet[i], levelSet->GetBufferedRegion());
320
321 in.GoToBegin();
322 cp.GoToBegin();
323
324 while (!in.IsAtEnd())
325 {
326 cp.Set(in.Get());
327 ++in;
328 ++cp;
329 }
330 }
331
332 InputImagePointer
334 {
335 if (i >= m_FunctionCount)
336 {
337 itkExceptionMacro("Request for level set #" << i << " but there are only " << m_FunctionCount);
338 }
339 else
340 {
341 return m_LevelSet[i];
342 }
343 }
344
345 void
347 {
348 this->m_Lookup = lookup;
349 }
350
351 void
353 {
354 this->m_KdTree = kdtree;
355 }
356
357 void
359 {
360 m_FunctionCount = n;
361
362 m_DifferenceFunctions.resize(m_FunctionCount, nullptr);
363
364 constexpr auto radius = MakeFilled<RadiusType>(1);
365
366 for (unsigned int i = 0; i < this->m_FunctionCount; ++i)
367 {
368 this->m_DifferenceFunctions[i] = FiniteDifferenceFunctionType::New();
369 this->m_DifferenceFunctions[i]->Initialize(radius);
370 }
371
372 // Initialize the images
373 m_LevelSet.resize(m_FunctionCount, nullptr);
374
375 // Initialize the lookup table
376 this->m_Lookup.resize(m_FunctionCount);
377
378 IdCellType k = 1;
379
380 {
381 auto it = this->m_Lookup.begin();
382 auto _end = this->m_Lookup.end();
383 while (it != _end)
384 {
385 *it = k;
386 ++it;
387 ++k;
388 }
389 }
390 }
391
392protected:
394 {
395 this->m_KdTree = nullptr;
396 this->m_ElapsedIterations = 0;
397 this->m_MaximumRMSError = itk::Math::eps;
398 this->m_RMSChange = NumericTraits<double>::max();
399 this->m_UseImageSpacing = true;
400 this->m_ManualReinitialization = false;
401 this->m_InitializedState = false;
402 this->m_NumberOfIterations = NumericTraits<unsigned int>::max();
403 this->m_FunctionCount = 0;
404 this->InPlaceOff();
405 }
406
408
409 IdCellType m_FunctionCount{};
410 std::vector<InputImagePointer> m_LevelSet{};
412 KdTreePointer m_KdTree{};
413
414 unsigned int m_ElapsedIterations{};
415 double m_MaximumRMSError{};
416 double m_RMSChange{};
417 unsigned int m_NumberOfIterations{};
418
420 std::vector<FiniteDifferenceFunctionPointer> m_DifferenceFunctions{};
421
424 bool m_UseImageSpacing{};
425
426 void
427 PrintSelf(std::ostream & os, Indent indent) const override;
428
430 virtual void
432
436 virtual void
438
444 virtual TimeStepType
446
450 virtual void
452
456 void
457 GenerateData() override;
458
470 void
472
475 virtual bool
477
487 virtual bool
488 ThreadedHalt(void * itkNotUsed(threadInfo))
489 {
490 return this->Halt();
491 }
492
498 virtual void
500 {}
501
508 virtual void
510 {
511 for (IdCellType i = 0; i < this->m_FunctionCount; ++i)
512 {
513 this->m_DifferenceFunctions[i]->InitializeIteration();
514 }
515 }
531 inline TimeStepType
532 ResolveTimeStep(const TimeStepVectorType & timeStepList, const std::vector<uint8_t> & valid);
533
536 virtual void
538 {}
539
540private:
543 bool m_ManualReinitialization{};
544
546 bool m_InitializedState{};
547};
548} // end namespace itk
549
550#ifndef ITK_MANUAL_INSTANTIATION
551# include "itkMultiphaseFiniteDifferenceImageFilter.hxx"
552#endif
553
554#endif
A multi-dimensional iterator templated over image type that walks a region of pixels.
A multi-dimensional iterator templated over image type that walks a region of pixels.
void Set(const PixelType &value) const
Base class for all process objects that output image data.
TOutputImage OutputImageType
typename OutputImageType::Pointer OutputImagePointer
Base class for filters that take an image as input and overwrite that image as the output.
Control indentation during Print() invocation.
Definition: itkIndent.h:50
virtual void ApplyUpdate(TimeStepType dt)=0
virtual void SetDifferenceFunction(const IdCellType &functionIndex, FiniteDifferenceFunctionPointer function)
void SetLevelSet(const IdCellType &i, const InputImageType *levelSet)
typename FiniteDifferenceFunctionType::Pointer FiniteDifferenceFunctionPointer
typename FiniteDifferenceFunctionType::TimeStepType TimeStepType
~MultiphaseFiniteDifferenceImageFilter() override=default
virtual const FiniteDifferenceFunctionPointer GetDifferenceFunction(const IdCellType &functionIndex) const
typename FiniteDifferenceFunctionType::RadiusType RadiusType
TimeStepType ResolveTimeStep(const TimeStepVectorType &timeStepList, const std::vector< uint8_t > &valid)
void PrintSelf(std::ostream &os, Indent indent) const override
virtual TimeStepType CalculateChange()=0
static constexpr T max(const T &)
The base class for all process objects (source, filters, mappers) in the Insight data processing pipe...
This class generates a KdTree object without centroid information.
This class provides methods for k-nearest neighbor search and related data structures for a k-d tree.
Definition: itkKdTree.h:536
This class is the native implementation of the a Sample with an STL container.
Definition: itkListSample.h:52
A templated class holding a n-Dimensional vector.
Definition: itkVector.h:63
static Pointer New()
SmartPointer< Self > Pointer
static constexpr double eps
Definition: itkMath.h:97
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
long IndexValueType
Definition: itkIntTypes.h:93
unsigned long SizeValueType
Definition: itkIntTypes.h:86
long OffsetValueType
Definition: itkIntTypes.h:97