ITK 6.0.0
Insight Toolkit
 
Loading...
Searching...
No Matches
itkFastMarchingStoppingCriterionBase.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
19#ifndef itkFastMarchingStoppingCriterionBase_h
20#define itkFastMarchingStoppingCriterionBase_h
21
23#include "itkNumericTraits.h"
25
26namespace itk
27{
28
35template <typename TInput, typename TOutput>
37{
38public:
39 ITK_DISALLOW_COPY_AND_MOVE(FastMarchingStoppingCriterionBase);
40
46
47 using NodeType = typename Traits::NodeType;
48 using OutputPixelType = typename Traits::OutputPixelType;
49 using NodePairType = typename Traits::NodePairType;
50 using OutputDomainType = typename Traits::OutputDomainType;
51 using OutputDomainPointer = typename Traits::OutputDomainPointer;
52
54 itkOverrideGetNameOfClassMacro(FastMarchingStoppingCriterionBase);
55
57 void
65
66 void
68 {
69 this->SetCurrentNode(iNodePair.GetNode());
70 this->SetCurrentValue(iNodePair.GetValue());
71 }
72
73 itkSetObjectMacro(Domain, OutputDomainType);
74 itkGetModifiableObjectMacro(Domain, OutputDomainType);
75
76protected:
85
88
90
93
96 virtual void
97 Reset() = 0;
98
100 virtual void
101 SetCurrentNode(const NodeType & iNode) = 0;
102
104 virtual void
106 {
108 m_CurrentValue = iValue;
109 }
110};
111} // namespace itk
112#endif
virtual void SetCurrentValue(const OutputPixelType &iValue)
typename Traits::OutputDomainPointer OutputDomainPointer
virtual void SetCurrentNode(const NodeType &iNode)=0
~FastMarchingStoppingCriterionBase() override=default
Base class traits to be used by the FastMarchingBase.
Implements transparent reference counting.
StoppingCriterionBase()
Constructor.
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....