DUNE-FEM (unstable)
Implementation of an \(hp\)-adaptive discrete function space using product Legendre polynomials. More...
#include <dune/fem/space/hpdg/legendre.hh>
Public Types | |
using | KeyType = typename BasisFunctionSetsType::KeyType |
key type identifying a basis function set | |
using | BasisFunctionSetType = typename BaseType::BasisFunctionSetType |
basis function set type | |
using | BlockMapperType = typename BaseType::BlockMapperType |
block mapper type | |
using | InterpolationImplType = DiscontinuousGalerkinLocalL2Projection< GridPartType, BasisFunctionSetType > |
local interpolation type | |
using | InterpolationType = LocalInterpolationWrapper< DiscreteFunctionSpaceType > |
local interpolation type | |
typedef DofManager< GridType > | DofManagerType |
type of DoF manager | |
typedef CommunicationManager< DiscreteFunctionSpaceType > | CommunicationManagerType |
type of communication manager | |
typedef Traits::FunctionSpaceType | FunctionSpaceType |
type of function space | |
typedef GridPartType::IntersectionType | IntersectionType |
type of the intersections | |
typedef AuxiliaryDofsType | SlaveDofsType |
deprecated type | |
Public Member Functions | |
bool | continuous (const IntersectionType &intersection) const |
returns true if discrete functions over this space have zero jump over the given intersection. More... | |
void | adapt (const Vector &polynomialOrders, const int polOrderShift=0) const |
default implementation of adapt does nothing, its only used in PAdaptiveLagrangeSpace | |
int | sequence () const |
get index of the sequence in grid sequences More... | |
const GridType & | grid () const |
get reference to grid this discrete function space belongs to More... | |
GridType & | grid () |
get reference to grid this discrete function space belongs to More... | |
GridPartType & | gridPart () const |
GridPartType & | gridPart () |
get a reference to the associated grid partition More... | |
const IndexSetType & | indexSet () const |
Get a reference to the associated index set. More... | |
int | size () const |
get number of DoFs for this space More... | |
int | primarySize () const |
get number of primary DoFs for this space More... | |
int | auxiliarySize () const |
get number of auxiliary DoFs for this space More... | |
int | maxNumDofs () const |
return the maximal number of dofs on entities | |
IteratorType | begin () const |
get iterator pointing to the first entity of the associated grid partition More... | |
IteratorType | end () const |
get iterator pointing behind the last entity of the associated grid partition More... | |
void | forEach (FunctorType &f) const |
apply a functor to each entity in the associated grid partition More... | |
bool | multipleGeometryTypes () const |
returns true if the grid has more than one geometry type More... | |
InterfaceType | communicationInterface () const |
return the communication interface appropriate for this space More... | |
CommunicationDirection | communicationDirection () const |
return the communication interface appropriate for this space More... | |
const CommunicationManagerType & | communicator () const |
return reference to communicator (see CommunicationManager) More... | |
void | communicate (DiscreteFunction &discreteFunction) const |
communicate data for given discrete function using the space's default communication operation More... | |
void | communicate (DiscreteFunction &discreteFunction, const Operation &op) const |
communicate data for given discrete function More... | |
BaseType::template CommDataHandle< DiscreteFunction, Operation >::Type | createDataHandle (DiscreteFunction &discreteFunction, const Operation &operation) const |
const AuxiliaryDofsType & | auxiliaryDofs () const |
get auxiliary dofs | |
void | addFunction (DiscreteFunction &df) const |
default implementation of addFunction does nothing at the moment | |
void | removeFunction (DiscreteFunction &df) const |
default implementation of removeFunction does nothing at the moment | |
const std::vector< GeometryType > & | geomTypes (int codim) const |
returns true if the grid has more than one geometry type More... | |
const AuxiliaryDofsType & | slaveDofs () const |
deprecated method, use auxiliaryDofs | |
Query methods | |
bool | continuous () const |
please doc me | |
bool | continuous (const typename BaseType::IntersectionType &intersection) const |
please doc me | |
bool | multipleBasisFunctionSets () const |
please doc me | |
Basis function set methods | |
int | order () const |
return polynomial order | |
int | order (const EntityType &entity) const |
return polynomial order | |
BasisFunctionSetType | basisFunctionSet (const EntityType &entity) const |
return basis function set | |
Interpolation | |
InterpolationType | interpolation () const |
return interpolation More... | |
InterpolationImplType | interpolation (const EntityType &entity) const |
return interpolation More... | |
InterpolationImplType | localInterpolation (const EntityType &entity) const |
return interpolation More... | |
Block mapper | |
BlockMapperType & | blockMapper () const |
return block mapper | |
Adaptation | |
const KeyType & | key (const EntityType &entity) const |
get identifiying basis function set key assigned to given entity More... | |
void | mark (const KeyType &key, const EntityType &entity) |
assign new key to given entity More... | |
KeyType | getMark (const EntityType &entity) const |
get key to be assigned to an entity after next call to adapt() More... | |
bool | adapt () |
please doc me | |
bool | adapt (DataProjection< DiscreteFunctionSpace, Implementation > &projection) |
please doc me | |
Deprecated methods | |
DFSpaceIdentifier | type () const |
Non-interface methods | |
const BasisFunctionSetsType & | basisFunctionSets () const |
return basis function sets | |
Static Public Attributes | |
static constexpr std::size_t | localBlockSize |
size of local blocks | |
Related Functions | |
(Note that these are not member functions.) | |
bool | operator== (const DiscreteFunctionSpaceInterface< Traits > &X, const DiscreteFunctionSpaceInterface< Traits > &Y) |
check two spaces for equality More... | |
Detailed Description
class Dune::Fem::hpDG::HierarchicLegendreDiscontinuousGalerkinSpace< FunctionSpace, GridPart, order, Storage >
Implementation of an \(hp\)-adaptive discrete function space using product Legendre polynomials.
- Template Parameters
-
FunctionSpace a Dune::Fem::FunctionSpace GridPart a Dune::Fem::GridPart order maximum polynomial order per coordinate Storage for certain caching features
Member Function Documentation
◆ auxiliarySize()
|
inlineinherited |
get number of auxiliary DoFs for this space
- Returns
- number of auxiliary DoFs (degrees of freedom that are NOT owned by this process)
◆ begin()
|
inlineinherited |
get iterator pointing to the first entity of the associated grid partition
- Returns
- iterator pointing to first entity
- Note
- The default implementation uses the codim 0 iterators of the associated grid partition.
◆ communicate() [1/2]
|
inlineinherited |
communicate data for given discrete function using the space's default communication operation
- Parameters
-
discreteFunction discrete function to be communicated
◆ communicate() [2/2]
|
inlineinherited |
communicate data for given discrete function
- Parameters
-
discreteFunction discrete function to be communicated [in] op communication operation to use (see DFCommunicationOperation)
◆ communicationDirection()
|
inlineinherited |
return the communication interface appropriate for this space
- Returns
- communication interface
◆ communicationInterface()
|
inlineinherited |
return the communication interface appropriate for this space
- Returns
- communication interface
◆ communicator()
|
inlineinherited |
return reference to communicator (see CommunicationManager)
- Returns
- reference to communicator
◆ continuous()
|
inlineinherited |
returns true if discrete functions over this space have zero jump over the given intersection.
For example, a Lagrange space returns true iff the intersection is conforming while a discontiuous Galerkin space always returns false.
- Parameters
-
intersection Intersection for which we want to know the continuety
- Returns
- true if the space contians functions which are continuous over the intersection, false otherwise
◆ createDataHandle()
|
inlineinherited |
- Note
- The default implementation is return CommDataHandle< DiscreteFunction, Operation > :: Type( discreteFunction );
◆ end()
|
inlineinherited |
get iterator pointing behind the last entity of the associated grid partition
- Returns
- iterator pointing behind last entity
- Note
- The default implementation uses the codim 0 iterators of the associated grid partition.
◆ forEach()
|
inlineinherited |
apply a functor to each entity in the associated grid partition
The functor must provide an the following operator
- Parameters
-
[in] f functor to apply
- Note
- The default implementation simply does the following: f( *it );IteratorType end() constget iterator pointing behind the last entity of the associated grid partitionDefinition: discretefunctionspace.hh:817IteratorType begin() constget iterator pointing to the first entity of the associated grid partitionDefinition: discretefunctionspace.hh:807GridPartType::template Codim< Traits::codimension >::IteratorType IteratorTypetype of iterator for grid traversalDefinition: discretefunctionspace.hh:222
◆ geomTypes()
|
inlineinherited |
returns true if the grid has more than one geometry type
- Returns
- true if the underlying grid has more than one geometry type (hybrid grid), false otherwise
◆ getMark()
|
inlineinherited |
get key to be assigned to an entity after next call to adapt()
- Parameters
-
[in] entity grid part entity
- Returns
- key
◆ grid() [1/2]
|
inlineinherited |
get reference to grid this discrete function space belongs to
- Returns
- reference to grid
◆ grid() [2/2]
|
inlineinherited |
get reference to grid this discrete function space belongs to
- Returns
- constant reference to grid
◆ gridPart() [1/2]
|
inlineinherited |
get a reference to the associated grid partition
- Returns
- reference to the grid partition
◆ gridPart() [2/2]
|
inlineinherited |
◆ indexSet()
|
inlineinherited |
Get a reference to the associated index set.
- Returns
- const reference to index set
◆ interpolation() [1/2]
|
inlineinherited |
return interpolation
- Parameters
-
[in] entity a grid part entity
- Returns
- local interpolation
◆ interpolation() [2/2]
|
inlineinherited |
return interpolation
- Parameters
-
[in] entity a grid part entity
- Returns
- local interpolation
◆ key()
|
inlineinherited |
get identifiying basis function set key assigned to given entity
- Parameters
-
[in] entity grid part entity
- Returns
- key
◆ localInterpolation()
|
inlineinherited |
return interpolation
- Parameters
-
[in] entity a grid part entity
- Returns
- local interpolation
◆ mark()
|
inlineinherited |
assign new key to given entity
- Parameters
-
[in] key key identifying basis function set [in] entity grid part entity
◆ multipleGeometryTypes()
|
inlineinherited |
returns true if the grid has more than one geometry type
- Returns
- true if the underlying grid has more than one geometry type (hybrid grid), false otherwise
◆ primarySize()
|
inlineinherited |
get number of primary DoFs for this space
- Returns
- number of primary DoFs (degrees of freedom that are owned by this process )
◆ sequence()
|
inlineinherited |
get index of the sequence in grid sequences
- Returns
- number of current sequence
◆ size()
|
inlineinherited |
get number of DoFs for this space
- Returns
- number of DoFs (degrees of freedom)
Friends And Related Function Documentation
◆ operator==()
|
related |
check two spaces for equality
This is a default implemented equality operator for discrete function spaces. It assumes the mapper to be a singleton and then compares the addresses of the two mappers.
Note that this method can be specialized by implementing another version that uses the exact traits of the discrete function space.
The documentation for this class was generated from the following file:
- dune/fem/space/hpdg/legendre.hh