18 #ifndef __WEIPA_ELEMENTDATA_H__
19 #define __WEIPA_ELEMENTDATA_H__
21 #include <weipa/weipa.h>
22 #include <weipa/vtkCellType.h>
Stores and manipulates one type of domain elements.
Definition: ElementData.h:50
virtual const QuadMaskInfo & getQuadMask(int fsCode) const =0
Returns a QuadMaskInfo structure for given functionspace code.
virtual ~ElementData()
Definition: ElementData.h:94
virtual int getGhostCount() const =0
Returns the number of "ghost" elements.
virtual const IntVec & getIDs() const =0
Returns a vector of element IDs.
virtual const IntVec & getNodeList() const =0
Returns a vector of the node IDs used by the elements.
virtual int getNumElements() const =0
Returns the number of elements.
virtual ZoneType getType() const =0
Returns the element type.
virtual int getElementFactor() const =0
If the original element type is not supported they are subdivided into N smaller elements (e....
virtual StringVec getMeshNames() const =0
Returns the names of the meshes associated with the elements.
virtual int getNodesPerElement() const =0
Returns the number of nodes per element.
virtual ElementData_ptr getReducedElements() const =0
Returns the reduced elements if available.
virtual StringVec getVarNames() const =0
Returns a vector with the mesh variable names.
virtual NodeData_ptr getNodes() const =0
Returns the NodeData instance used by the elements.
virtual void writeConnectivityVTK(std::ostream &os)=0
Writes connectivity data to a stream in VTK text format.
Definition: DataVar.cpp:51
std::vector< std::string > StringVec
Definition: weipa.h:61
boost::shared_ptr< ElementData > ElementData_ptr
Definition: weipa.h:67
std::vector< int > IntVec
Definition: weipa.h:60
boost::shared_ptr< NodeData > NodeData_ptr
Definition: weipa.h:69
ZoneType
Definition: ElementData.h:27
@ ZONETYPE_UNKNOWN
Definition: ElementData.h:28
@ ZONETYPE_TRIANGLE
Definition: ElementData.h:34
@ ZONETYPE_QUAD
Definition: ElementData.h:32
@ ZONETYPE_BEAM
Definition: ElementData.h:29
@ ZONETYPE_HEX
Definition: ElementData.h:30
@ ZONETYPE_POLYGON
Definition: ElementData.h:31
@ ZONETYPE_TET
Definition: ElementData.h:33
This struct holds a mask (0's and 1's) that indicates which quad nodes contribute to a sub-element wh...
Definition: ElementData.h:40
std::vector< IntVec > mask
Definition: ElementData.h:41
IntVec factor
Definition: ElementData.h:42
#define VTK_HEXAHEDRON
Definition: vtkCellType.h:48
#define VTK_LINE
Definition: vtkCellType.h:39
#define VTK_POLYGON
Definition: vtkCellType.h:43
#define VTK_QUAD
Definition: vtkCellType.h:45
#define VTK_TRIANGLE
Definition: vtkCellType.h:41
#define VTK_TETRA
Definition: vtkCellType.h:46