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:142
Definition: Quadrature.h:52
int offsets[2+1]
Definition: ReferenceElements.h:133
int numNodes
Definition: ReferenceElements.h:197
this struct holds the evaluation of a shape function on a quadrature scheme
Definition: ShapeFunctions.h:76
Definition: Quadrature.h:37
Definition: ReferenceElements.h:85
Definition: ReferenceElements.h:107
Definition: ShapeFunctions.h:40
Definition: ReferenceElements.h:40
double real_t
type of all real-valued scalars in escript
Definition: DataTypes.h:76
int numNodesOnFace
Definition: ReferenceElements.h:157
void reduction_order10(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:214
ElementTypeId TypeId
the type
Definition: ReferenceElements.h:121
boost::shared_ptr< ReferenceElement > ReferenceElement_ptr
Definition: ReferenceElements.h:211
Definition: ReferenceElements.h:48
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:1243
Definition: ShapeFunctions.h:31
void integral_order4(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:88
Definition: ReferenceElements.h:98
Definition: ReferenceElements.h:57
#define INDEX4(_X1_, _X2_, _X3_, _X4_, _N1_, _N2_, _N3_)
Definition: index.h:26
Definition: ReferenceElements.h:106
Definition: ReferenceElements.h:96
Definition: ReferenceElements.h:99
void reduction_order8(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:170
ShapeFunctionTypeId BasisFunctions
shape function for the basis functions
Definition: ReferenceElements.h:144
Definition: ReferenceElements.h:44
const ReferenceElementInfo * LinearType
type of the linear reference element
Definition: ReferenceElements.h:194
void reduction_order3(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:60
#define INDEX2(_X1_, _X2_, _N1_)
Definition: index.h:22
int subElementNodes[64 *2 *8]
Definition: ReferenceElements.h:149
Definition: ReferenceElements.h:72
Definition: ReferenceElements.h:75
Definition: ReferenceElements.h:102
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:1988
Definition: ReferenceElements.h:79
void gradient_order8(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:335
static ElementTypeId getTypeId(const char *)
returns the element type id from its textual representation
Definition: ReferenceElements.cpp:666
Definition: ReferenceElements.h:52
Definition: Quadrature.h:40
const ReferenceElementInfo ReferenceElement_InfoList[]
this list has been generated by generateReferenceElementList.py
Definition: ReferenceElements.cpp:47
ShapeFunctionTypeId
Definition: ShapeFunctions.h:29
void reduction_order5(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:104
Definition: ReferenceElements.h:112
Definition: ShapeFunctions.h:32
void integral_order3(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:63
Definition: ReferenceElements.h:62
Definition: ReferenceElements.h:70
Definition: ReferenceElements.h:59
int numLocalDim
Definition: ReferenceElements.h:198
ElementTypeId LinearTypeId
type id of the linear version of the element
Definition: ReferenceElements.h:136
this struct holds the definition of the shape functions on an element
Definition: ShapeFunctions.h:57
boost::shared_ptr< const ReferenceElement > const_ReferenceElement_ptr
Definition: ReferenceElements.h:212
ShapeFunctionTypeId TypeId
shape function type
Definition: ShapeFunctions.h:59
int numDim
number of spatial dimensions
Definition: Quadrature.h:58
void gradient_order3(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:85
int numDim
number of spatial dimensions
Definition: ShapeFunctions.h:63
Definition: ReferenceElements.h:71
const_ShapeFunction_ptr Parametrization
Definition: ReferenceElements.h:200
Definition: ReferenceElements.h:94
Definition: ReferenceElements.h:66
int getDataPointSize() const
Return the size of the data point. It is the product of the data point shape dimensions.
Definition: Data.cpp:1364
Definition: ReferenceElements.h:101
Definition: ShapeFunctions.h:50
Definition: ReferenceElements.h:86
Definition: ReferenceElements.h:53
void integral_order6(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:138
double * DBasisFunctionDv
Definition: ReferenceElements.h:205
Definition: ReferenceElements.h:42
void gradient_order7(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:283
Definition: ReferenceElements.h:111
Definition: ReferenceElements.h:58
Definition: ReferenceElements.h:56
Definition: ReferenceElements.h:87
Definition: ReferenceElements.h:45
Definition: ReferenceElements.h:77
Definition: AbstractAssembler.cpp:18
Definition: ReferenceElements.h:76
Definition: ReferenceElements.h:60
#define MAX_numSides
Definition: ReferenceElements.h:33
int integrationOrder
used integration order
Definition: ReferenceElements.h:196
Definition: ShapeFunctions.h:35
Data represents a collection of datapoints.
Definition: Data.h:63
Definition: ReferenceElements.h:100
Definition: ReferenceElements.h:67
Definition: ReferenceElements.h:95
#define INDEX3(_X1_, _X2_, _X3_, _N1_, _N2_)
Definition: index.h:24
void integral_order9(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:213
static const ShapeFunctionInfo * getInfo(ShapeFunctionTypeId id)
Definition: ShapeFunctions.cpp:119
Definition: Quadrature.h:34
Definition: ReferenceElements.h:110
Definition: ShapeFunctions.h:46
const ReferenceElementInfo * Type
type of the reference element
Definition: ReferenceElements.h:192
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:1953
Definition: ReferenceElements.h:113
Definition: ShapeFunctions.h:38
Definition: ReferenceElements.h:47
Definition: ShapeFunctions.h:49
void reduction_order6(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:126
void gradient_order9(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:388
int numRelevantGeoNodes
deprecated
Definition: ReferenceElements.h:152
Definition: ShapeFunctions.h:30
Definition: ReferenceElements.h:114
int numSubElements
number of subelements (>1 if macro elements are used)
Definition: ReferenceElements.h:127
Definition: ReferenceElements.h:65
Definition: ReferenceElements.h:63
Definition: ReferenceElements.h:84
Definition: ReferenceElements.h:105
Definition: ReferenceElements.h:80
Definition: ReferenceElements.h:38
Definition: ReferenceElements.h:89
double m_dx[2]
grid spacings / cell sizes of domain
Definition: speckley/src/Rectangle.h:397
Definition: ReferenceElements.h:92
const_ShapeFunction_ptr LinearBasisFunctions
Definition: ReferenceElements.h:202
this struct holds the definition of the reference element
Definition: ReferenceElements.h:119
Definition: ReferenceElements.h:55
int reverseNodes[64]
Definition: ReferenceElements.h:170
Definition: ReferenceElements.h:91
~ReferenceElement()
destructor
Definition: ReferenceElements.cpp:660
Definition: Quadrature.h:35
Definition: ReferenceElements.h:61
int numOrder
order of the shape functions
Definition: ShapeFunctions.h:67
Definition: ShapeFunctions.h:36
void integral_order8(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:188
QuadTypeId Quadrature
quadrature scheme
Definition: ReferenceElements.h:140
Definition: ReferenceElements.h:82
Definition: ShapeFunctions.h:33
Definition: ReferenceElements.h:104
Definition: ReferenceElements.h:64
Definition: ShapeFunctions.h:37
void reduction_order2(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:37
Definition: ShapeFunctions.h:44
int shiftNodes[64]
defines a permutation of the nodes which rotates the nodes on the face
Definition: ReferenceElements.h:167
Definition: ShapeFunctions.h:39
#define MAX_numSubElements
Definition: ReferenceElements.h:32
Definition: ReferenceElements.h:97
Definition: ShapeFunctions.h:45
void integral_order7(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:163
Definition: ReferenceElements.h:73
Definition: ReferenceElements.h:49
Definition: Quadrature.h:39
Definition: ReferenceElements.h:54
Definition: ReferenceElements.h:43
Definition: ReferenceElements.h:81
const QuadInfo * QuadInfo_getInfo(QuadTypeId id)
Definition: Quadrature.cpp:42
Definition: ReferenceElements.h:90
Definition: ReferenceElements.h:39
ElementTypeId
Definition: ReferenceElements.h:37
Definition: ShapeFunctions.h:47
Definition: ShapeFunctions.h:34
int index_t
type for array/matrix indices used both globally and on each rank
Definition: DataTypes.h:85
Definition: ReferenceElements.h:109
Definition: ReferenceElements.h:51
static const ReferenceElementInfo * getInfo(ElementTypeId id)
returns the element information structure for the given type id
Definition: ReferenceElements.cpp:678
int numSides
Definition: ReferenceElements.h:130
void gradient_order5(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:182
void gradient_order10(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:442
Definition: Quadrature.h:36
void integral_order5(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:113
Quad_getNumNodes * getNumQuadNodes
Definition: Quadrature.h:65
Definition: ReferenceElements.h:108
Quad_getNodes * getQuadNodes
function that returns the quadrature points for a given order
Definition: Quadrature.h:62
Definition: ReferenceElements.h:74
int numShapes
number of shape functions
Definition: ShapeFunctions.h:65
void gradient_order4(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:133
void reduction_order4(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:82
int linearNodes[64 *2]
stores the list of nodes defining the linear or macro element
Definition: ReferenceElements.h:138
Definition: ReferenceElements.h:68
int getNumNodes() const
Definition: ReferenceElements.h:189
Definition: ReferenceElements.h:88
void integral_order2(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:37
Definition: Quadrature.h:38
Definition: ReferenceElements.h:41
Definition: ReferenceElements.h:50
boost::shared_ptr< const ShapeFunction > const_ShapeFunction_ptr
Definition: ShapeFunctions.h:99
Quad_getMacro * getMacro
transfers a given quadrature scheme to a macro element structure
Definition: Quadrature.h:67
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:1122
dim_t m_NE[2]
number of elements for this rank in each dimension including shared
Definition: speckley/src/Rectangle.h:403
const_ShapeFunction_ptr BasisFunctions
Definition: ReferenceElements.h:201
int numNodes
number of nodes defining the element
Definition: ReferenceElements.h:125
Definition: ShapeFunctions.h:41
#define MAX_numNodes
Definition: ReferenceElements.h:31
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:62
void gradient_order2(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:37
Definition: ShapeFunctions.h:42
int faceNodes[64]
list of the nodes defining the face
Definition: ReferenceElements.h:163
A suite of factory methods for creating various finley domains.
Definition: finley/src/Assemble.h:32
Definition: ReferenceElements.h:69
int numLinearNodes
Definition: ReferenceElements.h:199
Definition: ShapeFunctions.h:48
void reduction_order7(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:148
Definition: ReferenceElements.h:93
An exception class that signals an invalid argument value.
Definition: EsysException.h:101
ElementTypeId
Definition: ElementType.h:37
Definition: ReferenceElements.h:78
Definition: ReferenceElements.h:103
void reduction_order9(const escript::Data &, escript::Data &) const
Definition: RectangleReductions.cpp:192
void integral_order10(std::vector< Scalar > &, const escript::Data &) const
Definition: RectangleIntegrals.cpp:238
Definition: ShapeFunctions.h:43
QuadTypeId
Definition: Quadrature.h:33
Definition: ReferenceElements.h:46
ReferenceElement(ElementTypeId id, int order)
constructor with type ID and integration order
Definition: ReferenceElements.cpp:591
void gradient_order6(escript::Data &, const escript::Data &) const
Definition: RectangleGradients.cpp:232
this struct holds the realization of a reference element
Definition: ReferenceElements.h:175
const char * Name
the name in text form e.g. "Line1", "Rec12", ...
Definition: ReferenceElements.h:123
int relevantGeoNodes[64]
Definition: ReferenceElements.h:153
bool DBasisFunctionDvShared
Definition: ReferenceElements.h:208
Definition: ReferenceElements.h:83