Dune Core Modules (2.5.0)

Dune::LevelMultipleCodimMultipleGeomTypeMapper< G, Layout > Class Template Reference

Multiple codim and multiple geometry type mapper for entities of one level. More...

#include <dune/grid/common/mcmgmapper.hh>

Public Types

typedef GV::IndexSet::IndexType Index
 Number type used for indices.
 

Public Member Functions

 LevelMultipleCodimMultipleGeomTypeMapper (const G &grid, int level)
 The constructor. More...
 
 LevelMultipleCodimMultipleGeomTypeMapper (const G &grid, int level, const Layout< G::dimension > layout)
 The constructor. More...
 
Index index (const EntityType &e) const
 Map entity to array index. More...
 
Index subIndex (const typename GV::template Codim< 0 >::Entity &e, int i, unsigned int codim) const
 Map subentity of codim 0 entity to array index. More...
 
Index subIndex (const typename G::Traits::template Codim< 0 >::Entity &e, int i, unsigned int codim) const
 Map subentity i of codim cc of a codim 0 entity to array index. More...
 
int size () const
 Return total number of entities in the entity set managed by the mapper. More...
 
bool contains (const EntityType &e, Index &result) const
 Returns true if the entity is contained in the index set. More...
 
bool contains (const typename GV::template Codim< 0 >::Entity &e, int i, int cc, Index &result) const
 Returns true if the entity is contained in the index set. More...
 
bool contains (const EntityType &e, int &result) const
 Returns true if the entity is contained in the index set and at the same time the array index is returned. More...
 
bool contains (const typename G::Traits::template Codim< 0 >::Entity &e, int i, int cc, int &result) const
 Returns true if the subentity is contained in the index set and at the same time the array index is returned. More...
 
void update ()
 Recalculates map after mesh adaptation.
 

Detailed Description

template<typename G, template< int > class Layout>
class Dune::LevelMultipleCodimMultipleGeomTypeMapper< G, Layout >

Multiple codim and multiple geometry type mapper for entities of one level.

This mapper uses all entities of a certain codimension on a given level as its entity set.

Template Parameters
GA Dune grid type.
LayoutA helper class template which determines which types of entities are mapped by this mapper. See MultipleCodimMultipleGeomTypeMapper for how exactly this template should look.

Constructor & Destructor Documentation

◆ LevelMultipleCodimMultipleGeomTypeMapper() [1/2]

template<typename G , template< int > class Layout>
Dune::LevelMultipleCodimMultipleGeomTypeMapper< G, Layout >::LevelMultipleCodimMultipleGeomTypeMapper ( const G &  grid,
int  level 
)
inline

The constructor.

Parameters
gridA reference to a grid.
levelA valid level of the grid.

◆ LevelMultipleCodimMultipleGeomTypeMapper() [2/2]

template<typename G , template< int > class Layout>
Dune::LevelMultipleCodimMultipleGeomTypeMapper< G, Layout >::LevelMultipleCodimMultipleGeomTypeMapper ( const G &  grid,
int  level,
const Layout< G::dimension >  layout 
)
inline

The constructor.

Use this constructor to provide a custom layout object e.g. not using the default constructor.

Parameters
gridA reference to a grid.
levelA valid level of the grid.
layoutA layout object

Member Function Documentation

◆ contains() [1/4]

bool Dune::MultipleCodimMultipleGeomTypeMapper< G::LevelGridView , Layout >::contains ( const EntityType &  e,
Index result 
) const
inlineinherited

Returns true if the entity is contained in the index set.

Parameters
eReference to entity
resultinteger reference where corresponding index is stored if true
Returns
true if entity is in entity set of the mapper

◆ contains() [2/4]

bool Dune::Mapper< GV::Grid , MultipleCodimMultipleGeomTypeMapper< G::LevelGridView, Layout > , GV::IndexSet::IndexType >::contains ( const EntityType &  e,
int &  result 
) const
inlineinherited

Returns true if the entity is contained in the index set and at the same time the array index is returned.

Parameters
[in]eReference to entity
[out]resultFilled with array index if entity is contained
Returns
true if entity is in entity set of the mapper

◆ contains() [3/4]

bool Dune::Mapper< GV::Grid , MultipleCodimMultipleGeomTypeMapper< G::LevelGridView, Layout > , GV::IndexSet::IndexType >::contains ( const typename G::Traits::template Codim< 0 >::Entity &  e,
int  i,
int  cc,
int &  result 
) const
inlineinherited

Returns true if the subentity is contained in the index set and at the same time the array index is returned.

Parameters
[in]eReference to codim 0 entity
[in]isubentity number
[in]ccsubentity codim
[out]resultFilled with array index if entity is contained
Returns
true if entity is in entity set of the mapper

◆ contains() [4/4]

bool Dune::MultipleCodimMultipleGeomTypeMapper< G::LevelGridView , Layout >::contains ( const typename GV::template Codim< 0 >::Entity &  e,
int  i,
int  cc,
Index result 
) const
inlineinherited

Returns true if the entity is contained in the index set.

Parameters
eReference to codim 0 entity
isubentity number
ccsubentity codim
resultinteger reference where corresponding index is stored if true
Returns
true if entity is in entity set of the mapper

◆ index()

Index Dune::MultipleCodimMultipleGeomTypeMapper< G::LevelGridView , Layout >::index ( const EntityType &  e) const
inlineinherited

Map entity to array index.

Template Parameters
EntityType
Parameters
eReference to codim EntityType entity.
Returns
An index in the range 0 ... Max number of entities in set - 1.

◆ size()

int Dune::MultipleCodimMultipleGeomTypeMapper< G::LevelGridView , Layout >::size ( ) const
inlineinherited

Return total number of entities in the entity set managed by the mapper.

This number can be used to allocate a vector of data elements associated with the entities of the set. In the parallel case this number is per process (i.e. it may be different in different processes).

Returns
Size of the entity set.

◆ subIndex() [1/2]

Index Dune::Mapper< GV::Grid , MultipleCodimMultipleGeomTypeMapper< G::LevelGridView, Layout > , GV::IndexSet::IndexType >::subIndex ( const typename G::Traits::template Codim< 0 >::Entity &  e,
int  i,
unsigned int  codim 
) const
inlineinherited

Map subentity i of codim cc of a codim 0 entity to array index.

Parameters
eReference to codim 0 entity.
iNumber of codim cc subentity of e, where cc is the template parameter of the function.
codimcodimension of subentity of e
Returns
An index in the range 0 ... Max number of entities in set - 1.

◆ subIndex() [2/2]

Index Dune::MultipleCodimMultipleGeomTypeMapper< G::LevelGridView , Layout >::subIndex ( const typename GV::template Codim< 0 >::Entity &  e,
int  i,
unsigned int  codim 
) const
inlineinherited

Map subentity of codim 0 entity to array index.

Parameters
eReference to codim 0 entity.
iNumber of subentity of e
codimCodimension of the subentity
Returns
An index in the range 0 ... Max number of entities in set - 1.

The documentation for this class was generated from the following file:
Creative Commons License   |  Legal Statements / Impressum  |  Hosted by TU Dresden  |  generated with Hugo v0.111.3 (Nov 12, 23:30, 2024)