dune-grid  2.5.0
leveliterator.hh
Go to the documentation of this file.
1 // -*- tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
2 // vi: set et ts=4 sw=2 sts=2:
3 #ifndef DUNE_ALBERTA_LEVELITERATOR_HH
4 #define DUNE_ALBERTA_LEVELITERATOR_HH
5 
7 
9 
10 #if HAVE_ALBERTA
11 
12 namespace Dune
13 {
14 
15  // AlbertaGridLevelIterator
16  // ------------------------
17 
18  template< int codim, PartitionIteratorType pitype, class GridImp >
19  class AlbertaGridLevelIterator
20  : public AlbertaGridTreeIterator< codim, GridImp, false >
21  {
22  typedef AlbertaGridLevelIterator< codim, pitype, GridImp > This;
24 
25  public:
26  typedef typename Base::Entity Entity;
27  typedef typename Base::MarkerVector MarkerVector;
28 
30  {}
31 
33  AlbertaGridLevelIterator ( const GridImp &grid, int level )
34  : Base( grid, level )
35  {}
36 
38  AlbertaGridLevelIterator ( const GridImp &grid,
39  const MarkerVector *vec,
40  int level )
41  : Base( grid, vec, level )
42  {}
43 
45  void increment ()
46  {
48  }
49  };
50 
51 
52  template< int codim, class GridImp >
53  class AlbertaGridLevelIterator< codim, Ghost_Partition, GridImp >
54  : public AlbertaGridTreeIterator< codim, GridImp, false >
55  {
58 
59  public:
60  typedef typename Base::Entity Entity;
61  typedef typename Base::MarkerVector MarkerVector;
62 
64  {}
65 
67  AlbertaGridLevelIterator ( const GridImp &grid, int level )
68  : Base( grid, level )
69  {}
70 
72  AlbertaGridLevelIterator ( const GridImp &grid,
73  const MarkerVector *vec,
74  int level )
75  : Base( grid, level )
76  {}
77 
79  void increment ()
80  {
82  }
83  };
84 }
85 
86 #endif // #if HAVE_ALBERTA
87 
88 #endif // #ifndef DUNE_ALBERTA_LEVELITERATOR_HH
AlbertaGridLevelIterator(const GridImp &grid, const MarkerVector *vec, int level)
Constructor making begin iterator.
Definition: leveliterator.hh:38
marker assigning subentities to one element containing them
Definition: treeiterator.hh:29
GridImp::template Codim< codim >::Entity Entity
Definition: treeiterator.hh:202
void increment()
increment the iterator
Definition: leveliterator.hh:79
AlbertaGridLevelIterator()
Definition: leveliterator.hh:29
Base::MarkerVector MarkerVector
Definition: leveliterator.hh:27
AlbertaGridLevelIterator(const GridImp &grid, int level)
Constructor making end iterator.
Definition: leveliterator.hh:33
AlbertaGridLevelIterator(const GridImp &grid, const MarkerVector *vec, int level)
Constructor making begin iterator (which is the end iterator in this case)
Definition: leveliterator.hh:72
Base::Entity Entity
Definition: leveliterator.hh:60
Base::Entity Entity
Definition: leveliterator.hh:26
Base::MarkerVector MarkerVector
Definition: leveliterator.hh:61
AlbertaGridLevelIterator(const GridImp &grid, int level)
Constructor making end iterator.
Definition: leveliterator.hh:67
void increment()
increment the iterator
Definition: leveliterator.hh:45
int level() const
ask for level of entities
Definition: albertagrid/entitypointer.hh:147
Include standard header files.
Definition: agrid.hh:59
const GridImp & grid() const
obtain a reference to the grid
Definition: albertagrid/entitypointer.hh:170
only ghost entities
Definition: gridenums.hh:140
void increment()
increment
Definition: treeiterator.hh:383
Definition: albertagrid/gridfamily.hh:72
EntityPointer implementation for AlbertaGrid.
Definition: albertagrid/entity.hh:21