Dune Core Modules (2.6.0)
Switch for uniform treatment of finite element with either the local or the global interface. More...
#include <dune/localfunctions/common/interfaceswitch.hh>
Public Types | |
typedef FiniteElement::Traits::Basis | Basis |
export the type of the basis | |
typedef FiniteElement::Traits::Interpolation | Interpolation |
export the type of the interpolation | |
typedef FiniteElement::Traits::Coefficients | Coefficients |
export the type of the coefficients | |
typedef std::shared_ptr< const FiniteElement > | Store |
Type for storing finite elements. More... | |
Static Public Member Functions | |
static const Basis & | basis (const FiniteElement &fe) |
access basis | |
static const Interpolation & | interpolation (const FiniteElement &fe) |
access interpolation | |
static const Coefficients & | coefficients (const FiniteElement &fe) |
access coefficients | |
static void | setStore (Store &store, const FiniteElement &fe) |
Store a finite element in the store. More... | |
Detailed Description
struct Dune::FiniteElementInterfaceSwitch< FiniteElement, Dummy >
Switch for uniform treatment of finite element with either the local or the global interface.
- Template Parameters
-
FiniteElement Type of the finite element to handle. Dummy Dummy parameter for enable_if. This must be left at the default value of void
.
- Note
- The local interface is detected by the presence of the type FiniteElement::Traits::LocalBasisType.
Member Typedef Documentation
◆ Store
typedef std::shared_ptr<const FiniteElement> Dune::FiniteElementInterfaceSwitch< FiniteElement, Dummy >::Store |
Type for storing finite elements.
Some algorithms use one variable to store (a pointer) a finite element and update that pointer while iterating through the grid. This works well for local finite elements, since they exists in a finite number of variants, which can be stored somewhere and don't need to change for the duration of the algorithm, so we can always store a simple pointer. For global finite elements we have to store the object itself however, and we must make sure that we destroy the object when we are done with it. Since global finite elements are not assignable in general, we needs to copy-construct them for each grid element we visit.
To accommodate both interfaces, we define a store: for local finite elements it is a simple pointer, and if we want to store a finite element in it we simply store its address. For global finite elements we use a shared_ptr, and if we want to store a finite element in it we allocate a new object and initialise it with the copy-constructor. For local finite elements we don't need to do anything when we are done with it, global finite elements are automatically destructed by the shared_ptr when we store a new one or when the shared_ptr itself is destroyed. Access to the finite element is done by simply dereferencing the store in both cases.
Member Function Documentation
◆ setStore()
|
inlinestatic |
Store a finite element in the store.
For local finite elements this means storing the address of the passed reference, for global finite element this means creating a new object with allocation and copy-construction and storing that.
The documentation for this struct was generated from the following file:
- dune/localfunctions/common/interfaceswitch.hh