14#ifndef DUMUX_DISCRETIZATION_BOX_FV_ELEMENT_GEOMETRY_HH
15#define DUMUX_DISCRETIZATION_BOX_FV_ELEMENT_GEOMETRY_HH
20#include <unordered_map>
24#include <dune/geometry/type.hh>
25#include <dune/localfunctions/lagrange/pqkfactory.hh>
26#include <dune/common/reservedvector.hh>
45template<
class GG,
bool enableGr
idGeometryCache>
52 using GridView =
typename GG::GridView;
53 static constexpr int dim = GridView::dimension;
54 static constexpr int dimWorld = GridView::dimensionworld;
57 using CoordScalar =
typename GridView::ctype;
58 using FeLocalBasis =
typename GG::FeCache::FiniteElementType::Traits::LocalBasisType;
59 using GGCache =
typename GG::Cache;
60 using GeometryHelper =
typename GGCache::GeometryHelper;
63 typename GridView::template Codim<0>::Entity::Geometry::LocalCoordinate,
64 typename GridView::template Codim<0>::Entity::Geometry::GlobalCoordinate
69 using Element =
typename GridView::template Codim<0>::Entity;
83 static constexpr std::size_t maxNumElementScvs = (1<<dim);
90 : ggCache_(&ggCache) {}
95 return ggCache_->scvs(eIdx_)[scvIdx];
101 return ggCache_->scvfs(eIdx_)[scvfIdx];
109 friend inline Dune::IteratorRange<typename std::vector<SubControlVolume>::const_iterator>
112 using Iter =
typename std::vector<SubControlVolume>::const_iterator;
113 const auto& s = fvGeometry.ggCache_->scvs(fvGeometry.eIdx_);
114 return Dune::IteratorRange<Iter>(s.begin(), s.end());
122 friend inline Dune::IteratorRange<typename std::vector<SubControlVolumeFace>::const_iterator>
125 using Iter =
typename std::vector<SubControlVolumeFace>::const_iterator;
126 const auto& s = fvGeometry.ggCache_->scvfs(fvGeometry.eIdx_);
127 return Dune::IteratorRange<Iter>(s.begin(), s.end());
132 friend inline std::ranges::view
auto
135 const auto& v = fvGeometry.ggCache_->boundaryFaces(fvGeometry.eIdx_);
136 return std::ranges::views::all(v);
142 return Dune::transformedRangeView(
143 Dune::range(Dune::referenceElement<CoordScalar, dim>(fvGeometry.element().type()).size(boundaryFace.intersectionIndex(), 1, dim)),
146 auto localDofIdx = Dune::referenceElement<CoordScalar, dim>(fvGeometry.element().type()).subEntity(boundaryFace.intersectionIndex(), 1, i, dim);
147 return CVFE::LocalDof
149 static_cast<LocalIndexType>(localDofIdx),
150 fvGeometry.gridGeometry().dofMapper().subIndex(fvGeometry.element(), localDofIdx, dim),
151 static_cast<GridIndexType>(fvGeometry.elementIndex())
160 return gridGeometry().feCache().get(element_->type()).localBasis();
172 return ggCache_->scvs(eIdx_).size();
178 return ggCache_->scvfs(eIdx_).size();
188 this->bindElement(element);
189 return std::move(*
this);
196 { this->bindElement(element); }
205 this->bindElement(element);
206 return std::move(*
this);
215 elementGeometry_.emplace(element.geometry());
217 eIdx_ = gridGeometry().elementMapper().index(element);
222 {
return static_cast<bool>(element_); }
226 {
return *element_; }
230 {
return *elementGeometry_; }
239 const auto localScvfIdx = scvf.index() - GeometryHelper::numInteriorScvf(element().type());
240 return ggCache_->scvfBoundaryGeometryKeys(eIdx_)[localScvfIdx][0];
245 {
return ggCache_->gridGeometry(); }
249 {
return ggCache_->hasBoundaryScvf(eIdx_); }
253 {
return hasBoundaryScvf(); }
257 {
return ggCache_->boundaryFaces(eIdx_)[bfIdx]; }
263 return { Dune::GeometryTypes::cube(dim), GeometryHelper(*elementGeometry_).getScvCorners(scv.indexInElement()) };
270 const GeometryHelper geometryHelper(*elementGeometry_);
273 const auto localBoundaryIndex = scvf.index() - geometryHelper.numInteriorScvf();
274 const auto& key = ggCache_->scvfBoundaryGeometryKeys(eIdx_)[localBoundaryIndex];
275 return { Dune::GeometryTypes::cube(dim-1), geometryHelper.getBoundaryScvfCorners(key[0], key[1]) };
278 return { Dune::GeometryTypes::cube(dim-1), geometryHelper.getScvfCorners(scvf.index()) };
285 const auto& elemGeo = elementGeometry();
286 const auto faceGeoInRef = referenceElement(elemGeo).template geometry<1>(boundaryFace.intersectionIndex());
287 typename BoundaryFace::Traits::CornerStorage corners;
288 for (
int i = 0; i < faceGeoInRef.corners(); ++i)
289 corners.push_back(elemGeo.global(faceGeoInRef.corner(i)));
290 return { faceGeoInRef.type(), corners };
296 const auto type = fvGeometry.element().type();
297 const auto& localKey = fvGeometry.gridGeometry().feCache().get(type).localCoefficients().localKey(scv.localDofIndex());
303 template<
class LocalDof>
306 const auto type = fvGeometry.element().type();
307 const auto& localKey = fvGeometry.gridGeometry().feCache().get(type).localCoefficients().localKey(localDof.index());
308 const auto& localPos = GeometryHelper::localDofPosition(type, localKey);
318 [&] (
const typename Element::Geometry::GlobalCoordinate& pos)
319 {
return fvGeometry.elementGeometry().local(pos); },
328 { scvf.
unitOuterNormal(), scvf.index(), fvGeometry.elementGeometry().local(scvf.ipGlobal()), scvf.ipGlobal() };
332 const GGCache* ggCache_;
335 std::optional<Element> element_;
336 std::optional<typename Element::Geometry> elementGeometry_;
343 using GridView =
typename GG::GridView;
344 static constexpr int dim = GridView::dimension;
345 static constexpr int dimWorld = GridView::dimensionworld;
348 using CoordScalar =
typename GridView::ctype;
349 using FeLocalBasis =
typename GG::FeCache::FiniteElementType::Traits::LocalBasisType;
350 using GGCache =
typename GG::Cache;
351 using GeometryHelper =
typename GGCache::GeometryHelper;
354 typename GridView::template Codim<0>::Entity::Geometry::LocalCoordinate,
355 typename GridView::template Codim<0>::Entity::Geometry::GlobalCoordinate
360 using Element =
typename GridView::template Codim<0>::Entity;
374 static constexpr std::size_t maxNumElementScvs = (1<<dim);
381 : ggCache_(&ggCache) {}
386 return scvs_[scvIdx];
392 return scvfs_[scvfIdx];
400 friend inline Dune::IteratorRange<typename std::vector<SubControlVolume>::const_iterator>
403 using Iter =
typename std::vector<SubControlVolume>::const_iterator;
404 return Dune::IteratorRange<Iter>(fvGeometry.scvs_.begin(), fvGeometry.scvs_.end());
412 friend inline Dune::IteratorRange<typename std::vector<SubControlVolumeFace>::const_iterator>
415 using Iter =
typename std::vector<SubControlVolumeFace>::const_iterator;
416 return Dune::IteratorRange<Iter>(fvGeometry.scvfs_.begin(), fvGeometry.scvfs_.end());
421 friend inline std::ranges::view
auto
423 {
return std::ranges::views::all(fvGeometry.boundaryFaces_); }
428 return Dune::transformedRangeView(
429 Dune::range(Dune::referenceElement<CoordScalar, dim>(fvGeometry.element().type()).size(boundaryFace.intersectionIndex(), 1, dim)),
432 auto localDofIdx = Dune::referenceElement<CoordScalar, dim>(fvGeometry.element().type()).subEntity(boundaryFace.intersectionIndex(), 1, i, dim);
433 return CVFE::LocalDof
435 static_cast<LocalIndexType>(localDofIdx),
436 fvGeometry.gridGeometry().dofMapper().subIndex(fvGeometry.element(), localDofIdx, dim),
437 static_cast<GridIndexType>(fvGeometry.elementIndex())
447 return gridGeometry().feCache().get(element_->type()).localBasis();
465 return scvfs_.size();
475 this->bindElement(element);
476 return std::move(*
this);
483 { this->bindElement(element); }
492 this->bindElement(element);
493 return std::move(*
this);
502 eIdx_ = gridGeometry().elementMapper().index(element);
503 elementGeometry_.emplace(element.geometry());
504 makeElementGeometries_();
509 {
return static_cast<bool>(element_); }
513 {
return *element_; }
517 {
return *elementGeometry_; }
526 const auto localScvfIdx = scvf.index() - GeometryHelper::numInteriorScvf(element().type());
527 return scvfBoundaryGeometryKeys_[localScvfIdx][0];
532 {
return ggCache_->gridGeometry(); }
536 {
return hasBoundaryScvf_; }
540 {
return hasBoundaryScvf(); }
544 {
return boundaryFaces_[bfIdx]; }
550 return { Dune::GeometryTypes::cube(dim), GeometryHelper(*elementGeometry_).getScvCorners(scv.indexInElement()) };
557 const GeometryHelper geometryHelper(*elementGeometry_);
560 const auto localBoundaryIndex = scvf.index() - geometryHelper.numInteriorScvf();
561 const auto& key = scvfBoundaryGeometryKeys_[localBoundaryIndex];
562 return { Dune::GeometryTypes::cube(dim-1), geometryHelper.getBoundaryScvfCorners(key[0], key[1]) };
565 return { Dune::GeometryTypes::cube(dim-1), geometryHelper.getScvfCorners(scvf.index()) };
572 const auto& elemGeo = elementGeometry();
573 const auto faceGeoInRef = referenceElement(elemGeo).template geometry<1>(boundaryFace.intersectionIndex());
574 typename BoundaryFace::Traits::CornerStorage corners;
575 for (
int i = 0; i < faceGeoInRef.corners(); ++i)
576 corners.push_back(elemGeo.global(faceGeoInRef.corner(i)));
577 return { faceGeoInRef.type(), corners };
583 const auto type = fvGeometry.element().type();
584 const auto& localKey = fvGeometry.gridGeometry().feCache().get(type).localCoefficients().localKey(scv.localDofIndex());
590 template<
class LocalDof>
593 const auto type = fvGeometry.element().type();
594 const auto& localKey = fvGeometry.gridGeometry().feCache().get(type).localCoefficients().localKey(localDof.index());
595 const auto& localPos = GeometryHelper::localDofPosition(type, localKey);
605 [&] (
const typename Element::Geometry::GlobalCoordinate& pos) {
return fvGeometry.elementGeometry().local(pos); },
614 { scvf.
unitOuterNormal(), scvf.index(), fvGeometry.elementGeometry().local(scvf.ipGlobal()), scvf.ipGlobal() };
618 void makeElementGeometries_()
620 hasBoundaryScvf_ =
false;
621 boundaryFaces_.clear();
624 const auto& element = *element_;
625 const auto& elementGeometry = *elementGeometry_;
626 const auto refElement = referenceElement(elementGeometry);
629 GeometryHelper geometryHelper(elementGeometry);
632 scvs_.resize(elementGeometry.corners());
633 for (LocalIndexType scvLocalIdx = 0; scvLocalIdx < elementGeometry.corners(); ++scvLocalIdx)
636 const auto dofIdxGlobal = gridGeometry().vertexMapper().subIndex(element, scvLocalIdx, dim);
639 scvs_[scvLocalIdx] = SubControlVolume(
640 geometryHelper.getScvCorners(scvLocalIdx),
648 const auto numInnerScvf = geometryHelper.numInteriorScvf();
649 scvfs_.resize(numInnerScvf);
650 scvfBoundaryGeometryKeys_.clear();
652 LocalIndexType scvfLocalIdx = 0;
653 for (; scvfLocalIdx < numInnerScvf; ++scvfLocalIdx)
656 std::array<LocalIndexType, 2> localScvIndices{{
657 static_cast<LocalIndexType
>(refElement.subEntity(scvfLocalIdx, dim-1, 0, dim)),
658 static_cast<LocalIndexType
>(refElement.subEntity(scvfLocalIdx, dim-1, 1, dim))
661 const auto& corners = geometryHelper.getScvfCorners(scvfLocalIdx);
662 scvfs_[scvfLocalIdx] = SubControlVolumeFace(
664 geometryHelper.normal(corners, localScvIndices),
667 std::move(localScvIndices)
672 LocalIndexType numBoundaryFaces = 0;
673 for (
const auto& intersection : intersections(gridGeometry().gridView(), element))
675 if (intersection.boundary() && !intersection.neighbor())
677 const auto isGeometry = intersection.geometry();
678 hasBoundaryScvf_ =
true;
681 boundaryFaces_.push_back(BoundaryFace{
684 intersection.centerUnitOuterNormal(),
686 static_cast<LocalIndexType
>(intersection.indexInInside()),
687 typename BoundaryFace::Traits::BoundaryFlag{intersection}
690 for (
unsigned int isScvfLocalIdx = 0; isScvfLocalIdx < isGeometry.corners(); ++isScvfLocalIdx)
693 const LocalIndexType insideScvIdx =
static_cast<LocalIndexType
>(refElement.subEntity(intersection.indexInInside(), 1, isScvfLocalIdx, dim));
694 std::array<LocalIndexType, 2> localScvIndices{{insideScvIdx, insideScvIdx}};
697 geometryHelper.getBoundaryScvfCorners(intersection.indexInInside(), isScvfLocalIdx),
698 intersection.centerUnitOuterNormal(),
702 std::move(localScvIndices)
705 scvfBoundaryGeometryKeys_.emplace_back(std::array<LocalIndexType, 2>{{
706 static_cast<LocalIndexType
>(intersection.indexInInside()),
707 static_cast<LocalIndexType
>(isScvfLocalIdx)
719 std::optional<Element> element_;
720 std::optional<typename Element::Geometry> elementGeometry_;
723 const GGCache* ggCache_;
726 std::vector<SubControlVolume> scvs_;
727 std::vector<SubControlVolumeFace> scvfs_;
728 std::vector<std::array<LocalIndexType, 2>> scvfBoundaryGeometryKeys_;
729 Dune::ReservedVector<BoundaryFace, 2*dim> boundaryFaces_;
731 bool hasBoundaryScvf_ =
false;
Helper class constructing the dual grid finite volume geometries for the box discretizazion method.
bool isBound() const
Returns true if bind/bindElement has already been called.
Definition: discretization/box/fvelementgeometry.hh:508
std::size_t numScvf() const
The total number of sub control volume faces.
Definition: discretization/box/fvelementgeometry.hh:463
GG GridGeometry
export type of finite volume grid geometry
Definition: discretization/box/fvelementgeometry.hh:366
SubControlVolumeFace::Traits::Geometry geometry(const SubControlVolumeFace &scvf) const
Geometry of a sub control volume face.
Definition: discretization/box/fvelementgeometry.hh:554
bool hasBoundaryScvf() const
Returns whether one of the geometry's scvfs lies on a boundary.
Definition: discretization/box/fvelementgeometry.hh:535
friend Dune::IteratorRange< typename std::vector< SubControlVolume >::const_iterator > scvs(const BoxFVElementGeometry &fvGeometry)
Definition: discretization/box/fvelementgeometry.hh:401
std::size_t numScv() const
The total number of sub control volumes.
Definition: discretization/box/fvelementgeometry.hh:457
GridIndexType elementIndex() const
The bound element's index in the grid view.
Definition: discretization/box/fvelementgeometry.hh:520
void bindElement(const Element &element) &
Definition: discretization/box/fvelementgeometry.hh:499
std::size_t intersectionIndex(const SubControlVolumeFace &scvf) const
The intersection index the scvf belongs to.
Definition: discretization/box/fvelementgeometry.hh:524
const SubControlVolumeFace & scvf(LocalIndexType scvfIdx) const
Get a sub control volume face with a local scvf index.
Definition: discretization/box/fvelementgeometry.hh:390
BoxFVElementGeometry(const GGCache &ggCache)
Constructor.
Definition: discretization/box/fvelementgeometry.hh:380
typename GG::ScvfQuadratureRule ScvfQuadratureRule
the quadrature rule type for scvfs
Definition: discretization/box/fvelementgeometry.hh:372
SubControlVolume::Traits::Geometry geometry(const SubControlVolume &scv) const
Geometry of a sub control volume.
Definition: discretization/box/fvelementgeometry.hh:547
const GridGeometry & gridGeometry() const
The grid geometry we are a restriction of.
Definition: discretization/box/fvelementgeometry.hh:531
typename GridView::template Codim< 0 >::Entity Element
export the element type
Definition: discretization/box/fvelementgeometry.hh:360
friend Dune::IteratorRange< typename std::vector< SubControlVolumeFace >::const_iterator > scvfs(const BoxFVElementGeometry &fvGeometry)
Definition: discretization/box/fvelementgeometry.hh:413
friend auto ipData(const BoxFVElementGeometry &fvGeometry, const SubControlVolume &scv)
Interpolation point data for an scv.
Definition: discretization/box/fvelementgeometry.hh:581
BoundaryFace::Traits::Geometry geometry(const BoundaryFace &boundaryFace) const
Geometry of a boundary face.
Definition: discretization/box/fvelementgeometry.hh:569
const FeLocalBasis & feLocalBasis() const
Get a local finite element basis.
Definition: discretization/box/fvelementgeometry.hh:445
const Element & element() const
The bound element.
Definition: discretization/box/fvelementgeometry.hh:512
const SubControlVolume & scv(LocalIndexType scvIdx) const
Get a sub control volume with a local scv index.
Definition: discretization/box/fvelementgeometry.hh:384
friend auto ipData(const BoxFVElementGeometry &fvGeometry, const typename Element::Geometry::GlobalCoordinate &globalPos)
Interpolation point data for a global position.
Definition: discretization/box/fvelementgeometry.hh:601
BoxFVElementGeometry bind(const Element &element) &&
bind the local view (r-value overload) This overload is called when an instance of this class is a te...
Definition: discretization/box/fvelementgeometry.hh:473
friend auto ipData(const BoxFVElementGeometry &fvGeometry, const SubControlVolumeFace &scvf)
Interpolation point data for scvf.
Definition: discretization/box/fvelementgeometry.hh:611
friend auto localDofs(const BoxFVElementGeometry &fvGeometry, const BoundaryFace &boundaryFace)
an iterator over all local dofs related to a boundary face
Definition: discretization/box/fvelementgeometry.hh:426
friend auto ipData(const BoxFVElementGeometry &fvGeometry, const LocalDof &localDof)
Interpolation point data for a localDof.
Definition: discretization/box/fvelementgeometry.hh:591
typename GG::ScvQuadratureRule ScvQuadratureRule
the quadrature rule type for scvs
Definition: discretization/box/fvelementgeometry.hh:370
std::size_t numLocalDofs() const
The total number of element-local dofs.
Definition: discretization/box/fvelementgeometry.hh:451
typename GG::BoundaryFace BoundaryFace
export the boundary face type
Definition: discretization/box/fvelementgeometry.hh:368
friend std::ranges::view auto boundaryFaces(const BoxFVElementGeometry &fvGeometry)
Definition: discretization/box/fvelementgeometry.hh:422
typename GG::SubControlVolumeFace SubControlVolumeFace
export type of subcontrol volume face
Definition: discretization/box/fvelementgeometry.hh:364
const BoundaryFace & boundaryFace(LocalIndexType bfIdx) const
Get a boundary face with a local boundary face index.
Definition: discretization/box/fvelementgeometry.hh:543
BoxFVElementGeometry bindElement(const Element &element) &&
bind the local view (r-value overload) This overload is called when an instance of this class is a te...
Definition: discretization/box/fvelementgeometry.hh:490
const Element::Geometry & elementGeometry() const
The bound element geometry.
Definition: discretization/box/fvelementgeometry.hh:516
bool hasBoundaryFaces() const
Returns whether the element has boundary faces.
Definition: discretization/box/fvelementgeometry.hh:539
typename GG::SubControlVolume SubControlVolume
export type of subcontrol volume
Definition: discretization/box/fvelementgeometry.hh:362
void bind(const Element &element) &
Definition: discretization/box/fvelementgeometry.hh:482
bool isBound() const
Returns true if bind/bindElement has already been called.
Definition: discretization/box/fvelementgeometry.hh:221
const FeLocalBasis & feLocalBasis() const
Get a local finite element basis.
Definition: discretization/box/fvelementgeometry.hh:158
BoundaryFace::Traits::Geometry geometry(const BoundaryFace &boundaryFace) const
Geometry of a boundary face.
Definition: discretization/box/fvelementgeometry.hh:282
BoxFVElementGeometry bindElement(const Element &element) &&
bind the local view (r-value overload) This overload is called when an instance of this class is a te...
Definition: discretization/box/fvelementgeometry.hh:203
const Element & element() const
The bound element.
Definition: discretization/box/fvelementgeometry.hh:225
SubControlVolume::Traits::Geometry geometry(const SubControlVolume &scv) const
Geometry of a sub control volume.
Definition: discretization/box/fvelementgeometry.hh:260
friend Dune::IteratorRange< typename std::vector< SubControlVolume >::const_iterator > scvs(const BoxFVElementGeometry &fvGeometry)
Definition: discretization/box/fvelementgeometry.hh:110
bool hasBoundaryFaces() const
Returns whether the element has boundary faces.
Definition: discretization/box/fvelementgeometry.hh:252
std::size_t numScv() const
The total number of sub control volumes.
Definition: discretization/box/fvelementgeometry.hh:170
typename GG::BoundaryFace BoundaryFace
export the boundary face type
Definition: discretization/box/fvelementgeometry.hh:77
const SubControlVolume & scv(LocalIndexType scvIdx) const
Get a sub control volume with a local scv index.
Definition: discretization/box/fvelementgeometry.hh:93
std::size_t numLocalDofs() const
The total number of element-local dofs.
Definition: discretization/box/fvelementgeometry.hh:164
std::size_t numScvf() const
The total number of sub control volume faces.
Definition: discretization/box/fvelementgeometry.hh:176
typename GG::SubControlVolume SubControlVolume
export type of subcontrol volume
Definition: discretization/box/fvelementgeometry.hh:71
const GridGeometry & gridGeometry() const
The grid geometry we are a restriction of.
Definition: discretization/box/fvelementgeometry.hh:244
bool hasBoundaryScvf() const
Returns whether one of the geometry's scvfs lies on a boundary.
Definition: discretization/box/fvelementgeometry.hh:248
friend Dune::IteratorRange< typename std::vector< SubControlVolumeFace >::const_iterator > scvfs(const BoxFVElementGeometry &fvGeometry)
Definition: discretization/box/fvelementgeometry.hh:123
friend auto ipData(const BoxFVElementGeometry &fvGeometry, const SubControlVolume &scv)
Interpolation point data for an scv.
Definition: discretization/box/fvelementgeometry.hh:294
typename GG::ScvQuadratureRule ScvQuadratureRule
export the scv interpolation point data type
Definition: discretization/box/fvelementgeometry.hh:79
const Element::Geometry & elementGeometry() const
The bound element geometry.
Definition: discretization/box/fvelementgeometry.hh:229
void bind(const Element &element) &
Definition: discretization/box/fvelementgeometry.hh:195
typename GG::ScvfQuadratureRule ScvfQuadratureRule
the quadrature rule type for scvfs
Definition: discretization/box/fvelementgeometry.hh:81
std::size_t intersectionIndex(const SubControlVolumeFace &scvf) const
The intersection index the scvf belongs to.
Definition: discretization/box/fvelementgeometry.hh:237
SubControlVolumeFace::Traits::Geometry geometry(const SubControlVolumeFace &scvf) const
Geometry of a sub control volume face.
Definition: discretization/box/fvelementgeometry.hh:267
friend auto ipData(const BoxFVElementGeometry &fvGeometry, const typename Element::Geometry::GlobalCoordinate &globalPos)
Interpolation point data for a global position.
Definition: discretization/box/fvelementgeometry.hh:314
GridIndexType elementIndex() const
The bound element's index in the grid view.
Definition: discretization/box/fvelementgeometry.hh:233
friend auto ipData(const BoxFVElementGeometry &fvGeometry, const SubControlVolumeFace &scvf)
Interpolation point data for scvf.
Definition: discretization/box/fvelementgeometry.hh:325
friend auto localDofs(const BoxFVElementGeometry &fvGeometry, const BoundaryFace &boundaryFace)
an iterator over all local dofs related to a boundary face
Definition: discretization/box/fvelementgeometry.hh:140
friend auto ipData(const BoxFVElementGeometry &fvGeometry, const LocalDof &localDof)
Interpolation point data for a localDof.
Definition: discretization/box/fvelementgeometry.hh:304
friend std::ranges::view auto boundaryFaces(const BoxFVElementGeometry &fvGeometry)
Definition: discretization/box/fvelementgeometry.hh:133
const BoundaryFace & boundaryFace(LocalIndexType bfIdx) const
Get a boundary face with a local boundary face index.
Definition: discretization/box/fvelementgeometry.hh:256
typename GG::SubControlVolumeFace SubControlVolumeFace
export type of subcontrol volume face
Definition: discretization/box/fvelementgeometry.hh:73
void bindElement(const Element &element) &
Definition: discretization/box/fvelementgeometry.hh:212
const SubControlVolumeFace & scvf(LocalIndexType scvfIdx) const
Get a sub control volume face with a local scvf index.
Definition: discretization/box/fvelementgeometry.hh:99
BoxFVElementGeometry(const GGCache &ggCache)
Constructor.
Definition: discretization/box/fvelementgeometry.hh:89
BoxFVElementGeometry bind(const Element &element) &&
bind the local view (r-value overload) This overload is called when an instance of this class is a te...
Definition: discretization/box/fvelementgeometry.hh:186
typename GridView::template Codim< 0 >::Entity Element
export the element type
Definition: discretization/box/fvelementgeometry.hh:69
GG GridGeometry
export type of finite volume grid geometry
Definition: discretization/box/fvelementgeometry.hh:75
Base class for the finite volume geometry vector for box models This builds up the sub control volume...
Definition: discretization/box/fvelementgeometry.hh:46
An interpolation point related to a face of an element.
Definition: cvfe/interpolationpointdata.hh:109
const GlobalPosition & unitOuterNormal() const
The unit outer normal vector at the quadrature point.
Definition: cvfe/interpolationpointdata.hh:123
An interpolation point related to an element that includes global and local positions.
Definition: cvfe/interpolationpointdata.hh:31
An interpolation point related to a global position of an element, giving its local positions by a ma...
Definition: cvfe/interpolationpointdata.hh:82
An interpolation point related to a localDof of an element, giving its global and local positions.
Definition: cvfe/interpolationpointdata.hh:60
LocalIndex localDofIndex() const
The local index of the corresponding dof.
Definition: cvfe/interpolationpointdata.hh:69
Classes representing interpolation point data for control-volume finite element schemes.
Class representing dofs on elements for control-volume finite element schemes.
Quadrature rules over sub-control volumes and sub-control volume faces.
Class providing iterators over sub control volumes and sub control volume faces of an element.
typename GridView::IndexSet::IndexType GridIndex
Definition: indextraits.hh:27
unsigned int LocalIndex
Definition: indextraits.hh:28