ITK 6.0.0
Insight Toolkit
 
Loading...
Searching...
No Matches
itkLevelSet.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 itkLevelSet_h
19#define itkLevelSet_h
20
21#include "itkLevelSetNode.h"
22
23namespace itk
24{
39template <typename TLevelSet>
41{
42public:
45 using LevelSetImageType = TLevelSet;
46
48 static constexpr unsigned int SetDimension = TLevelSet::ImageDimension;
49
51 using LevelSetPointer = typename TLevelSet::Pointer;
52 using LevelSetConstPointer = typename TLevelSet::ConstPointer;
53
55 using PixelType = typename TLevelSet::PixelType;
56
59
62
65};
66
84template <typename TPixel, unsigned int VAuxDimension = 1, unsigned int VSetDimension = 2>
86{
87public:
88
91
93 using AuxValueType = TPixel;
94
96 static constexpr unsigned int AuxDimension = VAuxDimension;
97
99 static constexpr unsigned int SetDimension = VSetDimension;
100
103
106
109
113};
114} // end namespace itk
115
116#endif
Level set auxiliary variables type information.
Definition itkLevelSet.h:86
VectorContainer< unsigned int, AuxValueVectorType > AuxValueContainer
Templated n-dimensional image class.
Definition itkImage.h:89
SmartPointer< const Self > ConstPointer
Definition itkImage.h:97
Represent a node in a level set.
Level set type information.
Definition itkLevelSet.h:41
LevelSetNode< PixelType, Self::SetDimension > NodeType
Definition itkLevelSet.h:58
typename TLevelSet::PixelType PixelType
Definition itkLevelSet.h:55
LevelSetTypeDefault Self
Definition itkLevelSet.h:44
typename TLevelSet::ConstPointer LevelSetConstPointer
Definition itkLevelSet.h:52
typename NodeContainer::Pointer NodeContainerPointer
Definition itkLevelSet.h:64
static constexpr unsigned int SetDimension
Definition itkLevelSet.h:48
VectorContainer< unsigned int, NodeType > NodeContainer
Definition itkLevelSet.h:61
typename TLevelSet::Pointer LevelSetPointer
Definition itkLevelSet.h:51
A templated class holding a n-Dimensional vector.
Definition itkVector.h:63
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
detail::VectorContainer< std::conditional_t< std::is_void_v< T2 >, SizeValueType, T1 >, std::conditional_t< std::is_void_v< T2 >, T1, T2 > > VectorContainer