19#ifndef vtkHigherOrderQuadrilateral_h
20#define vtkHigherOrderQuadrilateral_h
25#include "vtkCommonDataModelModule.h"
55 const std::function<
void(
const vtkIdType&)>& set_number_of_ids_and_points,
61 int EvaluatePosition(
const double x[3],
double closestPoint[3],
int& subId,
double pcoords[3],
62 double& dist2,
double weights[])
override;
63 void EvaluateLocation(
int& subId,
const double pcoords[3],
double x[3],
double* weights)
override;
70 int IntersectWithLine(
const double p1[3],
const double p2[3],
double tol,
double& t,
double x[3],
71 double pcoords[3],
int& subId)
override;
74 int subId,
const double pcoords[3],
const double* values,
int dim,
double* derivs)
override;
84 virtual void SetOrder(
const int s,
const int t);
130 center[0] = center[1] = 0.5;
object to represent cell connectivity
represent and manipulate cell attribute data
virtual int GetParametricCenter(double pcoords[3])
Return center of the cell in parametric coordinates.
dynamic, self-adjusting array of double
void PrepareApproxData(vtkPointData *pd, vtkCellData *cd, vtkIdType cellId, vtkDataArray *cellScalars)
void Clip(double value, vtkDataArray *cellScalars, vtkIncrementalPointLocator *locator, vtkCellArray *polys, vtkPointData *inPd, vtkPointData *outPd, vtkCellData *inCd, vtkIdType cellId, vtkCellData *outCd, int insideOut) override
Cut (or clip) the cell based on the input cellScalars and the specified value.
vtkCell * GetFace(int vtkNotUsed(faceId)) override
virtual void SetUniformOrderFromNumPoints(const vtkIdType numPts)
vtkNew< vtkIdList > TmpIds
vtkSmartPointer< vtkPointData > ApproxPD
vtkNew< vtkDoubleArray > Scalars
bool SubCellCoordinatesFromId(vtkVector3i &ijk, int subId)
virtual vtkQuad * GetApproximateQuad(int subId, vtkDataArray *scalarsIn=nullptr, vtkDataArray *scalarsOut=nullptr)=0
int GetNumberOfEdges() override
Return the number of edges in the cell.
int GetNumberOfFaces() override
Return the number of faces in the cell.
vtkSmartPointer< vtkQuad > Approx
int IntersectWithLine(const double p1[3], const double p2[3], double tol, double &t, double x[3], double pcoords[3], int &subId) override
Intersect with a ray.
bool SubCellCoordinatesFromId(int &i, int &j, int &k, int subId)
virtual void SetOrderFromCellData(vtkCellData *cell_data, const vtkIdType numPts, const vtkIdType cell_id)
int PointIndexFromIJK(int i, int j, int k)
int RequiresInitialization() override
Some cells require initialization prior to access.
vtkSmartPointer< vtkPoints > PointParametricCoordinates
virtual vtkHigherOrderCurve * getEdgeCell()
int GetCellDimension() override
Return the topological dimensional of the cell (0,1,2, or 3).
virtual void SetOrder(const int s, const int t)
virtual int GetOrder(int i)
void SetParametricCoords()
void SetEdgeIdsAndPoints(int edgeId, const std::function< void(const vtkIdType &)> &set_number_of_ids_and_points, const std::function< void(const vtkIdType &, const vtkIdType &)> &set_ids_and_points)
vtkSmartPointer< vtkCellData > ApproxCD
static int PointIndexFromIJK(int i, int j, const int *order)
double GetParametricDistance(const double pcoords[3]) override
Return the distance of the parametric coordinate provided to the cell.
vtkNew< vtkDoubleArray > CellScalars
void EvaluateLocation(int &subId, const double pcoords[3], double x[3], double *weights) override
Determine global coordinate (x[3]) from subId and parametric coordinates.
void Initialize() override
void InterpolateDerivs(const double pcoords[3], double *derivs) override=0
virtual const int * GetOrder()
vtkHigherOrderQuadrilateral()
void Derivatives(int subId, const double pcoords[3], const double *values, int dim, double *derivs) override
Compute derivatives given cell subId and parametric coordinates.
double * GetParametricCoords() override
Return a contiguous array of parametric coordinates of the points defining this cell.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
vtkNew< vtkPoints > TmpPts
vtkCell * GetEdge(int edgeId) override=0
Return the edge cell from the edgeId of the cell.
void Contour(double value, vtkDataArray *cellScalars, vtkIncrementalPointLocator *locator, vtkCellArray *verts, vtkCellArray *lines, vtkCellArray *polys, vtkPointData *inPd, vtkPointData *outPd, vtkCellData *inCd, vtkIdType cellId, vtkCellData *outCd) override
Generate contouring primitives.
int Triangulate(int index, vtkIdList *ptIds, vtkPoints *pts) override
Generate simplices of proper dimension.
void InterpolateFunctions(const double pcoords[3], double *weights) override=0
virtual vtkHigherOrderCurve * GetEdgeCell()=0
int EvaluatePosition(const double x[3], double closestPoint[3], int &subId, double pcoords[3], double &dist2, double weights[]) override
Given a point x[3] return inside(=1), outside(=0) cell, or (-1) computational problem encountered; ev...
int CellBoundary(int subId, const double pcoords[3], vtkIdList *pts) override
Given parametric coordinates of a point, return the closest cell boundary, and whether the point is i...
int GetCellType() override=0
Return the type of cell.
bool TransformApproxToCellParams(int subCell, double *pcoords)
int GetParametricCenter(double center[3]) override
Return center of the cell in parametric coordinates.
list of point or cell ids
Abstract class in support of both point location and point insertion.
a simple class to control print indentation
Allocate and hold a VTK object.
represent and manipulate point attribute data
represent and manipulate 3D points
a cell that represents a 2D quadrilateral
Hold a reference to a vtkObjectBase instance.
#define VTK_DEPRECATED_IN_9_1_0(reason)