VTK  9.5.20251201
vtkCell.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
106
107#ifndef vtkCell_h
108#define vtkCell_h
109
110#define VTK_CELL_SIZE 512
111#define VTK_TOL 1.e-05 // Tolerance for geometric calculation
112
113#include "vtkCommonDataModelModule.h" // For export macro
114#include "vtkObject.h"
115
116#include "vtkBoundingBox.h" // Needed for IntersectWithCell
117#include "vtkCellType.h" // Needed to define cell types
118#include "vtkIdList.h" // Needed for inline methods
119
120VTK_ABI_NAMESPACE_BEGIN
121class vtkCellArray;
122class vtkCellData;
123class vtkDataArray;
124class vtkPointData;
126class vtkPoints;
127
128class VTKCOMMONDATAMODEL_EXPORT vtkCell : public vtkObject
129{
130public:
131 vtkTypeMacro(vtkCell, vtkObject);
132 void PrintSelf(ostream& os, vtkIndent indent) override;
133
138 void Initialize(int npts, const vtkIdType* pts, vtkPoints* p);
139
146 void Initialize(int npts, vtkPoints* p);
147
153 virtual void ShallowCopy(vtkCell* c);
154
159 virtual void DeepCopy(vtkCell* c);
160
164 virtual int GetCellType() = 0;
165
169 virtual int GetCellDimension() = 0;
170
176 virtual int IsLinear() VTK_FUTURE_CONST { return 1; }
177
182 virtual int RequiresInitialization() { return 0; }
183 virtual void Initialize() {}
184
190 virtual int IsExplicitCell() VTK_FUTURE_CONST { return 0; }
191
197 virtual int RequiresExplicitFaceRepresentation() VTK_FUTURE_CONST { return 0; }
198
202 vtkPoints* GetPoints() { return this->Points; }
203
207 vtkIdType GetNumberOfPoints() const { return this->PointIds->GetNumberOfIds(); }
208
212 virtual int GetNumberOfEdges() = 0;
213
217 virtual int GetNumberOfFaces() = 0;
218
222 vtkIdList* GetPointIds() { return this->PointIds; }
223
227 vtkIdType GetPointId(int ptId) VTK_EXPECTS(0 <= ptId && ptId < GetPointIds()->GetNumberOfIds())
228 {
229 return this->PointIds->GetId(ptId);
230 }
231
235 virtual vtkCell* GetEdge(int edgeId) = 0;
236
248 virtual vtkCell* GetFace(int faceId) = 0;
249
257 virtual int CellBoundary(int subId, const double pcoords[3], vtkIdList* pts) = 0;
258
276 virtual int EvaluatePosition(const double x[3], double closestPoint[3], int& subId,
277 double pcoords[3], double& dist2, double weights[]) = 0;
278
284 virtual void EvaluateLocation(
285 int& subId, const double pcoords[3], double x[3], double* weights) = 0;
286
300 virtual void Contour(double value, vtkDataArray* cellScalars, vtkIncrementalPointLocator* locator,
301 vtkCellArray* verts, vtkCellArray* lines, vtkCellArray* polys, vtkPointData* inPd,
302 vtkPointData* outPd, vtkCellData* inCd, vtkIdType cellId, vtkCellData* outCd) = 0;
303
316 virtual void Clip(double value, vtkDataArray* cellScalars, vtkIncrementalPointLocator* locator,
317 vtkCellArray* connectivity, vtkPointData* inPd, vtkPointData* outPd, vtkCellData* inCd,
318 vtkIdType cellId, vtkCellData* outCd, int insideOut) = 0;
319
333 virtual int Inflate(double dist);
334
343 virtual double ComputeBoundingSphere(double center[3]) const;
344
353 virtual int IntersectWithLine(const double p1[3], const double p2[3], double tol, double& t,
354 double x[3], double pcoords[3], int& subId) = 0;
355
357
364 virtual int IntersectWithCell(vtkCell* other, double tol = 0.0);
365 virtual int IntersectWithCell(vtkCell* other, const vtkBoundingBox& boudingBox,
366 const vtkBoundingBox& otherBoundingBox, double tol = 0.0);
368
379 virtual int Triangulate(int index, vtkIdList* ptIds, vtkPoints* pts);
380
391 virtual int TriangulateIds(int index, vtkIdList* ptIds);
392
404 virtual int TriangulateLocalIds(int index, vtkIdList* ptIds) = 0;
405
420 virtual void Derivatives(
421 int subId, const double pcoords[3], const double* values, int dim, double* derivs) = 0;
422
427 void GetBounds(double bounds[6]);
428
434
438 double GetLength2();
439
446 virtual int GetParametricCenter(double pcoords[3]);
447
455 virtual double GetParametricDistance(const double pcoords[3]);
456
464 virtual int IsPrimaryCell() VTK_FUTURE_CONST { return 1; }
465
476
482 virtual void InterpolateFunctions(const double vtkNotUsed(pcoords)[3], double* vtkNotUsed(weight))
483 {
484 }
485 virtual void InterpolateDerivs(const double vtkNotUsed(pcoords)[3], double* vtkNotUsed(derivs)) {}
486
487 // left public for quick computational access
490
491protected:
493 ~vtkCell() override;
494
495 double Bounds[6];
496
497private:
498 vtkCell(const vtkCell&) = delete;
499 void operator=(const vtkCell&) = delete;
500};
501
502VTK_ABI_NAMESPACE_END
503#endif
Fast, simple class for representing and operating on 3D bounds.
object to represent cell connectivity
represent and manipulate cell attribute data
virtual int GetNumberOfEdges()=0
Return the number of edges in the cell.
virtual void Derivatives(int subId, const double pcoords[3], const double *values, int dim, double *derivs)=0
Compute derivatives given cell subId and parametric coordinates.
virtual int EvaluatePosition(const double x[3], double closestPoint[3], int &subId, double pcoords[3], double &dist2, double weights[])=0
Given a point x[3] return inside(=1), outside(=0) cell, or (-1) computational problem encountered; ev...
double Bounds[6]
Definition vtkCell.h:495
vtkIdType GetPointId(int ptId)
For cell point i, return the actual point id.
Definition vtkCell.h:227
virtual void Clip(double value, vtkDataArray *cellScalars, vtkIncrementalPointLocator *locator, vtkCellArray *connectivity, vtkPointData *inPd, vtkPointData *outPd, vtkCellData *inCd, vtkIdType cellId, vtkCellData *outCd, int insideOut)=0
Cut (or clip) the cell based on the input cellScalars and the specified value.
double GetLength2()
Compute Length squared of cell (i.e., bounding box diagonal squared).
virtual int CellBoundary(int subId, const double pcoords[3], vtkIdList *pts)=0
Given parametric coordinates of a point, return the closest cell boundary, and whether the point is i...
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
virtual int Inflate(double dist)
Inflates the cell.
virtual void InterpolateFunctions(const double pcoords[3], double *weight)
Compute the interpolation functions/derivatives (aka shape functions/derivatives) No-ops at this leve...
Definition vtkCell.h:482
virtual int RequiresExplicitFaceRepresentation() VTK_FUTURE_CONST
Determine whether the cell requires explicit face representation, and methods for setting and getting...
Definition vtkCell.h:197
vtkIdList * GetPointIds()
Return the list of point ids defining the cell.
Definition vtkCell.h:222
virtual int GetCellDimension()=0
Return the topological dimensional of the cell (0,1,2, or 3).
virtual void Contour(double value, vtkDataArray *cellScalars, vtkIncrementalPointLocator *locator, vtkCellArray *verts, vtkCellArray *lines, vtkCellArray *polys, vtkPointData *inPd, vtkPointData *outPd, vtkCellData *inCd, vtkIdType cellId, vtkCellData *outCd)=0
Generate contouring primitives.
virtual int GetNumberOfFaces()=0
Return the number of faces in the cell.
virtual void EvaluateLocation(int &subId, const double pcoords[3], double x[3], double *weights)=0
Determine global coordinate (x[3]) from subId and parametric coordinates.
void GetBounds(double bounds[6])
Compute cell bounding box (xmin,xmax,ymin,ymax,zmin,zmax).
virtual void ShallowCopy(vtkCell *c)
Copy this cell by reference counting the internal data structures.
virtual vtkCell * GetEdge(int edgeId)=0
Return the edge cell from the edgeId of the cell.
virtual int Triangulate(int index, vtkIdList *ptIds, vtkPoints *pts)
Generate simplices of proper dimension.
virtual int IntersectWithLine(const double p1[3], const double p2[3], double tol, double &t, double x[3], double pcoords[3], int &subId)=0
Intersect with a ray.
virtual int IsExplicitCell() VTK_FUTURE_CONST
Explicit cells require additional representational information beyond the usual cell type and connect...
Definition vtkCell.h:190
virtual double ComputeBoundingSphere(double center[3]) const
Computes the bounding sphere of the cell.
virtual int GetCellType()=0
Return the type of cell.
virtual void InterpolateDerivs(const double pcoords[3], double *derivs)
Definition vtkCell.h:485
virtual void DeepCopy(vtkCell *c)
Copy this cell by completely copying internal data structures.
virtual int IsPrimaryCell() VTK_FUTURE_CONST
Return whether this cell type has a fixed topology or whether the topology varies depending on the da...
Definition vtkCell.h:464
virtual void Initialize()
Definition vtkCell.h:183
virtual int TriangulateLocalIds(int index, vtkIdList *ptIds)=0
Generate simplices of proper dimension.
void Initialize(int npts, vtkPoints *p)
Initialize the cell with point coordinates specified.
virtual int TriangulateIds(int index, vtkIdList *ptIds)
Generate simplices of proper dimension.
virtual double GetParametricDistance(const double pcoords[3])
Return the distance of the parametric coordinate provided to the cell.
virtual int IntersectWithCell(vtkCell *other, const vtkBoundingBox &boudingBox, const vtkBoundingBox &otherBoundingBox, double tol=0.0)
Intersects with an other cell.
vtkPoints * GetPoints()
Get the point coordinates for the cell.
Definition vtkCell.h:202
double * GetBounds()
Compute cell bounding box (xmin,xmax,ymin,ymax,zmin,zmax).
~vtkCell() override
virtual int IsLinear() VTK_FUTURE_CONST
Non-linear cells require special treatment beyond the usual cell type and connectivity list informati...
Definition vtkCell.h:176
virtual vtkCell * GetFace(int faceId)=0
Return the face cell from the faceId of the cell.
virtual int RequiresInitialization()
Some cells require initialization prior to access.
Definition vtkCell.h:182
vtkPoints * Points
Definition vtkCell.h:488
void Initialize(int npts, const vtkIdType *pts, vtkPoints *p)
Initialize cell from outside with point ids and point coordinates specified.
vtkIdList * PointIds
Definition vtkCell.h:489
virtual int IntersectWithCell(vtkCell *other, double tol=0.0)
Intersects with an other cell.
virtual int GetParametricCenter(double pcoords[3])
Return center of the cell in parametric coordinates.
virtual double * GetParametricCoords()
Return a contiguous array of parametric coordinates of the points defining this cell.
vtkIdType GetNumberOfPoints() const
Return the number of points in the cell.
Definition vtkCell.h:207
list of point or cell ids
Definition vtkIdList.h:133
Abstract class in support of both point location and point insertion.
a simple class to control print indentation
Definition vtkIndent.h:108
represent and manipulate point attribute data
represent and manipulate 3D points
Definition vtkPoints.h:139
#define vtkDataArray
int vtkIdType
Definition vtkType.h:367
#define VTK_SIZEHINT(...)
#define VTK_EXPECTS(x)