VTK  9.5.20250807
vtkCellValidator.h
Go to the documentation of this file.
1// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
2// SPDX-License-Identifier: BSD-3-Clause
74#ifndef vtkCellValidator_h
75#define vtkCellValidator_h
76
77#include "vtkCellStatus.h" // For enum class.
78#include "vtkDataSetAlgorithm.h"
79#include "vtkFiltersGeneralModule.h" // For export macro
80
81VTK_ABI_NAMESPACE_BEGIN
82class vtkCell;
83class vtkGenericCell;
84class vtkEmptyCell;
85class vtkVertex;
86class vtkPolyVertex;
87class vtkLine;
88class vtkPolyLine;
89class vtkTriangle;
91class vtkPolygon;
92class vtkPixel;
93class vtkQuad;
94class vtkTetra;
95class vtkVoxel;
96class vtkHexahedron;
97class vtkWedge;
98class vtkPyramid;
101class vtkQuadraticEdge;
103class vtkQuadraticQuad;
117class vtkCubicLine;
119class vtkPolyhedron;
120class vtkLagrangeCurve;
123class vtkLagrangeTetra;
125class vtkLagrangeWedge;
126class vtkBezierCurve;
129class vtkBezierTetra;
131class vtkBezierWedge;
132
133class VTKFILTERSGENERAL_EXPORT vtkCellValidator : public vtkDataSetAlgorithm
134{
135public:
137 void PrintSelf(ostream& os, vtkIndent indent) override;
138
141
143
144 static void PrintState(State state, ostream& os, vtkIndent indent);
145
146 static State Check(vtkGenericCell*, double tolerance);
147 static State Check(vtkCell*, double tolerance);
148
149 static State Check(vtkEmptyCell*, double tolerance);
150 static State Check(vtkVertex*, double tolerance);
151 static State Check(vtkPolyVertex*, double tolerance);
152 static State Check(vtkLine*, double tolerance);
153 static State Check(vtkPolyLine*, double tolerance);
154 static State Check(vtkTriangle*, double tolerance);
155 static State Check(vtkTriangleStrip*, double tolerance);
156 static State Check(vtkPolygon*, double tolerance);
157 static State Check(vtkPixel*, double tolerance);
158 static State Check(vtkQuad*, double tolerance);
159 static State Check(vtkTetra*, double tolerance);
160 static State Check(vtkVoxel*, double tolerance);
161 static State Check(vtkHexahedron*, double tolerance);
162 static State Check(vtkWedge*, double tolerance);
163 static State Check(vtkPyramid*, double tolerance);
164 static State Check(vtkPentagonalPrism*, double tolerance);
165 static State Check(vtkHexagonalPrism*, double tolerance);
166 static State Check(vtkQuadraticEdge*, double tolerance);
167 static State Check(vtkQuadraticTriangle*, double tolerance);
168 static State Check(vtkQuadraticQuad*, double tolerance);
169 static State Check(vtkQuadraticPolygon*, double tolerance);
170 static State Check(vtkQuadraticTetra*, double tolerance);
171 static State Check(vtkQuadraticHexahedron*, double tolerance);
172 static State Check(vtkQuadraticWedge*, double tolerance);
173 static State Check(vtkQuadraticPyramid*, double tolerance);
174 static State Check(vtkBiQuadraticQuad*, double tolerance);
175 static State Check(vtkTriQuadraticHexahedron*, double tolerance);
176 static State Check(vtkTriQuadraticPyramid*, double tolerance);
177 static State Check(vtkQuadraticLinearQuad*, double tolerance);
178 static State Check(vtkQuadraticLinearWedge*, double tolerance);
179 static State Check(vtkBiQuadraticQuadraticWedge*, double tolerance);
181 static State Check(vtkBiQuadraticTriangle*, double tolerance);
182 static State Check(vtkCubicLine*, double tolerance);
183 static State Check(vtkConvexPointSet*, double tolerance);
184 static State Check(vtkPolyhedron*, double tolerance);
185 static State Check(vtkLagrangeCurve*, double tolerance);
186 static State Check(vtkLagrangeTriangle*, double tolerance);
187 static State Check(vtkLagrangeQuadrilateral*, double tolerance);
188 static State Check(vtkLagrangeTetra*, double tolerance);
189 static State Check(vtkLagrangeHexahedron*, double tolerance);
190 static State Check(vtkLagrangeWedge*, double tolerance);
191 static State Check(vtkBezierCurve*, double tolerance);
192 static State Check(vtkBezierTriangle*, double tolerance);
193 static State Check(vtkBezierQuadrilateral*, double tolerance);
194 static State Check(vtkBezierTetra*, double tolerance);
195 static State Check(vtkBezierHexahedron*, double tolerance);
196 static State Check(vtkBezierWedge*, double tolerance);
197
199
204 vtkSetClampMacro(Tolerance, double, 0.0, VTK_DOUBLE_MAX);
205 vtkGetMacro(Tolerance, double);
207
224 static void SetPlanarityTolerance(double tolerance);
225 static double GetPlanarityTolerance();
227
228protected:
230 ~vtkCellValidator() override = default;
231
232 double Tolerance;
233
235
236 static bool NoIntersectingEdges(vtkCell* cell, double tolerance);
237 static bool NoIntersectingFaces(vtkCell* cell, double tolerance);
238 static bool ContiguousEdges(vtkCell* twoDimensionalCell, double tolerance);
239 static State Convex(vtkCell* cell, double tolerance);
240 static bool FacesAreOrientedCorrectly(vtkCell* threeDimensionalCell, double tolerance);
241
242private:
243 vtkCellValidator(const vtkCellValidator&) = delete;
244 void operator=(const vtkCellValidator&) = delete;
245};
246
247VTK_ABI_NAMESPACE_END
248#endif
A 3D cell that represents an arbitrary order Bezier hex.
A 3D cell that represents an arbitrary order Bezier tetrahedron.
A 2D cell that represents an arbitrary order Bezier triangle.
A 3D cell that represents an arbitrary order Bezier wedge.
cell represents a parabolic, 9-node isoparametric quad
cell represents a biquadratic, 24-node isoparametric hexahedron
cell represents a parabolic, 18-node isoparametric wedge
cell represents a parabolic, isoparametric triangle
validates cells in a dataset
static State Check(vtkTriangle *, double tolerance)
static State Check(vtkPentagonalPrism *, double tolerance)
static State Check(vtkLagrangeTetra *, double tolerance)
static State Check(vtkQuadraticEdge *, double tolerance)
static State Check(vtkPolyVertex *, double tolerance)
static State Check(vtkEmptyCell *, double tolerance)
static State Check(vtkPolygon *, double tolerance)
static State Check(vtkLine *, double tolerance)
static State Check(vtkLagrangeQuadrilateral *, double tolerance)
static State Check(vtkHexagonalPrism *, double tolerance)
static State Check(vtkBiQuadraticQuadraticHexahedron *, double tolerance)
static State Check(vtkQuadraticLinearQuad *, double tolerance)
static State Check(vtkCell *, double tolerance)
static State Check(vtkGenericCell *, double tolerance)
static State Check(vtkTetra *, double tolerance)
static State Check(vtkQuad *, double tolerance)
static State Check(vtkQuadraticQuad *, double tolerance)
static State Check(vtkWedge *, double tolerance)
static State Check(vtkQuadraticLinearWedge *, double tolerance)
static State Check(vtkPolyLine *, double tolerance)
static void SetPlanarityTolerance(double tolerance)
static bool NoIntersectingFaces(vtkCell *cell, double tolerance)
static State Check(vtkPyramid *, double tolerance)
static State Check(vtkLagrangeCurve *, double tolerance)
static State Check(vtkLagrangeWedge *, double tolerance)
static State Convex(vtkCell *cell, double tolerance)
static State Check(vtkBezierQuadrilateral *, double tolerance)
static State Check(vtkQuadraticTriangle *, double tolerance)
static State Check(vtkBiQuadraticQuad *, double tolerance)
static bool NoIntersectingEdges(vtkCell *cell, double tolerance)
static State Check(vtkCubicLine *, double tolerance)
static State Check(vtkVoxel *, double tolerance)
~vtkCellValidator() override=default
static bool ContiguousEdges(vtkCell *twoDimensionalCell, double tolerance)
static double GetPlanarityTolerance()
static State Check(vtkBezierHexahedron *, double tolerance)
static State Check(vtkBezierTriangle *, double tolerance)
static State Check(vtkQuadraticPolygon *, double tolerance)
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
static bool FacesAreOrientedCorrectly(vtkCell *threeDimensionalCell, double tolerance)
static State Check(vtkVertex *, double tolerance)
static State Check(vtkConvexPointSet *, double tolerance)
static State Check(vtkBezierWedge *, double tolerance)
static State Check(vtkPolyhedron *, double tolerance)
static State Check(vtkQuadraticWedge *, double tolerance)
static State Check(vtkTriangleStrip *, double tolerance)
static State Check(vtkBezierCurve *, double tolerance)
static State Check(vtkBiQuadraticTriangle *, double tolerance)
static State Check(vtkPixel *, double tolerance)
static State Check(vtkBiQuadraticQuadraticWedge *, double tolerance)
static void PrintState(State state, ostream &os, vtkIndent indent)
static State Check(vtkTriQuadraticHexahedron *, double tolerance)
static State Check(vtkQuadraticTetra *, double tolerance)
static vtkCellValidator * New()
Construct to compute the validity of cells.
static State Check(vtkHexahedron *, double tolerance)
static State Check(vtkTriQuadraticPyramid *, double tolerance)
static State Check(vtkQuadraticHexahedron *, double tolerance)
static State Check(vtkQuadraticPyramid *, double tolerance)
static State Check(vtkBezierTetra *, double tolerance)
static State Check(vtkLagrangeHexahedron *, double tolerance)
static State Check(vtkLagrangeTriangle *, double tolerance)
int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *) override
This is called within ProcessRequest when a request asks the algorithm to do its work.
abstract class to specify cell behavior
Definition vtkCell.h:129
a 3D cell defined by a set of convex points
cell represents a cubic , isoparametric 1D line
Superclass for algorithms that produce output of the same type as input.
an empty cell used as a place-holder during processing
provides thread-safe access to cells
a 3D cell that represents a prism with hexagonal base
a cell that represents a linear 3D hexahedron
a simple class to control print indentation
Definition vtkIndent.h:108
Store zero or more vtkInformation instances.
Store vtkAlgorithm input/output information.
A 3D cell that represents an arbitrary order Lagrange hex.
A 3D cell that represents an arbitrary order Lagrange tetrahedron.
A 2D cell that represents an arbitrary order Lagrange triangle.
A 3D cell that represents an arbitrary order Lagrange wedge.
cell represents a 1D line
Definition vtkLine.h:132
a 3D cell that represents a convex prism with pentagonal base
a cell that represents an orthogonal quadrilateral
Definition vtkPixel.h:66
cell represents a set of 1D lines
cell represents a set of 0D vertices
a cell that represents an n-sided polygon
Definition vtkPolygon.h:132
A 3D cell defined by a set of polygonal faces.
a 3D cell that represents a linear pyramid
Definition vtkPyramid.h:95
a cell that represents a 2D quadrilateral
Definition vtkQuad.h:87
cell represents a parabolic, isoparametric edge
cell represents a parabolic, 20-node isoparametric hexahedron
cell represents a quadratic-linear, 6-node isoparametric quad
cell represents a, 12-node isoparametric wedge
a cell that represents a parabolic n-sided polygon
cell represents a parabolic, 13-node isoparametric pyramid
cell represents a parabolic, 8-node isoparametric quad
cell represents a parabolic, 10-node isoparametric tetrahedron
cell represents a parabolic, isoparametric triangle
cell represents a parabolic, 15-node isoparametric wedge
a 3D cell that represents a tetrahedron
Definition vtkTetra.h:113
cell represents a parabolic, 27-node isoparametric hexahedron
cell represents a parabolic, 19-node isoparametric pyramid
a cell that represents a triangle strip
a cell that represents a triangle
a cell that represents a 3D point
Definition vtkVertex.h:92
a cell that represents a 3D orthogonal parallelepiped
Definition vtkVoxel.h:80
a 3D cell that represents a linear wedge
Definition vtkWedge.h:85
vtkCellStatus
Diagnostic values indicating how well-specified a cell is.
#define VTK_DOUBLE_MAX
Definition vtkType.h:171