52 m_setupState(false), m_shapeType(LibUtilities::
eNoShapeType),
53 m_globalID(-1), m_straightEdge(0)
62 m_setupState(false), m_shapeType(LibUtilities::
eNoShapeType),
63 m_globalID(-1), m_straightEdge(0)
129 "This function is only valid for shape type geometries");
139 "This function is only valid for shape type geometries");
149 "This function is only valid for shape type geometries");
159 "This function is only valid for shape type geometries");
167 [[maybe_unused]]
const int i)
const
170 "This function is not valid for this geometry.");
178 [[maybe_unused]]
const int i)
const
181 "This function is not valid for this geometry.");
207 "This function is only valid for shape type geometries");
220 "This function is only valid for shape type geometries");
244 dist = std::numeric_limits<double>::max();
256 m_xmap->LocCoordToLocCollapsed(locCoord, eta);
261 dist = std::numeric_limits<double>::max();
277 "This function has not been defined for this geometry");
285 [[maybe_unused]]
const int j)
const
288 "This function has not been defined for this geometry");
296 [[maybe_unused]]
const int j)
const
299 "This function has not been defined for this geometry");
307 [[maybe_unused]]
const int j)
const
310 "This function has not been defined for this geometry");
318 [[maybe_unused]]
const int j)
const
321 "This function has not been defined for this geometry");
329 [[maybe_unused]]
const int j)
const
332 "This function has not been defined for this geometry");
340 [[maybe_unused]]
const int i,
344 "This function is only valid for expansion type geometries");
356 "This function is only valid for expansion type geometries");
366 "This function is only valid for expansion type geometries");
373 [[maybe_unused]]
CurveMap &curvedFaces)
387 "This function is only valid for expansion type geometries");
412 p->GetCoords(x[0], x[1], x[2]);
413 for (
int j = 0; j < 3; ++j)
421 p->GetCoords(x[0], x[1], x[2]);
422 for (
int j = 0; j < 3; ++j)
424 min[j] = (x[j] <
min[j] ? x[j] :
min[j]);
425 max[j] = (x[j] >
max[j] ? x[j] :
max[j]);
433 const int nq =
GetXmap()->GetTotPoints();
435 for (
int j = 0; j < 3; ++j)
443 for (
int j = 0; j < 3; ++j)
445 for (
int i = 0; i < nq; ++i)
447 min[j] = (xvec[j][i] <
min[j] ? xvec[j][i] :
min[j]);
448 max[j] = (xvec[j][i] >
max[j] ? xvec[j][i] :
max[j]);
454 for (
int j = 0; j < 3; ++j)
464 for (
int j = 0; j < 3; ++j)
517 "Expects number of global coordinates supplied to be greater than "
518 "or equal to the mesh dimension.");
523 if ((gloCoord[i] < minMax[i]) || (gloCoord[i] > minMax[i + 3]))
540 "Expects local coordinates to be same or "
541 "larger than shape dimension.");
550 if (!std::isfinite(locCoord[i]))
555 else if (locCoord[i] < -(1. + tol))
557 locCoord[i] = -(1. + tol);
560 else if (locCoord[i] > (1. + tol))
562 locCoord[i] = 1. + tol;
#define NEKERROR(type, msg)
Assert Level 0 – Fundamental assert which is used whether in FULLDEBUG, DEBUG or OPT compilation mode...
#define ASSERTL1(condition, msg)
Assert Level 1 – Debugging which is used whether in FULLDEBUG or DEBUG compilation mode....
Base class for shape geometry information.
virtual int v_GetNumEdges() const
Get the number of edges of this object.
virtual StdRegions::Orientation v_GetForient(const int i) const
Returns the orientation of face i with respect to the ordering of faces in the standard element.
virtual NekDouble v_GetCoord(const int i, const Array< OneD, const NekDouble > &Lcoord)
Given local collapsed coordinate Lcoord, return the value of physical coordinate in direction i.
Array< OneD, NekDouble > m_boundingBox
Array containing bounding box.
virtual PointGeom * v_GetVertex(int i) const
Returns vertex i of this object.
GeomState m_state
Enumeration to dictate whether coefficients are filled.
virtual void v_CalculateInverseIsoParam()
virtual int v_AllLeftCheck(const Array< OneD, const NekDouble > &gloCoord)
NekDouble GetLocCoords(const Array< OneD, const NekDouble > &coords, Array< OneD, NekDouble > &Lcoords)
Determine the local collapsed coordinates that correspond to a given Cartesian coordinate for this ge...
int PreliminaryCheck(const Array< OneD, const NekDouble > &gloCoord)
A fast and robust check if a given global coord is outside of a deformed element. For regular element...
virtual int v_GetEdgeNormalToFaceVert(const int i, const int j) const
Returns the standard lement edge IDs that are normal to a given face vertex.
int GetShapeDim() const
Get the object's shape dimension.
virtual void v_FillGeom()
Populate the coordinate mapping Geometry::m_coeffs information from any children geometry elements.
Geometry()
Default constructor.
virtual NekDouble v_GetLocCoords(const Array< OneD, const NekDouble > &coords, Array< OneD, NekDouble > &Lcoords)
Determine the local collapsed coordinates that correspond to a given Cartesian coordinate for this ge...
virtual int v_GetNumFaces() const
Get the number of faces of this object.
virtual StdRegions::StdExpansionSharedPtr v_GetXmap() const
Return the mapping object Geometry::m_xmap that represents the coordinate transformation from standar...
virtual void v_Reset(CurveMap &curvedEdges, CurveMap &curvedFaces)
Reset this geometry object: unset the current state, zero Geometry::m_coeffs and remove allocated Geo...
bool ClampLocCoords(Array< OneD, NekDouble > &locCoord, NekDouble tol=std::numeric_limits< NekDouble >::epsilon())
Clamp local coords to be within standard regions [-1, 1]^dim.
int GetGlobalID(void) const
Get the ID of this object.
PointGeom * GetVertex(int i) const
Returns vertex i of this object.
int GetCoordim() const
Return the coordinate dimension of this object (i.e. the dimension of the space in which this object ...
int GetFid(int i) const
Get the ID of face i of this object.
virtual int v_GetEdgeFaceMap(int i, int j) const
Returns the standard element edge IDs that are connected to a given face.
LibUtilities::ShapeType m_shapeType
Type of shape.
Array< OneD, Array< OneD, NekDouble > > m_coeffs
Array containing expansion coefficients of m_xmap.
GeomState m_geomFactorsState
State of the geometric factors.
virtual Geometry2D * v_GetFace(int i) const
Returns face i of this object.
GeomFactorsSharedPtr GetMetricInfo()
Get the geometric factors for this object.
StdRegions::StdExpansionSharedPtr m_xmap
mapping containing isoparametric transformation.
virtual StdRegions::Orientation v_GetEorient(const int i) const
Returns the orientation of edge i with respect to the ordering of edges in the standard element.
StdRegions::StdExpansionSharedPtr GetXmap() const
Return the mapping object Geometry::m_xmap that represents the coordinate transformation from standar...
static GeomFactorsVector m_regGeomFactorsManager
std::array< NekDouble, 6 > GetBoundingBox()
Generates the bounding box for the element.
int GetNumVerts() const
Get the number of vertices of this object.
Geometry1D * GetEdge(int i) const
Returns edge i of this object.
Geometry2D * GetFace(int i) const
Returns face i of this object.
bool MinMaxCheck(const Array< OneD, const NekDouble > &gloCoord)
Check if given global coord is within the BoundingBox of the element.
virtual int v_GetVertexEdgeMap(int i, int j) const
Returns the standard element edge IDs that are connected to a given vertex.
virtual NekDouble v_FindDistance(const Array< OneD, const NekDouble > &xs, Array< OneD, NekDouble > &xi)
GeomFactorsSharedPtr GetGeomFactors()
Get the geometric factors for this object, generating them if required.
static GeomFactorsSharedPtr ValidateRegGeomFactor(GeomFactorsSharedPtr geomFactor)
Check to see if a geometric factor has already been created that contains the same regular informatio...
virtual Geometry1D * v_GetEdge(int i) const
Returns edge i of this object.
virtual int v_GetNumVerts() const
Get the number of vertices of this object.
GeomFactorsSharedPtr m_geomFactors
Geometric factors.
int m_coordim
Coordinate dimension of this geometry object.
virtual int v_GetDir(const int faceidx, const int facedir) const
Returns the element coordinate direction corresponding to a given face coordinate direction.
virtual int v_GetVid(int i) const
Get the ID of vertex i of this object.
virtual int v_GetShapeDim() const
Get the object's shape dimension.
virtual int v_GetVertexFaceMap(int i, int j) const
Returns the standard element face IDs that are connected to a given vertex.
virtual bool v_ContainsPoint(const Array< OneD, const NekDouble > &gloCoord, Array< OneD, NekDouble > &locCoord, NekDouble tol, NekDouble &dist)
Determine whether an element contains a particular Cartesian coordinate .
int GetEid(int i) const
Get the ID of edge i of this object.
static const NekDouble kGeomFactorsTol
static const NekDouble kFindDistanceMin
bool GlobalIdEquality(const Geometry *&lhs, const Geometry *&rhs)
std::vector< GeomFactorsSharedPtr > GeomFactorsVector
A vector of GeomFactor pointers.
std::shared_ptr< GeomFactors > GeomFactorsSharedPtr
Pointer to a GeomFactors object.
bool SortByGlobalId(const Geometry *&lhs, const Geometry *&rhs)
Less than operator to sort Geometry objects by global id when sorting STL containers.
std::unordered_map< int, CurveSharedPtr > CurveMap
@ eRegular
Geometry is straight-sided with constant geometric factors.
@ eNotFilled
Geometric information has not been generated.
std::shared_ptr< StdExpansion > StdExpansionSharedPtr
scalarT< T > max(scalarT< T > lhs, scalarT< T > rhs)
scalarT< T > min(scalarT< T > lhs, scalarT< T > rhs)