diff --git a/dumux/discretization/facecentered/staggered/fvgridgeometry.hh b/dumux/discretization/facecentered/staggered/fvgridgeometry.hh index fabdbdd1eabc0cb0ba9dbaea727849e419ad93f1..c53cd6e1bad9de339b46b21f81cd461a707fd457 100644 --- a/dumux/discretization/facecentered/staggered/fvgridgeometry.hh +++ b/dumux/discretization/facecentered/staggered/fvgridgeometry.hh @@ -298,9 +298,8 @@ private: scvfsIndexSet.push_back(scvfIdx); - const auto& lateralFacet = geometryHelper.facet(lateralFacetIndex, element); const auto commonEntityIdx = geometryHelper.globalCommonEntityIndex( - geometryHelper.facet(localScvIdx, element), lateralFacet + element, localScvIdx, lateralFacetIndex ); commonEntityIdxToScvfsMap[commonEntityIdx].push_back(scvfIdx); ++scvfIdx; @@ -739,9 +738,8 @@ private: scvfsIndexSet.push_back(scvfIdx); - const auto& lateralFacet = geometryHelper.facet(lateralFacetIndex, element); const auto commonEntityIdx = geometryHelper.globalCommonEntityIndex( - geometryHelper.facet(localScvIdx, element), lateralFacet + element, localScvIdx, lateralFacetIndex ); commonEntityIdxToScvfsMap[commonEntityIdx].push_back(scvfIdx); diff --git a/dumux/discretization/facecentered/staggered/geometryhelper.hh b/dumux/discretization/facecentered/staggered/geometryhelper.hh index 1cd282850eff8d88ee8a9b5a3cd9369f260a563b..fbbeee83683b5e2ecf1212d2eefc2fa72092d6a1 100644 --- a/dumux/discretization/facecentered/staggered/geometryhelper.hh +++ b/dumux/discretization/facecentered/staggered/geometryhelper.hh @@ -123,18 +123,25 @@ public: } //! Map two facets to a global common entity index (vertex in 2D or edge in 3D) - auto globalCommonEntityIndex(const Facet& facet0, const Facet& facet1) const + auto globalCommonEntityIndex(const Element& element, SmallLocalIndexType localFacetIdx0, SmallLocalIndexType localFacetIdx1) const { - assert(facet0.subEntities(2) == facet1.subEntities(2)); + const auto refElement = referenceElement(element); + + assert(refElement.size(localFacetIdx0, 1, 2) == refElement.size(localFacetIdx1, 1, 2)); std::array<GridIndexType, dim == 2 ? 2 : 4> cache = {}; std::bitset<dim == 2 ? 2 : 4> valueCached = {}; - for (int i = 0; i < facet0.subEntities(2); ++i) + for (int i = 0; i < refElement.size(localFacetIdx0, 1, 2); ++i) { - const auto globalEntityIdx0 = gridView().indexSet().subIndex(facet0, i, 2); - for (int j = 0; j < facet1.subEntities(2); ++j) + // get local sub index of subentity w.r.t. to the element + const auto localEntityIdx0 = refElement.subEntity(localFacetIdx0, 1, i, 2); + // and with the local index we can get the global index of the vertex/edge (2d/3d) + const auto globalEntityIdx0 = gridView().indexSet().subIndex(element, localEntityIdx0, 2); + for (int j = 0; j < refElement.size(localFacetIdx1, 1, 2); ++j) { - const auto globalEntityIdx1 = valueCached[j] ? cache[j] : gridView().indexSet().subIndex(facet1, j, 2); + const auto globalEntityIdx1 = valueCached[j] ? cache[j] + : gridView().indexSet().subIndex(element, refElement.subEntity(localFacetIdx1, 1, j, 2), 2); + if (globalEntityIdx0 == globalEntityIdx1) return globalEntityIdx0; else