Go to the documentation of this file.
25 #ifndef __FINLEY_REFERENCEELEMENTS_H__
26 #define __FINLEY_REFERENCEELEMENTS_H__
33 #define MAX_numNodes 64
34 #define MAX_numSubElements 8
35 #define MAX_numSides 2
218 #endif // __FINLEY_REFERENCEELEMENTS_H__
ShapeFunctionTypeId Parametrization
shape function for parametrization of the element
Definition: ReferenceElements.h:144
int offsets[2+1]
Definition: ReferenceElements.h:135
int numNodes
Definition: ReferenceElements.h:199
this struct holds the evaluation of a shape function on a quadrature scheme
Definition: ShapeFunctions.h:77
@ RecQuad
Definition: Quadrature.h:39
@ Rec4_Contact
Definition: ReferenceElements.h:87
@ Hex27Face_Contact
Definition: ReferenceElements.h:109
@ Rec9Shape
Definition: ShapeFunctions.h:41
@ Line3
Definition: ReferenceElements.h:42
double real_t
type of all real-valued scalars in escript
Definition: DataTypes.h:79
int numNodesOnFace
Definition: ReferenceElements.h:159
void reduction_order10(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:216
ElementTypeId TypeId
the type
Definition: ReferenceElements.h:123
boost::shared_ptr< ReferenceElement > ReferenceElement_ptr
Definition: ReferenceElements.h:213
@ Rec9
Definition: ReferenceElements.h:50
void requireWrite()
Ensures data is ready for write access. This means that the data will be resolved if lazy and will be...
Definition: Data.cpp:1239
@ Line2Shape
Definition: ShapeFunctions.h:32
void integral_order4(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:90
@ Rec8Face_Contact
Definition: ReferenceElements.h:100
@ Hex32
Definition: ReferenceElements.h:59
#define INDEX4(_X1_, _X2_, _X3_, _X4_, _N1_, _N2_, _N3_)
Definition: index.h:27
@ Hex20Face_Contact
Definition: ReferenceElements.h:108
@ Tri10Face_Contact
Definition: ReferenceElements.h:98
@ Rec9Face_Contact
Definition: ReferenceElements.h:101
void reduction_order8(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:172
ShapeFunctionTypeId BasisFunctions
shape function for the basis functions
Definition: ReferenceElements.h:146
@ Tri9
Definition: ReferenceElements.h:46
const ReferenceElementInfo * LinearType
type of the linear reference element
Definition: ReferenceElements.h:196
void reduction_order3(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:62
#define INDEX2(_X1_, _X2_, _N1_)
Definition: index.h:23
int subElementNodes[64 *2 *8]
Definition: ReferenceElements.h:151
@ Tet16Face
Definition: ReferenceElements.h:74
@ Hex27Face
Definition: ReferenceElements.h:77
@ Tet4Face_Contact
Definition: ReferenceElements.h:104
const DataTypes::real_t * getSampleDataRO(DataTypes::RealVectorType::size_type sampleNo, DataTypes::real_t dummy=0) const
Return the sample data for the given sample no. Please do not use this unless you NEED to access samp...
Definition: Data.h:1989
@ Line3_Contact
Definition: ReferenceElements.h:81
void gradient_order8(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:337
static ElementTypeId getTypeId(const char *)
returns the element type id from its textual representation
Definition: ReferenceElements.cpp:670
@ Tet10
Definition: ReferenceElements.h:54
@ NoQuad
Definition: Quadrature.h:42
const ReferenceElementInfo ReferenceElement_InfoList[]
this list has been generated by generateReferenceElementList.py
Definition: ReferenceElements.cpp:51
ShapeFunctionTypeId
Definition: ShapeFunctions.h:30
void reduction_order5(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:106
@ Tet10Macro
Definition: ReferenceElements.h:114
@ Line3Shape
Definition: ShapeFunctions.h:33
void integral_order3(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:65
@ Tri6Face
Definition: ReferenceElements.h:64
@ Tet4Face
Definition: ReferenceElements.h:72
@ Line3Face
Definition: ReferenceElements.h:61
int numLocalDim
Definition: ReferenceElements.h:200
ElementTypeId LinearTypeId
type id of the linear version of the element
Definition: ReferenceElements.h:138
this struct holds the definition of the shape functions on an element
Definition: ShapeFunctions.h:58
boost::shared_ptr< const ReferenceElement > const_ReferenceElement_ptr
Definition: ReferenceElements.h:214
ShapeFunctionTypeId TypeId
shape function type
Definition: ShapeFunctions.h:60
void gradient_order3(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:87
@ Tet10Face
Definition: ReferenceElements.h:73
const_ShapeFunction_ptr Parametrization
Definition: ReferenceElements.h:202
@ Tri6Face_Contact
Definition: ReferenceElements.h:96
@ Rec8Face
Definition: ReferenceElements.h:68
int getDataPointSize() const
Return the size of the data point. It is the product of the data point shape dimensions.
Definition: Data.cpp:1360
@ Rec16Face_Contact
Definition: ReferenceElements.h:103
@ NoShape
Definition: ShapeFunctions.h:51
@ Rec8_Contact
Definition: ReferenceElements.h:88
@ Tet16
Definition: ReferenceElements.h:55
void integral_order6(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:140
double * DBasisFunctionDv
Definition: ReferenceElements.h:207
@ Tri3
Definition: ReferenceElements.h:44
void gradient_order7(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:285
@ Rec9Macro
Definition: ReferenceElements.h:113
@ Line2Face
Definition: ReferenceElements.h:60
@ Hex27
Definition: ReferenceElements.h:58
@ Rec9_Contact
Definition: ReferenceElements.h:89
@ Tri10
Definition: ReferenceElements.h:47
@ Point1_Contact
Definition: ReferenceElements.h:79
Definition: AbstractAssembler.cpp:19
@ Hex32Face
Definition: ReferenceElements.h:78
@ Line4Face
Definition: ReferenceElements.h:62
#define MAX_numSides
Definition: ReferenceElements.h:35
int integrationOrder
used integration order
Definition: ReferenceElements.h:198
@ Tri6Shape
Definition: ShapeFunctions.h:36
Data represents a collection of datapoints.
Definition: Data.h:64
@ Rec12Face_Contact
Definition: ReferenceElements.h:102
@ Rec9Face
Definition: ReferenceElements.h:69
@ Tri9Face_Contact
Definition: ReferenceElements.h:97
#define INDEX3(_X1_, _X2_, _X3_, _N1_, _N2_)
Definition: index.h:25
void integral_order9(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:215
static const ShapeFunctionInfo * getInfo(ShapeFunctionTypeId id)
Definition: ShapeFunctions.cpp:123
@ PointQuad
Definition: Quadrature.h:36
@ Tri6Macro
Definition: ReferenceElements.h:112
@ Hex8Shape
Definition: ShapeFunctions.h:47
const ReferenceElementInfo * Type
type of the reference element
Definition: ReferenceElements.h:194
DataTypes::real_t * getSampleDataRW(DataTypes::RealVectorType::size_type sampleNo, DataTypes::real_t dummy=0)
Return the sample data for the given sample no. Please do not use this unless you NEED to access samp...
Definition: Data.h:1954
@ Hex27Macro
Definition: ReferenceElements.h:115
@ Rec4Shape
Definition: ShapeFunctions.h:39
@ Rec8
Definition: ReferenceElements.h:49
@ Hex32Shape
Definition: ShapeFunctions.h:50
void reduction_order6(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:128
void gradient_order9(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:390
int numRelevantGeoNodes
deprecated
Definition: ReferenceElements.h:154
@ Point1Shape
Definition: ShapeFunctions.h:31
@ NoRef
Definition: ReferenceElements.h:116
int numSubElements
number of subelements (>1 if macro elements are used)
Definition: ReferenceElements.h:129
@ Rec4Face
Definition: ReferenceElements.h:67
@ Tri9Face
Definition: ReferenceElements.h:65
@ Tri10_Contact
Definition: ReferenceElements.h:86
@ Hex8Face_Contact
Definition: ReferenceElements.h:107
@ Line4_Contact
Definition: ReferenceElements.h:82
@ Point1
Definition: ReferenceElements.h:40
@ Rec16_Contact
Definition: ReferenceElements.h:91
double m_dx[2]
grid spacings / cell sizes of domain
Definition: speckley/src/Rectangle.h:400
@ Line4Face_Contact
Definition: ReferenceElements.h:94
const_ShapeFunction_ptr LinearBasisFunctions
Definition: ReferenceElements.h:204
this struct holds the definition of the reference element
Definition: ReferenceElements.h:121
@ Hex20
Definition: ReferenceElements.h:57
int reverseNodes[64]
Definition: ReferenceElements.h:172
@ Line3Face_Contact
Definition: ReferenceElements.h:93
~ReferenceElement()
destructor
Definition: ReferenceElements.cpp:664
@ LineQuad
Definition: Quadrature.h:37
@ Tri3Face
Definition: ReferenceElements.h:63
@ Tri9Shape
Definition: ShapeFunctions.h:37
void integral_order8(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:190
QuadTypeId Quadrature
quadrature scheme
Definition: ReferenceElements.h:142
@ Tri6_Contact
Definition: ReferenceElements.h:84
@ Line4Shape
Definition: ShapeFunctions.h:34
@ Tet16Face_Contact
Definition: ReferenceElements.h:106
@ Tri10Face
Definition: ReferenceElements.h:66
@ Tri10Shape
Definition: ShapeFunctions.h:38
void reduction_order2(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:39
@ Tet10Shape
Definition: ShapeFunctions.h:45
int shiftNodes[64]
defines a permutation of the nodes which rotates the nodes on the face
Definition: ReferenceElements.h:169
@ Rec8Shape
Definition: ShapeFunctions.h:40
#define MAX_numSubElements
Definition: ReferenceElements.h:34
@ Rec4Face_Contact
Definition: ReferenceElements.h:99
@ Tet16Shape
Definition: ShapeFunctions.h:46
void integral_order7(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:165
@ Hex8Face
Definition: ReferenceElements.h:75
@ Rec12
Definition: ReferenceElements.h:51
@ HexQuad
Definition: Quadrature.h:41
@ Hex8
Definition: ReferenceElements.h:56
@ Tri6
Definition: ReferenceElements.h:45
@ Tri3_Contact
Definition: ReferenceElements.h:83
const QuadInfo * QuadInfo_getInfo(QuadTypeId id)
Definition: Quadrature.cpp:44
@ Line2Face_Contact
Definition: ReferenceElements.h:92
@ Line2
Definition: ReferenceElements.h:41
ElementTypeId
Definition: ReferenceElements.h:39
@ Hex20Shape
Definition: ShapeFunctions.h:48
@ Tri3Shape
Definition: ShapeFunctions.h:35
int index_t
type for array/matrix indices used both globally and on each rank
Definition: DataTypes.h:88
@ Line3Macro
Definition: ReferenceElements.h:111
@ Tet4
Definition: ReferenceElements.h:53
static const ReferenceElementInfo * getInfo(ElementTypeId id)
returns the element information structure for the given type id
Definition: ReferenceElements.cpp:682
int numSides
Definition: ReferenceElements.h:132
void gradient_order5(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:184
void gradient_order10(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:444
@ TriQuad
Definition: Quadrature.h:38
void integral_order5(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:115
@ Hex32Face_Contact
Definition: ReferenceElements.h:110
@ Hex20Face
Definition: ReferenceElements.h:76
void gradient_order4(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:135
void reduction_order4(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:84
int linearNodes[64 *2]
stores the list of nodes defining the linear or macro element
Definition: ReferenceElements.h:140
@ Rec12Face
Definition: ReferenceElements.h:70
int getNumNodes() const
Definition: ReferenceElements.h:191
@ Rec12_Contact
Definition: ReferenceElements.h:90
void integral_order2(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:39
@ TetQuad
Definition: Quadrature.h:40
@ Line4
Definition: ReferenceElements.h:43
@ Rec16
Definition: ReferenceElements.h:52
boost::shared_ptr< const ShapeFunction > const_ShapeFunction_ptr
Definition: ShapeFunctions.h:100
bool actsExpanded() const
Return true if this Data is expanded or resolves to expanded. That is, if it has a separate value for...
Definition: Data.cpp:1118
dim_t m_NE[2]
number of elements for this rank in each dimension including shared
Definition: speckley/src/Rectangle.h:406
const_ShapeFunction_ptr BasisFunctions
Definition: ReferenceElements.h:203
int numNodes
number of nodes defining the element
Definition: ReferenceElements.h:127
@ Rec12Shape
Definition: ShapeFunctions.h:42
#define MAX_numNodes
Definition: ReferenceElements.h:33
Data Scalar(double value, const FunctionSpace &what, bool expanded)
A collection of factory functions for creating Data objects which contain data points of various shap...
Definition: DataFactory.cpp:63
void gradient_order2(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:39
@ Rec16Shape
Definition: ShapeFunctions.h:43
int faceNodes[64]
list of the nodes defining the face
Definition: ReferenceElements.h:165
A suite of factory methods for creating various finley domains.
Definition: finley/src/Assemble.h:32
@ Rec16Face
Definition: ReferenceElements.h:71
int numLinearNodes
Definition: ReferenceElements.h:201
@ Hex27Shape
Definition: ShapeFunctions.h:49
void reduction_order7(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:150
@ Tri3Face_Contact
Definition: ReferenceElements.h:95
An exception class that signals an invalid argument value.
Definition: EsysException.h:103
ElementTypeId
Definition: ElementType.h:39
@ Line2_Contact
Definition: ReferenceElements.h:80
@ Tet10Face_Contact
Definition: ReferenceElements.h:105
void reduction_order9(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:194
void integral_order10(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:240
@ Tet4Shape
Definition: ShapeFunctions.h:44
QuadTypeId
Definition: Quadrature.h:35
@ Rec4
Definition: ReferenceElements.h:48
ReferenceElement(ElementTypeId id, int order)
constructor with type ID and integration order
Definition: ReferenceElements.cpp:595
void gradient_order6(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:234
this struct holds the realization of a reference element
Definition: ReferenceElements.h:177
const char * Name
the name in text form e.g. "Line1", "Rec12", ...
Definition: ReferenceElements.h:125
int relevantGeoNodes[64]
Definition: ReferenceElements.h:155
bool DBasisFunctionDvShared
Definition: ReferenceElements.h:210
@ Tri9_Contact
Definition: ReferenceElements.h:85