Go to the documentation of this file.
17 #ifndef __FINLEY_SHAPEFUNCTIONS_H__
18 #define __FINLEY_SHAPEFUNCTIONS_H__
22 #include <boost/shared_ptr.hpp>
24 #define S_INDEX(_J_,_I_,_NUMNODES_) INDEX2(_J_,_I_,_NUMNODES_)
25 #define DSDV_INDEX(_J_,_K_,_I_,_NUMNODES_,_DIM_) INDEX3(_J_,_K_,_I_,_NUMNODES_,_DIM_)
76 struct ShapeFunction {
86 const ShapeFunctionInfo*
Type;
94 std::vector<double>
S;
96 std::vector<double>
dSdv;
124 #endif // __FINLEY_SHAPEFUNCTIONS_H__
ShapeFunction_Evaluation Shape_Point1
Definition: ShapeFunctions.h:100
Definition: ShapeFunctions.h:39
const ShapeFunctionInfo ShapeFunction_InfoList[]
Definition: ShapeFunctions.cpp:45
int main(int argc, char **argv)
Definition: ScriptMPI.cpp:128
int numVertices
number of vertices of the element
Definition: ShapeFunctions.h:68
ShapeFunction_Evaluation Shape_Hex27
Definition: ShapeFunctions.h:118
Definition: ShapeFunctions.h:30
ShapeFunction_Evaluation Shape_Tri10
Definition: ShapeFunctions.h:107
int main(int argc, char **argv)
Definition: ScriptMPIredirect.cpp:128
#define INDEX2(_X1_, _X2_, _N1_)
Definition: index.h:21
std::vector< double > QuadNodes
coordinates of quadrature nodes
Definition: ShapeFunctions.h:89
std::vector< double > S
shape functions at quadrature nodes
Definition: ShapeFunctions.h:93
ShapeFunction_Evaluation Shape_Hex8
Definition: ShapeFunctions.h:116
ShapeFunctionTypeId
Definition: ShapeFunctions.h:28
ShapeFunction_Evaluation Shape_Hex32
Definition: ShapeFunctions.h:119
ShapeFunction_Evaluation Shape_Rec4
Definition: ShapeFunctions.h:108
Definition: ShapeFunctions.h:31
this struct holds the definition of the shape functions on an element
Definition: ShapeFunctions.h:56
ShapeFunction_Evaluation Shape_Tri3
Definition: ShapeFunctions.h:104
ShapeFunctionTypeId TypeId
shape function type
Definition: ShapeFunctions.h:58
const ShapeFunctionInfo * Type
shape function information
Definition: ShapeFunctions.h:85
int numDim
number of spatial dimensions
Definition: ShapeFunctions.h:62
Definition: ShapeFunctions.h:49
ShapeFunction_Evaluation Shape_Line2
Definition: ShapeFunctions.h:101
ShapeFunction_Evaluation Shape_Tet4
Definition: ShapeFunctions.h:113
void Solver_updateIncompleteSchurComplement(SparseMatrix_ptr A_CC, SparseMatrix_ptr A_CF, double *invA_FF, index_t *A_FF_pivot, SparseMatrix_ptr A_FC)
Definition: SchurComplement.cpp:39
ShapeFunction_Evaluation Shape_Tet16
Definition: ShapeFunctions.h:115
Definition: ShapeFunctions.h:34
#define MPI_COMM_WORLD
Definition: EsysMPI.h:46
int comparIndex(const void *index1, const void *index2)
this int-comparison function is used by qsort/bsearch in various places
Definition: PasoUtil.cpp:48
std::vector< double > dSdv
derivative of the shape functions at quadrature nodes
Definition: ShapeFunctions.h:95
index_t dim_t
Definition: DataTypes.h:87
static const ShapeFunctionInfo * getInfo(ShapeFunctionTypeId id)
Definition: ShapeFunctions.cpp:117
Definition: ShapeFunctions.h:45
Definition: ShapeFunctions.h:37
Definition: ShapeFunctions.h:48
#define DSDV(_J_, _K_, _I_)
Definition: ShapeFunctions.cpp:135
Definition: ShapeFunctions.h:29
ShapeFunction_Evaluation Shape_Tri9
Definition: ShapeFunctions.h:106
void() ShapeFunction_Evaluation(int, std::vector< double > &, std::vector< double > &, std::vector< double > &)
Definition: ShapeFunctions.h:53
ShapeFunction_Evaluation Shape_Rec16
Definition: ShapeFunctions.h:112
ShapeFunction_Evaluation Shape_Tri6
Definition: ShapeFunctions.h:105
ShapeFunction(ShapeFunctionTypeId id, int numQuadDim, int numQuadNodes, const std::vector< double > &QuadNodes, const std::vector< double > &QuadWeights)
Definition: ShapeFunctions.cpp:75
int numOrder
order of the shape functions
Definition: ShapeFunctions.h:66
Definition: ShapeFunctions.h:35
Definition: ShapeFunctions.h:32
Definition: ShapeFunctions.h:36
Definition: ShapeFunctions.h:43
Definition: ShapeFunctions.h:38
boost::shared_ptr< SparseMatrix > SparseMatrix_ptr
Definition: SparseMatrix.h:46
#define V(_K_, _I_)
Definition: ShapeFunctions.cpp:133
Definition: ShapeFunctions.h:44
ShapeFunction_Evaluation * getValues
function to evaluate the shape functions at a set of points
Definition: ShapeFunctions.h:70
ShapeFunction_Evaluation Shape_Rec9
Definition: ShapeFunctions.h:110
Definition: ShapeFunctions.h:46
ShapeFunction_Evaluation Shape_Rec12
Definition: ShapeFunctions.h:111
Definition: ShapeFunctions.h:33
int index_t
type for array/matrix indices used both globally and on each rank
Definition: DataTypes.h:82
ShapeFunctionTypeId getTypeId(const char *)
Definition: ShapeFunctions.cpp:105
int numShapes
number of shape functions
Definition: ShapeFunctions.h:64
boost::shared_ptr< const ShapeFunction > const_ShapeFunction_ptr
Definition: ShapeFunctions.h:98
ShapeFunction_Evaluation Shape_Line4
Definition: ShapeFunctions.h:103
ShapeFunction_Evaluation Shape_Rec8
Definition: ShapeFunctions.h:109
#define S(_J_, _I_)
Definition: ShapeFunctions.cpp:134
Definition: ShapeFunctions.h:40
Definition: BiCGStab.cpp:25
ShapeFunction_Evaluation Shape_Line3
Definition: ShapeFunctions.h:102
Definition: ShapeFunctions.h:41
A suite of factory methods for creating various finley domains.
Definition: finley/src/Assemble.h:31
Definition: ShapeFunctions.h:47
const char * Name
the name in text form e.g. "Line2", "Rec12", ...
Definition: ShapeFunctions.h:60
An exception class that signals an invalid argument value.
Definition: EsysException.h:99
ShapeFunction_Evaluation Shape_Tet10
Definition: ShapeFunctions.h:114
Definition: ShapeFunctions.h:42
ShapeFunction_Evaluation Shape_Hex20
Definition: ShapeFunctions.h:117
std::vector< double > QuadWeights
weights of the quadrature scheme
Definition: ShapeFunctions.h:91
int numQuadNodes
number of quadrature points
Definition: ShapeFunctions.h:87