ITK  6.0.0
Insight Toolkit
itkDiscreteGaussianCurvatureQuadEdgeMeshFilter.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 itkDiscreteGaussianCurvatureQuadEdgeMeshFilter_h
19#define itkDiscreteGaussianCurvatureQuadEdgeMeshFilter_h
20
22#include "itkMath.h"
23
24
25namespace itk
26{
37template <typename TInputMesh, typename TOutputMesh = TInputMesh>
39 : public DiscreteCurvatureQuadEdgeMeshFilter<TInputMesh, TOutputMesh>
40{
41public:
42 ITK_DISALLOW_COPY_AND_MOVE(DiscreteGaussianCurvatureQuadEdgeMeshFilter);
43
48
49 using typename Superclass::InputMeshType;
50 using typename Superclass::InputMeshPointer;
51
52 using typename Superclass::OutputMeshType;
53 using typename Superclass::OutputMeshPointer;
54 using typename Superclass::OutputPointsContainerPointer;
55 using typename Superclass::OutputPointsContainerIterator;
56 using typename Superclass::OutputPointType;
57 using typename Superclass::OutputVectorType;
58 using typename Superclass::OutputCoordType;
59 using typename Superclass::OutputPointIdentifier;
60 using typename Superclass::OutputCellIdentifier;
61 using typename Superclass::OutputQEType;
62 using typename Superclass::OutputMeshTraits;
63 using typename Superclass::OutputCurvatureType;
64 using typename Superclass::TriangleType;
65
67 itkOverrideGetNameOfClassMacro(DiscreteGaussianCurvatureQuadEdgeMeshFilter);
68
70 itkNewMacro(Self);
71
72#ifdef ITK_USE_CONCEPT_CHECKING
73 // Begin concept checking
75 // End concept checking
76#endif
77
78protected:
81
84 {
85 const OutputMeshPointer output = this->GetOutput();
86
87 OutputQEType * qe = iP.GetEdge();
88
89 if (qe != nullptr)
90 {
91 OutputQEType * qe_it = qe;
92
93 OutputCurvatureType sum_theta = 0.;
94 OutputCurvatureType area = 0.;
95
96 do
97 {
98 // cell_id = qe_it->GetLeft();
99 OutputQEType * qe_it2 = qe_it->GetOnext();
100 const OutputPointType q0 = output->GetPoint(qe_it->GetDestination());
101 const OutputPointType q1 = output->GetPoint(qe_it2->GetDestination());
102
103 // Compute Angle;
104 sum_theta += static_cast<OutputCurvatureType>(TriangleType::ComputeAngle(q0, iP, q1));
105 area += this->ComputeMixedArea(qe_it, qe_it2);
106 qe_it = qe_it2;
107 } while (qe_it != qe);
108
109 return (2.0 * itk::Math::pi - sum_theta) / area;
110 }
111
112 return 0.;
113 }
114};
115} // namespace itk
116
117#endif
see the following paper title: Discrete Differential-Geometry Operators for Triangulated 2-Manifolds ...
OutputCurvatureType EstimateCurvature(const OutputPointType &iP) override
~DiscreteGaussianCurvatureQuadEdgeMeshFilter() override=default
Light weight base class for most itk classes.
typename OutputMeshType::Pointer OutputMeshPointer
Definition: itkMeshSource.h:69
#define itkConceptMacro(name, concept)
static constexpr double pi
Definition: itkMath.h:66
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....