1#ifndef DUNE_ALUGRID_3D_GRIDVIEW_HH
2#define DUNE_ALUGRID_3D_GRIDVIEW_HH
6#include <dune/common/exceptions.hh>
8#include <dune/grid/common/capabilities.hh>
9#include <dune/grid/common/gridview.hh>
14 template<
class Gr
idImp, PartitionIteratorType pitype >
15 class ALU3dLevelGridView;
17 template<
class Gr
idImp, PartitionIteratorType pitype >
18 class ALU3dLeafGridView;
21 template<
class Gr
idImp, PartitionIteratorType pitype >
27 typedef typename std::remove_const<GridImp>::type
Grid;
30 typedef typename Grid :: Traits :: LevelIndexSet
IndexSet;
36 typedef typename Grid :: Traits :: LevelIntersectionIterator
46 typedef typename Twists::Twist
Twist;
48 typedef typename Grid :: Traits
61 template< PartitionIteratorType pit >
71 enum {
conforming = Capabilities :: isLevelwiseConforming< Grid > :: v };
75 template<
class Gr
idImp, PartitionIteratorType pitype >
119 return grid().levelIndexSet( level_ );
125 return grid().size( level_, codim );
129 int size (
const GeometryType &type )
const
131 return grid().size( level_, type );
138 return grid().template lbegin< cd, pitype >( level_ );
142 template<
int cd, PartitionIteratorType pit >
145 return grid().template lbegin< cd, pit >( level_ );
152 return grid().template lend< cd, pitype >( level_ );
156 template<
int cd, PartitionIteratorType pit >
159 return grid().template lend< cd, pit >( level_ );
166 return grid().ilevelbegin( entity );
173 return grid().ilevelend( entity );
179 return grid().comm();
185 return grid().overlapSize(level_, codim);
191 return grid().ghostSize(level_, codim);
195 template<
class DataHandle,
class Data >
196 typename Grid::LevelCommunication
communicate ( CommDataHandleIF< DataHandle, Data > &data,
197 InterfaceType iftype,
198 CommunicationDirection dir )
const
200 return grid().communicate( data, iftype, dir, level_ );
206 return grid().template twists< cd >( type );
215 template<
class Gr
idImp, PartitionIteratorType pitype >
220 typedef typename std::remove_const<GridImp>::type
Grid;
223 typedef typename Grid :: Traits :: LeafIndexSet
IndexSet;
229 typedef typename Grid :: Traits :: LeafIntersectionIterator
239 typedef typename Twists::Twist
Twist;
241 typedef typename Grid :: Traits
254 template <PartitionIteratorType pit >
264 enum {
conforming = Capabilities :: isLeafwiseConforming< Grid > :: v };
268 template<
class Gr
idImp, PartitionIteratorType pitype >
312 return grid().leafIndexSet();
318 return grid().size( codim );
322 int size (
const GeometryType &type )
const
324 return grid().size( type );
331 return grid().template leafbegin< cd, pitype >();
335 template<
int cd, PartitionIteratorType pit >
338 return grid().template leafbegin< cd, pit >();
345 return grid().template leafend< cd, pitype >();
349 template<
int cd, PartitionIteratorType pit >
352 return grid().template leafend< cd, pit >();
359 return grid().ileafbegin( entity );
366 return grid().ileafend( entity );
372 return grid().comm();
378 return grid().overlapSize(codim);
384 return grid().ghostSize(codim);
388 template<
class DataHandle,
class Data >
389 typename Grid::LeafCommunication
communicate ( CommDataHandleIF< DataHandle, Data > &data,
390 InterfaceType iftype,
391 CommunicationDirection dir )
const
393 return grid().communicate( data, iftype, dir );
399 return grid().template twists< cd >( type );
Definition alu3dinclude.hh:80
Definition gridview.hh:77
int size(int codim) const
obtain number of entities in a given codimension
Definition gridview.hh:123
Traits::Grid Grid
type of the grid
Definition gridview.hh:84
int overlapSize(int codim) const
Return size of the overlap region for a given codim on the grid view.
Definition gridview.hh:183
int ghostSize(int codim) const
Return size of the ghost region for a given codim on the grid view.
Definition gridview.hh:189
Codim< cd >::Iterator end() const
obtain end iterator for this view
Definition gridview.hh:150
IntersectionIterator iend(const typename Codim< 0 > ::Entity &entity) const
obtain end intersection iterator with respect to this view
Definition gridview.hh:171
ALU3dLevelGridView(const Grid &grid, int level)
Definition gridview.hh:104
Codim< cd >::template Partition< pit >::Iterator end() const
obtain end iterator for this view
Definition gridview.hh:157
const IndexSet & indexSet() const
obtain the index set
Definition gridview.hh:117
@ conforming
Definition gridview.hh:102
Traits::CollectiveCommunication CollectiveCommunication
type of the collective communication
Definition gridview.hh:96
ALU3dLevelGridViewTraits< GridImp, pitype > Traits
Definition gridview.hh:81
Codim< cd >::template Partition< pit >::Iterator begin() const
obtain begin iterator for this view
Definition gridview.hh:143
int size(const GeometryType &type) const
obtain number of entities with a given geometry type
Definition gridview.hh:129
Codim< cd >::Twists twists(GeometryType type) const
Definition gridview.hh:204
Traits::IntersectionIterator IntersectionIterator
type of the intersection iterator
Definition gridview.hh:93
Traits::Intersection Intersection
type of the intersection
Definition gridview.hh:90
IntersectionIterator ibegin(const typename Codim< 0 > ::Entity &entity) const
obtain begin intersection iterator with respect to this view
Definition gridview.hh:164
Codim< cd >::Iterator begin() const
obtain begin iterator for this view
Definition gridview.hh:136
Traits::IndexSet IndexSet
type of the index set
Definition gridview.hh:87
const CollectiveCommunication & comm() const
obtain collective communication object
Definition gridview.hh:177
Grid::LevelCommunication communicate(CommDataHandleIF< DataHandle, Data > &data, InterfaceType iftype, CommunicationDirection dir) const
Definition gridview.hh:196
const Grid & grid() const
obtain a const reference to the underlying hierarchic grid
Definition gridview.hh:110
Definition gridview.hh:270
IntersectionIterator ibegin(const typename Codim< 0 > ::Entity &entity) const
obtain begin intersection iterator with respect to this view
Definition gridview.hh:357
Codim< cd >::Twists twists(GeometryType type) const
Definition gridview.hh:397
Traits::Intersection Intersection
type of the intersection
Definition gridview.hh:283
const IndexSet & indexSet() const
obtain the index set
Definition gridview.hh:310
Grid::LeafCommunication communicate(CommDataHandleIF< DataHandle, Data > &data, InterfaceType iftype, CommunicationDirection dir) const
Definition gridview.hh:389
Traits::Grid Grid
type of the grid
Definition gridview.hh:277
ALU3dLeafGridViewTraits< GridImp, pitype > Traits
Definition gridview.hh:274
int size(int codim) const
obtain number of entities in a given codimension
Definition gridview.hh:316
int overlapSize(int codim) const
Return size of the overlap region for a given codim on the grid view.
Definition gridview.hh:376
Traits::IntersectionIterator IntersectionIterator
type of the intersection iterator
Definition gridview.hh:286
const Grid & grid() const
obtain a const reference to the underlying hierarchic grid
Definition gridview.hh:303
ALU3dLeafGridView(const Grid &grid)
Definition gridview.hh:298
IntersectionIterator iend(const typename Codim< 0 > ::Entity &entity) const
obtain end intersection iterator with respect to this view
Definition gridview.hh:364
int size(const GeometryType &type) const
obtain number of entities with a given geometry type
Definition gridview.hh:322
Codim< cd >::Iterator end() const
obtain end iterator for this view
Definition gridview.hh:343
int ghostSize(int codim) const
Return size of the ghost region for a given codim on the grid view.
Definition gridview.hh:382
Codim< cd >::template Partition< pit >::Iterator end() const
obtain end iterator for this view
Definition gridview.hh:350
Codim< cd >::Iterator begin() const
obtain begin iterator for this view
Definition gridview.hh:329
const CollectiveCommunication & comm() const
obtain collective communication object
Definition gridview.hh:370
@ conforming
Definition gridview.hh:295
Codim< cd >::template Partition< pit >::Iterator begin() const
obtain begin iterator for this view
Definition gridview.hh:336
Traits::CollectiveCommunication CollectiveCommunication
type of the collective communication
Definition gridview.hh:289
Traits::IndexSet IndexSet
type of the index set
Definition gridview.hh:280
Definition gridview.hh:23
std::remove_const< GridImp >::type Grid
type of the grid
Definition gridview.hh:27
ALU3dLevelGridView< GridImp, pitype > GridViewImp
Definition gridview.hh:24
Grid::Traits::LevelIndexSet IndexSet
type of the index set
Definition gridview.hh:30
@ conforming
Definition gridview.hh:71
Grid::Traits::LevelIntersection Intersection
type of the intersection
Definition gridview.hh:33
Grid::Traits::CollectiveCommunication CollectiveCommunication
type of the collective communication
Definition gridview.hh:40
Grid::Traits::LevelIntersectionIterator IntersectionIterator
type of the intersection iterator
Definition gridview.hh:37
Definition gridview.hh:44
Grid::Traits::template Codim< cd >::template Partition< pitype >::LevelIterator Iterator
Definition gridview.hh:50
Grid::template Codim< cd >::LocalGeometry LocalGeometry
Definition gridview.hh:58
Grid::Traits::template Codim< cd >::EntityPointer EntityPointer
Definition gridview.hh:54
Grid::template Codim< cd >::Geometry Geometry
Definition gridview.hh:56
Grid::Traits::template Codim< cd >::Entity Entity
Definition gridview.hh:52
Grid::Traits::template Codim< cd >::Twists Twists
Definition gridview.hh:45
Twists::Twist Twist
Definition gridview.hh:46
Define types needed to iterate over entities of a given partition type.
Definition gridview.hh:63
Grid::template Codim< cd >::template Partition< pit >::LevelIterator Iterator
iterator over a given codim and partition type
Definition gridview.hh:67
Codim Structure.
Definition gridview.hh:100
Definition gridview.hh:216
Grid::Traits::LeafIndexSet IndexSet
type of the index set
Definition gridview.hh:223
std::remove_const< GridImp >::type Grid
type of the grid
Definition gridview.hh:220
Grid::Traits::LeafIntersection Intersection
type of the intersection
Definition gridview.hh:226
Grid::Traits::CollectiveCommunication CollectiveCommunication
type of the collective communication
Definition gridview.hh:233
ALU3dLeafGridView< GridImp, pitype > GridViewImp
Definition gridview.hh:217
Grid::Traits::LeafIntersectionIterator IntersectionIterator
type of the intersection iterator
Definition gridview.hh:230
@ conforming
Definition gridview.hh:264
Definition gridview.hh:237
Grid::Traits::template Codim< cd >::template Partition< pitype >::LeafIterator Iterator
Definition gridview.hh:243
Grid::Traits::template Codim< cd >::Twists Twists
Definition gridview.hh:238
Grid::Traits::template Codim< cd >::EntityPointer EntityPointer
Definition gridview.hh:247
Grid::template Codim< cd >::Geometry Geometry
Definition gridview.hh:249
Twists::Twist Twist
Definition gridview.hh:239
Grid::template Codim< cd >::LocalGeometry LocalGeometry
Definition gridview.hh:251
Grid::Traits::template Codim< cd >::Entity Entity
Definition gridview.hh:245
Define types needed to iterate over entities of a given partition type.
Definition gridview.hh:256
Grid::template Codim< cd >::template Partition< pit >::LeafIterator Iterator
iterator over a given codim and partition type
Definition gridview.hh:260
Codim Structure.
Definition gridview.hh:293