gmsh-TingyuanDoc  0.1
An Open-Source Timing-driven Analytical Mixed-size FPGA Placer
MSubPoint Class Reference

#include <MSubElement.h>

Inheritance diagram for MSubPoint:
Collaboration diagram for MSubPoint:

Public Member Functions

 MSubPoint (MVertex *v0, int num=0, int part=0, bool owner=false, MElement *orig=nullptr)
 
 MSubPoint (const std::vector< MVertex * > &v, int num=0, int part=0, bool owner=false, MElement *orig=nullptr)
 
 MSubPoint (const MPoint &pt, bool owner=false, MElement *orig=nullptr)
 
 ~MSubPoint ()
 
virtual int getTypeForMSH () const
 
virtual const nodalBasisgetFunctionSpace (int order=-1, bool serendip=false) const
 
virtual const JacobianBasisgetJacobianFuncSpace (int order=-1) const
 
virtual void getShapeFunctions (double u, double v, double w, double s[], int order=-1) const
 
virtual void getGradShapeFunctions (double u, double v, double w, double s[][3], int order=-1) const
 
virtual void getHessShapeFunctions (double u, double v, double w, double s[][3][3], int order=-1) const
 
virtual void getThirdDerivativeShapeFunctions (double u, double v, double w, double s[][3][3][3], int order=-1) const
 
virtual double getJacobian (const fullMatrix< double > &gsf, double jac[3][3]) const
 
virtual double getJacobian (const std::vector< SVector3 > &gsf, double jac[3][3]) const
 
virtual double getJacobian (double u, double v, double w, double jac[3][3]) const
 
virtual double getPrimaryJacobian (double u, double v, double w, double jac[3][3]) const
 
virtual std::size_t getNumShapeFunctions () const
 
virtual std::size_t getNumPrimaryShapeFunctions () const
 
virtual const MVertexgetShapeFunctionNode (int i) const
 
virtual MVertexgetShapeFunctionNode (int i)
 
virtual void xyz2uvw (double xyz[3], double uvw[3]) const
 
virtual void movePointFromParentSpaceToElementSpace (double &u, double &v, double &w) const
 
virtual void movePointFromElementSpaceToParentSpace (double &u, double &v, double &w) const
 
virtual bool isInside (double u, double v, double w) const
 
virtual void getIntegrationPoints (int pOrder, int *npts, IntPt **pts)
 
virtual MElementgetParent () const
 
virtual void setParent (MElement *p, bool owner=false)
 
virtual bool ownsParent () const
 
virtual std::vector< MElement * > getMultiParents () const
 
virtual void setMultiParent (std::vector< MElement * > &parents, bool owner=false)
 
virtual const MElementgetBaseElement () const
 
virtual MElementgetBaseElement ()
 
- Public Member Functions inherited from MPoint
 MPoint (MVertex *v0, int num=0, int part=0)
 
 MPoint (const std::vector< MVertex * > &v, int num=0, int part=0)
 
 ~MPoint ()
 
virtual int getDim () const
 
virtual std::size_t getNumVertices () const
 
virtual MVertexgetVertex (int num)
 
virtual const MVertexgetVertex (int num) const
 
virtual void setVertex (int num, MVertex *v)
 
virtual int getNumEdges () const
 
virtual MEdge getEdge (int num) const
 
virtual int getNumEdgesRep (bool curved)
 
virtual void getEdgeRep (bool curved, int num, double *x, double *y, double *z, SVector3 *n)
 
virtual int getNumFaces ()
 
virtual MFace getFace (int num) const
 
virtual int getNumFacesRep (bool curved)
 
virtual void getFaceRep (bool curved, int num, double *x, double *y, double *z, SVector3 *n)
 
virtual int getType () const
 
virtual int getTypeForVTK () const
 
virtual const char * getStringForPOS () const
 
virtual void getNode (int num, double &u, double &v, double &w) const
 
virtual SPoint3 barycenterUVW () const
 
virtual int numCommonNodesInDualGraph (const MElement *const other) const
 
- Public Member Functions inherited from MElement
 MElement (std::size_t num=0, int part=0)
 
virtual ~MElement ()
 
double getTolerance () const
 
virtual std::size_t getNum () const
 
void forceNum (std::size_t num)
 
virtual int getPolynomialOrder () const
 
virtual bool getIsAssimilatedSerendipity () const
 
virtual bool getIsOnlySerendipity () const
 
virtual int getPartition () const
 
virtual void setPartition (int num)
 
virtual char getVisibility () const
 
virtual void setVisibility (char val)
 
void getVertices (std::vector< MVertex * > &verts)
 
virtual void getVertexInfo (const MVertex *vertex, int &ithVertex) const
 
virtual MVertexgetVertexUNV (int num)
 
virtual MVertexgetVertexVTK (int num)
 
virtual MVertexgetVertexMATLAB (int num)
 
virtual MVertexgetVertexTOCHNOG (int num)
 
virtual MVertexgetVertexBDF (int num)
 
virtual MVertexgetVertexDIFF (int num)
 
virtual MVertexgetVertexINP (int num)
 
virtual MVertexgetVertexKEY (int num)
 
virtual MVertexgetVertexRAD (int num)
 
virtual MVertexgetVertexNEU (int num)
 
virtual int getNumEdgeVertices () const
 
virtual int getNumFaceVertices () const
 
virtual int getNumVolumeVertices () const
 
std::size_t getNumPrimaryVertices () const
 
virtual MEdgeN getHighOrderEdge (int num, int sign)
 
MEdgeN getHighOrderEdge (const MEdge &edge)
 
virtual bool getEdgeInfo (const MEdge &edge, int &ithEdge, int &sign) const
 
virtual int numEdge2numVertex (int numEdge, int numVert) const
 
virtual MEdge getEdgeSolin (int numEdge)
 
virtual MFaceN getHighOrderFace (int num, int sign, int rot)
 
MFaceN getHighOrderFace (const MFace &face)
 
virtual bool getFaceInfo (const MFace &face, int &ithFace, int &sign, int &rot) const
 
virtual MFace getFaceSolin (int numFace)
 
virtual void getEdgeVertices (const int num, std::vector< MVertex * > &v) const
 
virtual void getFaceVertices (const int num, std::vector< MVertex * > &v) const
 
virtual int getNumChildren () const
 
virtual MElementgetChild (int i) const
 
virtual MElementgetDomain (int i) const
 
virtual void setDomain (MElement *e, int i)
 
virtual double maxEdge ()
 
virtual double minEdge ()
 
double maxDistToStraight () const
 
double skewness ()
 
virtual double gammaShapeMeasure ()
 
virtual double etaShapeMeasure ()
 
double minSICNShapeMeasure ()
 
double minSIGEShapeMeasure ()
 
double distoShapeMeasure ()
 
double minIsotropyMeasure (bool knownValid=false, bool reversedOk=false)
 
double minScaledJacobian (bool knownValid=false, bool reversedOk=false)
 
virtual double angleShapeMeasure ()
 
virtual void scaledJacRange (double &jmin, double &jmax, GEntity *ge=nullptr) const
 
virtual void idealJacRange (double &jmin, double &jmax, GEntity *ge=nullptr)
 
virtual void signedInvCondNumRange (double &iCNMin, double &iCNMax, GEntity *ge=nullptr)
 
virtual void signedInvGradErrorRange (double &minSIGE, double &maxSIGE)
 
virtual double getInnerRadius ()
 
virtual double getOuterRadius ()
 
virtual SPoint3 barycenter (bool primary=false) const
 
virtual SPoint3 fastBarycenter (bool primary=false) const
 
virtual SPoint3 barycenter_infty () const
 
virtual void reverse ()
 
virtual double getVolume ()
 
virtual int getVolumeSign ()
 
virtual bool setVolumePositive ()
 
int getValidity ()
 
virtual std::string getInfoString (bool multline)
 
virtual const FuncSpaceData getFuncSpaceData (int order=-1, bool serendip=false) const
 
virtual const FuncSpaceData getJacobianFuncSpaceData (int orderElement=-1) const
 
virtual double getJacobian (const std::vector< SVector3 > &gsf, double *jac) const
 
double getJacobian (double u, double v, double w, fullMatrix< double > &j) const
 
double getJacobianDeterminant (double u, double v, double w) const
 
void getSignedJacobian (fullVector< double > &jacobian, int o=-1) const
 
void getNodesCoord (fullMatrix< double > &nodesXYZ) const
 
void getNodesCoordNonSerendip (fullMatrix< double > &nodesXYZ) const
 
bezierCoeffgetBezierVerticesCoord () const
 
virtual double getEigenvaluesMetric (double u, double v, double w, double values[3]) const
 
virtual void pnt (double u, double v, double w, SPoint3 &p) const
 
virtual void pnt (double u, double v, double w, double *p) const
 
virtual void pnt (const std::vector< double > &sf, SPoint3 &p) const
 
virtual void primaryPnt (double u, double v, double w, SPoint3 &p)
 
double interpolate (double val[], double u, double v, double w, int stride=1, int order=-1)
 
void interpolateGrad (double val[], double u, double v, double w, double f[], int stride=1, double invjac[3][3]=nullptr, int order=-1)
 
void interpolateCurl (double val[], double u, double v, double w, double f[], int stride=3, int order=-1)
 
double interpolateDiv (double val[], double u, double v, double w, int stride=3, int order=-1)
 
double integrate (double val[], int pOrder, int stride=1, int order=-1)
 
double integrateCirc (double val[], int edge, int pOrder, int order=-1)
 
double integrateFlux (double val[], int face, int pOrder, int order=-1)
 
virtual void writeMSH2 (FILE *fp, double version=1.0, bool binary=false, int num=0, int elementary=1, int physical=1, int parentNum=0, int dom1Num=0, int dom2Num=0, std::vector< short > *ghosts=nullptr)
 
virtual void writeMSH3 (FILE *fp, bool binary=false, int elementary=1, std::vector< short > *ghosts=nullptr)
 
virtual void writePOS (FILE *fp, bool printElementary, bool printElementNumber, bool printSICN, bool printSIGE, bool printGamma, bool printDisto, double scalingFactor=1.0, int elementary=1)
 
virtual void writeSTL (FILE *fp, bool binary=false, double scalingFactor=1.0)
 
virtual void writeX3D (FILE *fp, double scalingFactor=1.0)
 
virtual void writeVRML (FILE *fp)
 
virtual void writePLY2 (FILE *fp)
 
virtual void writeUNV (FILE *fp, int num=0, int elementary=1, int physical=1)
 
virtual void writeVTK (FILE *fp, bool binary=false, bool bigEndian=false)
 
virtual void writeMATLAB (FILE *fp, int filetype, int elementary=0, int physical=0, bool binary=false)
 
virtual void writeTOCHNOG (FILE *fp, int num)
 
virtual void writeMESH (FILE *fp, int elementTagType=1, int elementary=1, int physical=0)
 
virtual void writeNEU (FILE *fp, unsigned gambitType, int adjust, int phys=0)
 
virtual void writeIR3 (FILE *fp, int elementTagType, int num, int elementary, int physical)
 
virtual void writeBDF (FILE *fp, int format=0, int elementTagType=1, int elementary=1, int physical=0)
 
virtual void writeDIFF (FILE *fp, int num, bool binary=false, int physical_property=1)
 
virtual void writeINP (FILE *fp, int num)
 
virtual void writeKEY (FILE *fp, int pid, int num)
 
virtual void writeRAD (FILE *fp, int num)
 
virtual void writeSU2 (FILE *fp, int num)
 
virtual int getTypeForUNV () const
 
virtual const char * getStringForTOCHNOG () const
 
virtual const char * getStringForBDF () const
 
virtual const char * getStringForDIFF () const
 
virtual const char * getStringForINP () const
 
virtual const char * getStringForKEY () const
 
virtual const char * getStringForRAD () const
 
std::string getName ()
 
virtual std::size_t getNumVerticesForMSH ()
 
virtual void getVerticesIdForMSH (std::vector< int > &verts)
 
virtual MElementcopy (std::map< int, MVertex * > &vertexMap, std::map< MElement *, MElement * > &newParents, std::map< MElement *, MElement * > &newDomains)
 

Protected Member Functions

 MSubPoint (const std::vector< MVertex * > &v, int num, int part, bool owner, int orig)
 
virtual void updateParent (GModel *gm)
 
- Protected Member Functions inherited from MElement
void _getEdgeRep (MVertex *v0, MVertex *v1, double *x, double *y, double *z, SVector3 *n, int faceIndex=-1)
 
void _getFaceRep (MVertex *v0, MVertex *v1, MVertex *v2, double *x, double *y, double *z, SVector3 *n)
 

Protected Attributes

bool _owner
 
union {
   MElement *   _orig
 
   int   _orig_N
 
}; 
 
std::vector< MElement * > _parents
 
MElement_base
 
int _pOrder
 
int _npts
 
IntPt_pts
 
- Protected Attributes inherited from MPoint
MVertex_v [1]
 

Friends

class MElementFactory
 
class GModel
 

Additional Inherited Members

- Static Public Member Functions inherited from MElement
static unsigned int getInfoMSH (const int typeMSH, const char **const name=nullptr)
 
- Static Protected Member Functions inherited from MElement
static bool _getFaceInfo (const MFace &face, const MFace &other, int &sign, int &rot)
 
- Static Protected Attributes inherited from MElement
static double _isInsideTolerance
 

Detailed Description

Definition at line 345 of file MSubElement.h.

Constructor & Destructor Documentation

◆ MSubPoint() [1/4]

MSubPoint::MSubPoint ( const std::vector< MVertex * > &  v,
int  num,
int  part,
bool  owner,
int  orig 
)
inlineprotected

Definition at line 362 of file MSubElement.h.

◆ MSubPoint() [2/4]

MSubPoint::MSubPoint ( MVertex v0,
int  num = 0,
int  part = 0,
bool  owner = false,
MElement orig = nullptr 
)
inline

Definition at line 371 of file MSubElement.h.

◆ MSubPoint() [3/4]

MSubPoint::MSubPoint ( const std::vector< MVertex * > &  v,
int  num = 0,
int  part = 0,
bool  owner = false,
MElement orig = nullptr 
)
inline

Definition at line 377 of file MSubElement.h.

◆ MSubPoint() [4/4]

MSubPoint::MSubPoint ( const MPoint pt,
bool  owner = false,
MElement orig = nullptr 
)
inline

Definition at line 383 of file MSubElement.h.

◆ ~MSubPoint()

MSubPoint::~MSubPoint ( )

Definition at line 731 of file MSubElement.cpp.

Member Function Documentation

◆ getBaseElement() [1/2]

virtual MElement* MSubPoint::getBaseElement ( )
inlinevirtual

Reimplemented from MElement.

Definition at line 444 of file MSubElement.h.

Here is the call graph for this function:

◆ getBaseElement() [2/2]

virtual const MElement* MSubPoint::getBaseElement ( ) const
inlinevirtual

Reimplemented from MElement.

Definition at line 439 of file MSubElement.h.

Referenced by isInside(), movePointFromElementSpaceToParentSpace(), and movePointFromParentSpaceToElementSpace().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ getFunctionSpace()

const nodalBasis * MSubPoint::getFunctionSpace ( int  order = -1,
bool  serendip = false 
) const
virtual

Reimplemented from MElement.

Definition at line 742 of file MSubElement.cpp.

Here is the call graph for this function:

◆ getGradShapeFunctions()

void MSubPoint::getGradShapeFunctions ( double  u,
double  v,
double  w,
double  s[][3],
int  order = -1 
) const
virtual

Reimplemented from MPoint.

Definition at line 760 of file MSubElement.cpp.

Here is the call graph for this function:

◆ getHessShapeFunctions()

void MSubPoint::getHessShapeFunctions ( double  u,
double  v,
double  w,
double  s[][3][3],
int  order = -1 
) const
virtual

Reimplemented from MElement.

Definition at line 766 of file MSubElement.cpp.

Here is the call graph for this function:

◆ getIntegrationPoints()

void MSubPoint::getIntegrationPoints ( int  pOrder,
int *  npts,
IntPt **  pts 
)
virtual

Reimplemented from MPoint.

Definition at line 884 of file MSubElement.cpp.

Here is the call graph for this function:

◆ getJacobian() [1/3]

double MSubPoint::getJacobian ( const fullMatrix< double > &  gsf,
double  jac[3][3] 
) const
virtual

Reimplemented from MElement.

Definition at line 779 of file MSubElement.cpp.

Here is the call graph for this function:

◆ getJacobian() [2/3]

double MSubPoint::getJacobian ( const std::vector< SVector3 > &  gsf,
double  jac[3][3] 
) const
virtual

Reimplemented from MElement.

Definition at line 785 of file MSubElement.cpp.

Here is the call graph for this function:

◆ getJacobian() [3/3]

double MSubPoint::getJacobian ( double  u,
double  v,
double  w,
double  jac[3][3] 
) const
virtual

Reimplemented from MElement.

Definition at line 791 of file MSubElement.cpp.

Here is the call graph for this function:

◆ getJacobianFuncSpace()

const JacobianBasis * MSubPoint::getJacobianFuncSpace ( int  order = -1) const
virtual

Reimplemented from MPoint.

Definition at line 748 of file MSubElement.cpp.

Here is the call graph for this function:

◆ getMultiParents()

virtual std::vector<MElement *> MSubPoint::getMultiParents ( ) const
inlinevirtual

Definition at line 431 of file MSubElement.h.

◆ getNumPrimaryShapeFunctions()

std::size_t MSubPoint::getNumPrimaryShapeFunctions ( ) const
virtual

Reimplemented from MElement.

Definition at line 810 of file MSubElement.cpp.

Here is the call graph for this function:

◆ getNumShapeFunctions()

std::size_t MSubPoint::getNumShapeFunctions ( ) const
virtual

Reimplemented from MElement.

Definition at line 804 of file MSubElement.cpp.

Here is the call graph for this function:

◆ getParent()

virtual MElement* MSubPoint::getParent ( ) const
inlinevirtual

Reimplemented from MElement.

Definition at line 424 of file MSubElement.h.

◆ getPrimaryJacobian()

double MSubPoint::getPrimaryJacobian ( double  u,
double  v,
double  w,
double  jac[3][3] 
) const
virtual

Reimplemented from MElement.

Definition at line 797 of file MSubElement.cpp.

Here is the call graph for this function:

◆ getShapeFunctionNode() [1/2]

MVertex * MSubPoint::getShapeFunctionNode ( int  i)
virtual

Reimplemented from MElement.

Definition at line 822 of file MSubElement.cpp.

Here is the call graph for this function:

◆ getShapeFunctionNode() [2/2]

const MVertex * MSubPoint::getShapeFunctionNode ( int  i) const
virtual

Reimplemented from MElement.

Definition at line 816 of file MSubElement.cpp.

Here is the call graph for this function:

◆ getShapeFunctions()

void MSubPoint::getShapeFunctions ( double  u,
double  v,
double  w,
double  s[],
int  order = -1 
) const
virtual

Reimplemented from MPoint.

Definition at line 754 of file MSubElement.cpp.

Here is the call graph for this function:

◆ getThirdDerivativeShapeFunctions()

void MSubPoint::getThirdDerivativeShapeFunctions ( double  u,
double  v,
double  w,
double  s[][3][3][3],
int  order = -1 
) const
virtual

Reimplemented from MElement.

Definition at line 772 of file MSubElement.cpp.

Here is the call graph for this function:

◆ getTypeForMSH()

virtual int MSubPoint::getTypeForMSH ( ) const
inlinevirtual

Reimplemented from MPoint.

Definition at line 390 of file MSubElement.h.

◆ isInside()

bool MSubPoint::isInside ( double  u,
double  v,
double  w 
) const
virtual

Reimplemented from MPoint.

Definition at line 861 of file MSubElement.cpp.

Here is the call graph for this function:

◆ movePointFromElementSpaceToParentSpace()

void MSubPoint::movePointFromElementSpaceToParentSpace ( double &  u,
double &  v,
double &  w 
) const
virtual

Reimplemented from MElement.

Definition at line 847 of file MSubElement.cpp.

Here is the call graph for this function:

◆ movePointFromParentSpaceToElementSpace()

void MSubPoint::movePointFromParentSpaceToElementSpace ( double &  u,
double &  v,
double &  w 
) const
virtual

Reimplemented from MElement.

Definition at line 833 of file MSubElement.cpp.

Referenced by isInside().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ ownsParent()

virtual bool MSubPoint::ownsParent ( ) const
inlinevirtual

Reimplemented from MElement.

Definition at line 430 of file MSubElement.h.

◆ setMultiParent()

virtual void MSubPoint::setMultiParent ( std::vector< MElement * > &  parents,
bool  owner = false 
)
inlinevirtual

Definition at line 432 of file MSubElement.h.

◆ setParent()

virtual void MSubPoint::setParent ( MElement p,
bool  owner = false 
)
inlinevirtual

Reimplemented from MElement.

Definition at line 425 of file MSubElement.h.

◆ updateParent()

void MSubPoint::updateParent ( GModel gm)
protectedvirtual

Reimplemented from MElement.

Definition at line 737 of file MSubElement.cpp.

Here is the call graph for this function:

◆ xyz2uvw()

void MSubPoint::xyz2uvw ( double  xyz[3],
double  uvw[3] 
) const
virtual

Reimplemented from MElement.

Definition at line 828 of file MSubElement.cpp.

Here is the call graph for this function:

Friends And Related Function Documentation

◆ GModel

friend class GModel
friend

Definition at line 347 of file MSubElement.h.

◆ MElementFactory

friend class MElementFactory
friend

Definition at line 346 of file MSubElement.h.

Member Data Documentation

◆ @28

union { ... }

◆ _base

MElement* MSubPoint::_base
mutableprotected

Definition at line 356 of file MSubElement.h.

Referenced by getBaseElement(), and ~MSubPoint().

◆ _npts

int MSubPoint::_npts
protected

Definition at line 359 of file MSubElement.h.

◆ _orig

◆ _orig_N

int MSubPoint::_orig_N

Definition at line 353 of file MSubElement.h.

Referenced by updateParent().

◆ _owner

bool MSubPoint::_owner
protected

Definition at line 350 of file MSubElement.h.

Referenced by ownsParent(), setMultiParent(), and setParent().

◆ _parents

std::vector<MElement *> MSubPoint::_parents
protected

Definition at line 355 of file MSubElement.h.

Referenced by getMultiParents(), and setMultiParent().

◆ _pOrder

int MSubPoint::_pOrder
protected

Definition at line 358 of file MSubElement.h.

◆ _pts

IntPt* MSubPoint::_pts
protected

Definition at line 360 of file MSubElement.h.

Referenced by getIntegrationPoints(), and ~MSubPoint().


The documentation for this class was generated from the following files: