Intrepid
|
Implementation of the default H(grad)-compatible FEM basis of degree 2 on Triangle cell. More...
#include <Intrepid_HGRAD_TRI_C2_FEM.hpp>
Public Member Functions | |
Basis_HGRAD_TRI_C2_FEM () | |
Constructor. | |
void | getValues (ArrayScalar &outputValues, const ArrayScalar &inputPoints, const EOperator operatorType) const |
Evaluation of a FEM basis on a reference Triangle cell. More... | |
void | getValues (ArrayScalar &outputValues, const ArrayScalar &inputPoints, const ArrayScalar &cellVertices, const EOperator operatorType=OPERATOR_VALUE) const |
FVD basis evaluation: invocation of this method throws an exception. | |
void | getDofCoords (ArrayScalar &DofCoords) const |
Returns spatial locations (coordinates) of degrees of freedom on a reference Quadrilateral. More... | |
Public Member Functions inherited from Intrepid::Basis< Scalar, ArrayScalar > | |
virtual | ~Basis () |
Destructor. | |
virtual int | getCardinality () const |
Returns cardinality of the basis. More... | |
virtual int | getDegree () const |
Returns the degree of the basis. More... | |
virtual const shards::CellTopology | getBaseCellTopology () const |
Returns the base cell topology for which the basis is defined. See Shards documentation http://trilinos.sandia.gov/packages/shards for definition of base cell topology. More... | |
virtual EBasis | getBasisType () const |
Returns the basis type. More... | |
virtual ECoordinates | getCoordinateSystem () const |
Returns the type of coordinate system for which the basis is defined. More... | |
virtual int | getDofOrdinal (const int subcDim, const int subcOrd, const int subcDofOrd) |
DoF tag to ordinal lookup. More... | |
virtual const std::vector < std::vector< std::vector < int > > > & | getDofOrdinalData () |
DoF tag to ordinal data structure. | |
virtual const std::vector< int > & | getDofTag (const int dofOrd) |
DoF ordinal to DoF tag lookup. More... | |
virtual const std::vector < std::vector< int > > & | getAllDofTags () |
Retrieves all DoF tags. More... | |
Public Member Functions inherited from Intrepid::DofCoordsInterface< ArrayScalar > | |
virtual | ~DofCoordsInterface ()=0 |
Pure virtual destructor (gives warnings if not included). Following "Effective C++: 3rd Ed." item 7 the implementation is included in the definition file. | |
Private Member Functions | |
void | initializeTags () |
Initializes tagToOrdinal_ and ordinalToTag_ lookup arrays. | |
Additional Inherited Members | |
Protected Attributes inherited from Intrepid::Basis< Scalar, ArrayScalar > | |
int | basisCardinality_ |
Cardinality of the basis, i.e., the number of basis functions/degrees-of-freedom. | |
int | basisDegree_ |
Degree of the largest complete polynomial space that can be represented by the basis. | |
shards::CellTopology | basisCellTopology_ |
Base topology of the cells for which the basis is defined. See the Shards package http://trilinos.sandia.gov/packages/shards for definition of base cell topology. | |
EBasis | basisType_ |
Type of the basis. | |
ECoordinates | basisCoordinates_ |
The coordinate system for which the basis is defined. | |
bool | basisTagsAreSet_ |
"true" if tagToOrdinal_ and ordinalToTag_ have been initialized | |
std::vector< std::vector< int > > | ordinalToTag_ |
DoF ordinal to tag lookup table. More... | |
std::vector< std::vector < std::vector< int > > > | tagToOrdinal_ |
DoF tag to ordinal lookup table. More... | |
Implementation of the default H(grad)-compatible FEM basis of degree 2 on Triangle cell.
Implements Lagrangian basis of degree 2 on the reference Triangle cell. The basis has cardinality 6 and spans a COMPLETE quadratic polynomial space. Basis functions are dual to a unisolvent set of degrees-of-freedom (DoF) defined and enumerated as follows:
================================================================================================= | | degree-of-freedom-tag table | | | DoF |----------------------------------------------------------| DoF definition | | ordinal | subc dim | subc ordinal | subc DoF ord |subc num DoF | | |=========|==============|==============|==============|=============|===========================| | 0 | 0 | 0 | 0 | 1 | L_0(u) = u(0,0) | |---------|--------------|--------------|--------------|-------------|---------------------------| | 1 | 0 | 1 | 0 | 1 | L_1(u) = u(1,0) | |---------|--------------|--------------|--------------|-------------|---------------------------| | 2 | 0 | 2 | 0 | 1 | L_2(u) = u(0,1) | |---------|--------------|--------------|--------------|-------------|---------------------------| | 3 | 1 | 0 | 0 | 1 | L_3(u) = u(1/2,0) | |---------|--------------|--------------|--------------|-------------|---------------------------| | 4 | 1 | 1 | 0 | 1 | L_4(u) = u(1/2,1/2) | |---------|--------------|--------------|--------------|-------------|---------------------------| | 5 | 1 | 2 | 0 | 1 | L_5(u) = u(0,1/2) | |=========|==============|==============|==============|=============|===========================| | MAX | maxScDim=1 | maxScOrd=2 | maxDfOrd=0 | - | | |=========|==============|==============|==============|=============|===========================|
Definition at line 87 of file Intrepid_HGRAD_TRI_C2_FEM.hpp.
|
virtual |
Returns spatial locations (coordinates) of degrees of freedom on a reference Quadrilateral.
DofCoords | [out] - array with the coordinates of degrees of freedom, dimensioned (F,D) |
Implements Intrepid::DofCoordsInterface< ArrayScalar >.
Definition at line 263 of file Intrepid_HGRAD_TRI_C2_FEMDef.hpp.
|
virtual |
Evaluation of a FEM basis on a reference Triangle cell.
Returns values of <var>operatorType</var> acting on FEM basis functions for a set of points in the <strong>reference Triangle</strong> cell. For rank and dimensions of I/O array arguments see Section \ref basis_md_array_sec .
outputValues | [out] - variable rank array with the basis values |
inputPoints | [in] - rank-2 array (P,D) with the evaluation points |
operatorType | [in] - the operator acting on the basis functions |
Implements Intrepid::Basis< Scalar, ArrayScalar >.
Definition at line 98 of file Intrepid_HGRAD_TRI_C2_FEMDef.hpp.