ITK  6.0.0
Insight Toolkit
itkSimplexMeshVolumeCalculator.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 itkSimplexMeshVolumeCalculator_h
19#define itkSimplexMeshVolumeCalculator_h
20
21#include "itkIntTypes.h"
22#include "itkPolygonCell.h"
23#include "itkVector.h"
24#include "itkSimplexMesh.h"
25#include "itkVectorContainer.h"
26
27namespace itk
28{
53template <typename TInputMesh>
54class ITK_TEMPLATE_EXPORT SimplexMeshVolumeCalculator : public Object
55{
56public:
57 ITK_DISALLOW_COPY_AND_MOVE(SimplexMeshVolumeCalculator);
58
61
64
68
70 itkNewMacro(Self);
71
73 itkOverrideGetNameOfClassMacro(SimplexMeshVolumeCalculator);
74
75 using InputMeshType = TInputMesh;
78
80 using InputPixelType = typename InputMeshType::PixelType;
81 using InputCellTraitsType = typename InputMeshType::MeshTraits::CellTraits;
82
83 using InputPointsContainer = typename InputMeshType::PointsContainer;
85 using InputPointsContainerIterator = typename InputPointsContainer::ConstIterator;
86
87 using InputNeighbors = typename InputMeshType::NeighborListType;
88 using InputNeighborsIterator = typename InputMeshType::NeighborListType::iterator;
89
90 using SimplexCellType = typename InputMeshType::CellType;
92
93 // stores the center for each simplex mesh cell, key is the point id
96
99
108 {
109 public:
110
115 virtual ~SimplexCellVisitor() = default;
121 void
123 {
124 using PointIdIterator = typename SimplexPolygonType::PointIdIterator;
125 PointIdIterator it = poly->PointIdsBegin();
126 InputPointType center{};
127 InputPointType p{};
130 while (it != poly->PointIdsEnd())
131 {
132 m_Mesh->GetPoint(*it, &p);
133 center += p.GetVectorFromOrigin();
134 ++it;
135 }
136
137 center[0] /= poly->GetNumberOfPoints();
138 center[1] /= poly->GetNumberOfPoints();
139 center[2] /= poly->GetNumberOfPoints();
140
141 m_CenterMap->InsertElement(cellId, center);
142 }
143
146 {
147 return m_CenterMap;
148 }
149
150 void
152 {
153 m_Mesh = mesh;
154 }
155
156 protected:
159 };
160
162 CellInterfaceVisitorImplementation<InputPixelType, InputCellTraitsType, SimplexPolygonType, SimplexCellVisitor>;
163
165 using CellMultiVisitorType = typename SimplexCellType::MultiVisitor;
167
169 itkSetObjectMacro(SimplexMesh, InputMeshType);
170
172 void
174
176 itkGetConstMacro(Volume, double);
177
179 itkGetConstMacro(Area, double);
180
181protected:
183 ~SimplexMeshVolumeCalculator() override = default;
184 void
185 PrintSelf(std::ostream & os, Indent indent) const override;
186
187private:
188 void
190
191 void
193
195 void
197
199 void
201
205
207 PointMapPointer m_Centers{};
208
209 InputMeshPointer m_SimplexMesh{};
210
211 double m_Volume{ 0.0 };
212 double m_VolumeX{ 0.0 };
213 double m_VolumeY{ 0.0 };
214 double m_VolumeZ{ 0.0 };
215 double m_Area{ 0.0 };
216 double m_Kx{ 0.0 };
217 double m_Ky{ 0.0 };
218 double m_Kz{ 0.0 };
219 double m_Wxyz{ 0.0 };
220 double m_Wxy{ 0.0 };
221 double m_Wxz{ 0.0 };
222 double m_Wyz{ 0.0 };
223
224 IndexValueType m_Muncx{ 0 };
225 IndexValueType m_Muncy{ 0 };
226 IndexValueType m_Muncz{ 0 };
227
228 SizeValueType m_NumberOfTriangles{ 0 };
229};
230} // namespace itk
231
232#ifndef ITK_MANUAL_INSTANTIATION
233# include "itkSimplexMeshVolumeCalculator.hxx"
234#endif
235
236#endif /* __SimplexMeshVolumeCalculator_h */
A template class used to implement a visitor object.
A templated class holding a n-Dimensional covariant vector.
Control indentation during Print() invocation.
Definition: itkIndent.h:50
Light weight base class for most itk classes.
A wrapper of the STL "map" container.
Base class for most ITK classes.
Definition: itkObject.h:62
Represents a polygon in a Mesh.
unsigned int GetNumberOfPoints() const override
PointIdIterator PointIdsEnd() override
PointIdIterator PointIdsBegin() override
void Visit(IdentifierType cellId, SimplexPolygonType *poly)
visits all polygon cells and compute the cell centers
Adapted from itkSimplexMeshToTriangleFilter to calculate the volume of a simplex mesh using the baryc...
typename CellMultiVisitorType::Pointer CellMultiVisitorPointer
typename InputMeshType::PointType InputPointType
typename InputMeshType::ConstPointer InputMeshConstPointer
typename SimplexCellType::MultiVisitor CellMultiVisitorType
typename SimplexVisitorInterfaceType::Pointer SimplexVisitorInterfacePointer
typename InputMeshType::NeighborListType::iterator InputNeighborsIterator
typename InputMeshType::Pointer InputMeshPointer
typename PointMapType::Pointer PointMapPointer
IdentifierType FindCellId(IdentifierType id1, IdentifierType id2, IdentifierType id3)
typename InputPointsContainer::ConstIterator InputPointsContainerIterator
typename InputPointType::VectorType VectorType
typename InputPointsContainer::ConstPointer InputPointsContainerPointer
~SimplexMeshVolumeCalculator() override=default
typename InputMeshType::MeshTraits::CellTraits InputCellTraitsType
typename InputMeshType::PixelType InputPixelType
void CalculateTriangleVolume(InputPointType p1, InputPointType p2, InputPointType p3)
typename InputMeshType::NeighborListType InputNeighbors
typename InputMeshType::PointsContainer InputPointsContainer
void PrintSelf(std::ostream &os, Indent indent) const override
typename InputMeshType::CellType SimplexCellType
The class represents a 2-simplex mesh.
SmartPointer< const Self > ConstPointer
static Pointer New()
SmartPointer< Self > Pointer
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
long IndexValueType
Definition: itkIntTypes.h:93
SizeValueType IdentifierType
Definition: itkIntTypes.h:90
unsigned long SizeValueType
Definition: itkIntTypes.h:86