Dune Core Modules (2.4.1)

geometry.hh
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_ALU3DGRIDGEOMETRY_HH
4#define DUNE_ALU3DGRIDGEOMETRY_HH
5
6// System includes
7
8// Dune includes
11
12// Local includes
13#include "alu3dinclude.hh"
14#include "topology.hh"
15#include "mappings.hh"
16#include <dune/grid/alugrid/common/objectfactory.hh>
17
18namespace Dune
19{
20
21 // Forward declarations
22 template<int cd, int dim, class GridImp>
23 class ALU3dGridEntity;
24 template<int cd, class GridImp >
25 class ALU3dGridEntityPointer;
26 template<int mydim, int coorddim, class GridImp>
27 class ALU3dGridGeometry;
28 template< ALU3dGridElementType, class >
29 class ALU3dGrid;
30 class BilinearSurfaceMapping;
31 class TrilinearMapping;
32
33 template< class GridImp >
34 class ALU3dGridIntersectionIterator;
35
36 template <int cdim>
37 class MyALUGridGeometryImplementation
38 {
39 public:
40 typedef FieldVector<alu3d_ctype, cdim> CoordinateVectorType;
41
42 static const signed char invalid = -1; // means geometry is not meaningful
43 static const signed char updated = 0; // means the point values have been set
44 static const signed char buildmapping = 1; // means updated and mapping was build
45
46 template <int dim, int corners, class Mapping>
47 class GeometryImplBase
48 {
49 private:
50 // prohibited due to reference counting
51 GeometryImplBase( const GeometryImplBase& );
52
53 protected:
55 static const int corners_ = corners ;
56
58 typedef FieldMatrix<alu3d_ctype, corners , cdim> CoordinateMatrixType;
59
60 template <int dummy, int dimused>
61 struct CoordTypeExtractorType
62 {
63 typedef CoordinateMatrixType Type;
64 };
65
66 template <int dummy>
67 struct CoordTypeExtractorType< dummy, 3 >
68 {
69 typedef CoordinateMatrixType* Type;
70 };
71
72 typedef typename CoordTypeExtractorType< 0, dim > :: Type CoordinateStorageType ;
73
75 typedef Mapping MappingType;
76
78 CoordinateStorageType coord_ ;
79
81 MappingType map_;
82
84 double volume_ ;
85
87 mutable unsigned int refCount_;
88
90 signed char status_ ;
91 public:
93 GeometryImplBase()
94 : coord_( 0 ),
95 map_(),
96 volume_( 1.0 )
97 {
98 reset();
99 }
100
102 void reset()
103 {
104 // reset reference counter
105 refCount_ = 1;
106 // reset status
107 status_ = invalid ;
108 }
109
111 void operator ++ () { ++ refCount_; }
112
114 void operator -- () { assert( refCount_ > 0 ); --refCount_; }
115
117 bool operator ! () const { return refCount_ == 0; }
118
120 bool stillUsed () const { return refCount_ > 1 ; }
121
122 // copy coordinate vector from field vector or alu3d_ctype[cdim]
123 template <class CoordPtrType>
124 static inline void copy(const CoordPtrType& p,
125 CoordinateVectorType& c)
126 {
127 assert( cdim == 3 );
128 c[0] = p[0];
129 c[1] = p[1];
130 c[2] = p[2];
131 }
132
133 template <class CoordPtrType>
134 void update(const CoordPtrType&,
135 const CoordPtrType&,
136 const CoordPtrType&,
137 const CoordPtrType&,
138 const CoordPtrType&,
139 const CoordPtrType&,
140 const CoordPtrType&,
141 const CoordPtrType& ) const
142 {
143 DUNE_THROW(InvalidStateException,"This method should not be called!");
144 }
145
146 template <class CoordPtrType>
147 void update(const CoordPtrType&,
148 const CoordPtrType&,
149 const CoordPtrType&,
150 const CoordPtrType& ) const
151 {
152 DUNE_THROW(InvalidStateException,"This method should not be called!");
153 }
154
155 template <class CoordPtrType>
156 void update(const CoordPtrType&,
157 const CoordPtrType&,
158 const CoordPtrType& ) const
159 {
160 DUNE_THROW(InvalidStateException,"This method should not be called!");
161 }
162
163 // set status to invalid
164 void invalidate () { status_ = invalid ; }
165
166 // return true if geometry is valid
167 bool valid () const { return status_ != invalid ; }
168
169 // set volume
170 void setVolume( const double volume ) { volume_ = volume ; }
171
172 // return volume
173 double volume() const { return volume_; }
174 };
175
177 template <int dummy, int dim,
178 ALU3dGridElementType eltype> class GeometryImpl;
179 public:
180 // geometry implementation for edges and vertices
181 template <int dummy, int dim, ALU3dGridElementType eltype>
182 class GeometryImpl : public GeometryImplBase< dim, dim+1, LinearMapping<cdim, dim> >
183 {
184 typedef GeometryImplBase< dim, dim+1, LinearMapping<cdim, dim> > BaseType;
185
186 using BaseType :: corners_ ;
187 using BaseType :: copy ;
188 using BaseType :: coord_ ;
189 using BaseType :: map_ ;
190 using BaseType :: status_ ;
191
192 typedef typename BaseType :: MappingType MappingType ;
193 public:
194 using BaseType :: update ;
195 using BaseType :: valid ;
196
197 // return coordinate vector
198 inline const CoordinateVectorType& operator [] (const int i) const
199 {
200 assert( valid() );
201 assert( i>=0 && i<corners_ );
202 return coord_[i];
203 }
204
205 inline MappingType& mapping()
206 {
207 assert( valid() );
208 if( status_ == buildmapping ) return map_;
209
210 map_.buildMapping( coord_[0] );
211 status_ = buildmapping ;
212 return map_;
213 }
214
215 // update vertex
216 template <class CoordPtrType>
217 inline void update(const CoordPtrType& p0)
218 {
219 assert( corners_ == 1 );
220 copy( p0, coord_[0] );
221 // we need to update the mapping
222 status_ = updated ;
223 }
224 };
225
226 // geometry implementation for edges and vertices
227 template <int dummy, ALU3dGridElementType eltype>
228 class GeometryImpl<dummy,1,eltype>
229 : public GeometryImplBase< 1, 2, LinearMapping<cdim, 1> >
230 {
231 enum { dim = 1 };
232 typedef GeometryImplBase< dim, dim+1, LinearMapping<cdim, dim> > BaseType;
233
234 using BaseType :: corners_ ;
235 using BaseType :: copy ;
236 using BaseType :: coord_ ;
237 using BaseType :: map_ ;
238 using BaseType :: status_ ;
239
240 typedef typename BaseType :: MappingType MappingType;
241 public:
242 using BaseType :: update ;
243 using BaseType :: valid ;
244
245 // return coordinate vector
246 inline const CoordinateVectorType& operator [] (const int i) const
247 {
248 assert( valid() );
249 assert( i>=0 && i<corners_ );
250 return coord_[i];
251 }
252
253 inline MappingType& mapping()
254 {
255 assert( valid() );
256 if( status_ == buildmapping ) return map_;
257
258 map_.buildMapping( coord_[0], coord_[1] );
259 status_ = buildmapping ;
260 return map_;
261 }
262
263 // update edge
264 template <class CoordPtrType>
265 inline void update(const CoordPtrType& p0,
266 const CoordPtrType& p1)
267 {
268 assert( corners_ == 2 );
269 copy( p0, coord_[0] );
270 copy( p1, coord_[1] );
271 status_ = updated;
272 }
273 };
274
275 // geom impl for simplex faces (triangles)
276 template <int dummy>
277 class GeometryImpl<dummy, 2, tetra>
278 : public GeometryImplBase< 2, 3, LinearMapping<cdim, 2> >
279 {
280 // dim = 2, corners = 3
281 typedef GeometryImplBase< 2, 3, LinearMapping<cdim, 2> > BaseType;
282
283 using BaseType :: corners_ ;
284 using BaseType :: copy ;
285 using BaseType :: coord_ ;
286 using BaseType :: map_ ;
287 using BaseType :: status_ ;
288
289 typedef typename BaseType :: MappingType MappingType ;
290 public:
291 using BaseType :: update ;
292 using BaseType :: valid ;
293
294 // return coordinate vector
295 inline const CoordinateVectorType& operator [] (const int i) const
296 {
297 assert( valid() );
298 assert( i>=0 && i<corners_ );
299 return coord_[i];
300 }
301
302 // update geometry coordinates
303 template <class CoordPtrType>
304 inline void update(const CoordPtrType& p0,
305 const CoordPtrType& p1,
306 const CoordPtrType& p2)
307 {
308 copy(p0, coord_[0] );
309 copy(p1, coord_[1] );
310 copy(p2, coord_[2] );
311 status_ = updated;
312 }
313
314 // return mapping (always up2date)
315 inline MappingType& mapping()
316 {
317 assert( valid() );
318 if( status_ == buildmapping ) return map_;
319
320 map_.buildMapping( coord_[0], coord_[1], coord_[2] );
321 status_ = buildmapping ;
322 return map_;
323 }
324 };
325
327 //
328 // hexa specializations
329 //
331
332 // geom impl for cube faces (quadrilaterals)
333 template <int dummy>
334 class GeometryImpl<dummy, 2, hexa>
335 : public GeometryImplBase< 2, 4, BilinearSurfaceMapping >
336 {
337 // dim = 2, corners = 4
338 typedef GeometryImplBase< 2, 4, BilinearSurfaceMapping > BaseType;
339
340 using BaseType :: corners_ ;
341 using BaseType :: copy ;
342 using BaseType :: coord_ ;
343 using BaseType :: map_ ;
344 using BaseType :: status_ ;
345
346 typedef typename BaseType :: MappingType MappingType ;
347 public:
348 using BaseType :: update ;
349 using BaseType :: valid ;
350
351 // return coordinate vector
352 inline const CoordinateVectorType& operator [] (const int i) const
353 {
354 assert( valid() );
355 assert( i>=0 && i<corners_ );
356 return coord_[i];
357 }
358
359 // update geometry coordinates
360 template <class CoordPtrType>
361 inline void update(const CoordPtrType& p0,
362 const CoordPtrType& p1,
363 const CoordPtrType& p2,
364 const CoordPtrType& p3)
365 {
366 copy(p0, coord_[0] );
367 copy(p1, coord_[1] );
368 copy(p2, coord_[2] );
369 copy(p3, coord_[3] );
370 status_ = updated;
371 }
372
373 // return mapping (always up2date)
374 inline MappingType& mapping()
375 {
376 assert( valid() );
377 if( status_ == buildmapping ) return map_;
378
379 map_.buildMapping( coord_[0], coord_[1], coord_[2], coord_[3] );
380 status_ = buildmapping ;
381 return map_;
382 }
383 };
384
385 // geometry impl for hexahedrons
386 template <int dummy>
387 class GeometryImpl<dummy,3, hexa>
388 : public GeometryImplBase< 3, 8, TrilinearMapping >
389 {
390 // dim = 3, corners = 8
391 typedef GeometryImplBase< 3, 8, TrilinearMapping > BaseType;
392
393 using BaseType :: corners_ ;
394 using BaseType :: copy ;
395 using BaseType :: coord_ ;
396 using BaseType :: map_ ;
397 using BaseType :: status_ ;
398
399 typedef typename BaseType :: MappingType MappingType ;
400 typedef typename BaseType :: CoordinateMatrixType CoordinateMatrixType;
401
402 typedef alu3d_ctype CoordPtrType[cdim];
403
404 // coordinate pointer vector
405 const alu3d_ctype* coordPtr_[ corners_ ];
406 public:
407 using BaseType :: update ;
408 using BaseType :: valid ;
409
411 GeometryImpl() : BaseType()
412 {
413 // set initialize coord pointers
414 for( int i=0; i<corners_; ++i )
415 coordPtr_[ i ] = 0;
416 }
417
418 // desctructor
419 ~GeometryImpl()
420 {
421 if( coord_ ) delete coord_;
422 }
423
424 const alu3d_ctype* point( const int i ) const
425 {
426 assert( valid() );
427 assert( i>=0 && i<corners_ );
428 assert( coordPtr_[i] );
429 return coordPtr_[ i ];
430 }
431
432 // return coordinates
433 inline CoordinateVectorType operator [] (const int i) const
434 {
435 CoordinateVectorType coord ;
436 copy( point( i ), coord );
437 return coord ;
438 }
439
440 // update geometry coordinates
441 inline void update(const CoordPtrType& p0,
442 const CoordPtrType& p1,
443 const CoordPtrType& p2,
444 const CoordPtrType& p3,
445 const CoordPtrType& p4,
446 const CoordPtrType& p5,
447 const CoordPtrType& p6,
448 const CoordPtrType& p7)
449 {
450 coordPtr_[0] = &p0[ 0 ];
451 coordPtr_[1] = &p1[ 0 ];
452 coordPtr_[2] = &p2[ 0 ];
453 coordPtr_[3] = &p3[ 0 ];
454 coordPtr_[4] = &p4[ 0 ];
455 coordPtr_[5] = &p5[ 0 ];
456 coordPtr_[6] = &p6[ 0 ];
457 coordPtr_[7] = &p7[ 0 ];
458 status_ = updated;
459 }
460
461 // update geometry in father coordinates
462 template <class GeometryImp>
463 inline void updateInFather(const GeometryImp &fatherGeom ,
464 const GeometryImp &myGeom)
465 {
466 if( coord_ == 0 )
467 {
468 coord_ = new CoordinateMatrixType();
469 }
470
471 CoordinateMatrixType& coord = *coord_;
472 // compute the local coordinates in father refelem
473 for(int i=0; i < myGeom.corners() ; ++i)
474 {
475 // calculate coordinate
476 coord[i] = fatherGeom.local( myGeom.corner( i ) );
477
478 // set pointer
479 coordPtr_[i] = (&(coord[i][0]));
480
481 // to avoid rounding errors
482 for(int j=0; j<cdim; ++j)
483 {
484 if ( coord[i][j] < 1e-16) coord[i][j] = 0.0;
485 }
486 }
487
488 status_ = updated ;
489 }
490
491 // return mapping (always up2date)
492 inline MappingType& mapping()
493 {
494 assert( valid() );
495 if( status_ == buildmapping ) return map_;
496
497 map_.buildMapping( point( 0 ), point( 1 ), point( 2 ), point( 3 ),
498 point( 4 ), point( 5 ), point( 6 ), point( 7 ) );
499
500 status_ = buildmapping;
501 return map_;
502 }
503
504 // set status to invalid
505 void invalidate () { status_ = invalid ; }
506
507 // return true if geometry is valid
508 bool valid () const { return status_ != invalid ; }
509 };
510
511
512 // geometry impl for hexahedrons
513 template <int dummy>
514 class GeometryImpl<dummy,3, tetra>
515 : public GeometryImplBase< 3, 4, LinearMapping<cdim, cdim> >
516 {
517 // dim = 3, corners = 8
518 typedef GeometryImplBase< 3, 4, LinearMapping<cdim, cdim> > BaseType;
519
520 using BaseType :: corners_ ;
521 using BaseType :: copy ;
522 using BaseType :: coord_ ;
523 using BaseType :: map_ ;
524 using BaseType :: status_ ;
525
526 typedef typename BaseType :: MappingType MappingType ;
527 typedef typename BaseType :: CoordinateMatrixType CoordinateMatrixType;
528
529 typedef alu3d_ctype CoordPtrType[cdim];
530
531 // coordinate pointer vector
532 const alu3d_ctype* coordPtr_[ corners_ ];
533 public:
534 using BaseType :: update ;
535 using BaseType :: valid ;
536
537 // default constructor
538 GeometryImpl() : BaseType()
539 {
540 // set initialize coord pointers
541 for( int i=0; i<corners_; ++i )
542 coordPtr_[ i ] = 0;
543 }
544
545 // destructor
546 ~GeometryImpl()
547 {
548 if( coord_ ) delete coord_;
549 }
550
551 const alu3d_ctype* point( const int i ) const
552 {
553 assert( valid() );
554 assert( i>=0 && i<corners_ );
555 assert( coordPtr_[ i ] );
556 return coordPtr_[ i ];
557 }
558
559 // return coordinate vector
560 inline CoordinateVectorType operator [] (const int i) const
561 {
562 CoordinateVectorType coord ;
563 copy( point( i ), coord );
564 return coord ;
565 }
566
567 // update geometry coordinates
568 inline void update(const CoordPtrType& p0,
569 const CoordPtrType& p1,
570 const CoordPtrType& p2,
571 const CoordPtrType& p3)
572 {
573 coordPtr_[0] = &p0[ 0 ];
574 coordPtr_[1] = &p1[ 0 ];
575 coordPtr_[2] = &p2[ 0 ];
576 coordPtr_[3] = &p3[ 0 ];
577 status_ = updated;
578 }
579
580 // update geometry in father coordinates
581 template <class GeometryImp>
582 inline void updateInFather(const GeometryImp &fatherGeom ,
583 const GeometryImp & myGeom)
584 {
585 if( coord_ == 0 )
586 {
587 coord_ = new CoordinateMatrixType();
588 }
589
590 CoordinateMatrixType& coord = *coord_;
591 // compute the local coordinates in father refelem
592 for(int i=0; i < myGeom.corners() ; ++i)
593 {
594 // calculate coordinate
595 coord[i] = fatherGeom.local( myGeom.corner( i ) );
596
597 // set pointer
598 coordPtr_[i] = (&(coord[i][0]));
599
600 // to avoid rounding errors
601 for(int j=0; j<cdim; ++j)
602 {
603 if ( coord[i][j] < 1e-16) coord[i][j] = 0.0;
604 }
605 }
606
607 status_ = updated;
608 }
609
610 // return mapping (always up2date)
611 inline MappingType& mapping()
612 {
613 assert( valid() );
614 if( status_ == buildmapping ) return map_;
615
616 map_.buildMapping( point( 0 ), point( 1 ), point( 2 ), point( 3 ) );
617
618 status_ = buildmapping;
619 return map_;
620 }
621 };
622 }; // end of class ALUGridGeometryImplementation
623
624 template <int mydim, int cdim, class GridImp>
625 class ALU3dGridGeometry :
626 public GeometryDefaultImplementation<mydim, cdim, GridImp, ALU3dGridGeometry>
627 {
628 static const ALU3dGridElementType elementType = GridImp::elementType;
629
630 typedef typename GridImp::MPICommunicatorType Comm;
631
632 friend class ALU3dGridIntersectionIterator<GridImp>;
633
634 typedef typename ALU3dImplTraits< elementType, Comm >::IMPLElementType IMPLElementType;
635 typedef typename ALU3dImplTraits< elementType, Comm >::GEOFaceType GEOFaceType;
636 typedef typename ALU3dImplTraits< elementType, Comm >::GEOEdgeType GEOEdgeType;
637 typedef typename ALU3dImplTraits< elementType, Comm >::GEOVertexType GEOVertexType;
638
639 // interface types
640 typedef typename ALU3dImplTraits< elementType, Comm >::HFaceType HFaceType;
641 typedef typename ALU3dImplTraits< elementType, Comm >::HEdgeType HEdgeType;
642 typedef typename ALU3dImplTraits< elementType, Comm >::VertexType VertexType;
643
644 typedef ElementTopologyMapping<elementType> ElementTopo;
645 typedef FaceTopologyMapping<elementType> FaceTopo;
646
647 enum { corners_ = (elementType == hexa) ? StaticPower<2,mydim>::power : mydim+1 };
648
649 // type of specialized geometry implementation
650 typedef typename MyALUGridGeometryImplementation<cdim> ::
651 template GeometryImpl<0, mydim, elementType > GeometryImplType;
652
653 public:
654 typedef typename GridImp :: ctype ctype;
655
657 typedef FieldVector<ctype, mydim> LocalCoordinate;
658
660 typedef FieldVector<ctype, cdim > GlobalCoordinate;
661
663 typedef FieldMatrix<ctype,cdim,mydim> JacobianInverseTransposed;
664
666 typedef FieldMatrix< ctype, mydim, cdim > JacobianTransposed;
667
668 // type of coordinate matrix for faces
669 typedef FieldMatrix<ctype,
670 EntityCount< elementType > :: numVerticesPerFace , 3> FaceCoordinatesType;
671
674 ALU3dGridGeometry();
675
677 ALU3dGridGeometry( const ALU3dGridGeometry& );
678
680 ALU3dGridGeometry& operator = ( const ALU3dGridGeometry& );
681
683 ~ALU3dGridGeometry( );
684
687 GeometryType type () const;
688
690 int corners () const;
691
693 GlobalCoordinate corner (int i) const;
694
697 GlobalCoordinate global (const LocalCoordinate& local) const;
698
701 LocalCoordinate local (const GlobalCoordinate& global) const;
702
704 ctype integrationElement (const LocalCoordinate& local) const;
705
708 const JacobianInverseTransposed &jacobianInverseTransposed (const LocalCoordinate& local) const;
709
711 const JacobianTransposed& jacobianTransposed (const LocalCoordinate& local) const;
712
714 inline bool affine () const;
715
717 ctype volume () const;
718
719 //***********************************************************************
721 //***********************************************************************
723 bool buildGeom(const IMPLElementType & item);
724 bool buildGeom(const HFaceType & item, int twist, int faceNum);
725 bool buildGeom(const HEdgeType & item, int twist, int);
726 bool buildGeom(const VertexType & item, int twist, int);
727
728 // this method is used by the intersection iterator
729 bool buildGeom(const FaceCoordinatesType& coords);
730
731 // this method is used by the intersection iterator
732 template <class coord_t>
733 bool buildGeom(const coord_t& p0,
734 const coord_t& p1,
735 const coord_t& p2,
736 const coord_t& p3);
737
738 // this method is used by the intersection iterator
739 template <class coord_t>
740 bool buildGeom(const coord_t& p0,
741 const coord_t& p1,
742 const coord_t& p2);
743
745 template <class GeometryType>
746 bool buildGeomInFather(const GeometryType &fatherGeom , const GeometryType & myGeom);
747
750 void print (std::ostream& ss) const;
751
753 void invalidate () ;
754
756 bool valid () const ;
757
758 protected:
760 void assign( const ALU3dGridGeometry& other );
762 void removeObj();
764 void getObject();
765
766 // type of object provider
767 typedef ALUMemoryProvider< GeometryImplType > GeometryProviderType ;
768
770 static GeometryProviderType& geoProvider()
771 {
772#ifdef USE_SMP_PARALLEL
773 typedef ALUGridObjectFactory< GridImp > GridObjectFactoryType;
774 static std::vector< GeometryProviderType > storage( GridObjectFactoryType :: maxThreads() );
775 return storage[ GridObjectFactoryType :: threadNumber () ];
776#else
777 static GeometryProviderType storage;
778 return storage;
779#endif
780 }
781
782 // return reference to geometry implementation
783 GeometryImplType& geoImpl() const
784 {
785 assert( geoImpl_ );
786 return *geoImpl_;
787 }
788
789 // implementation of the coordinates and mapping
790 GeometryImplType* geoImpl_;
791 };
792
793} // end namespace Dune
794
795#include "geometry_imp.cc"
796
797#endif
vector space out of a tensor product of fields.
Definition: fvector.hh:94
general type of geometry implementation
Definition: geometry.hh:183
Different resources needed by all grid implementations.
GeometryType
Type representing VTK's entity geometry types.
Definition: common.hh:178
#define DUNE_THROW(E, m)
Definition: exceptions.hh:243
Dune namespace.
Definition: alignment.hh:10
Various implementations of the power function for run-time and static arguments.
Creative Commons License   |  Legal Statements / Impressum  |  Hosted by TU Dresden  |  generated with Hugo v0.111.3 (Dec 22, 23:30, 2024)