139 using GridView =
typename IV::Traits::GridView;
140 static constexpr int dim = GridView::dimension;
141 static constexpr int dimWorld = GridView::dimensionworld;
142 static constexpr bool isSurfaceGrid = dim < dimWorld;
145 auto& g = handle.g();
146 auto& deltaG = handle.deltaG();
147 auto& outsideG = handle.gOutside();
157 using Scalar =
typename IV::Traits::MatVecTraits::TMatrix::value_type;
158 using LocalIndexType =
typename IV::Traits::IndexSet::LocalIndexType;
160 for (LocalIndexType faceIdx = 0; faceIdx < iv.numFaces(); ++faceIdx)
163 const auto& curLocalScvf = iv.localScvf(faceIdx);
164 const auto& curGlobalScvf =
fvGeometry().scvf(curLocalScvf.gridScvfIndex());
165 const auto& gravity =
problem().spatialParams().gravity(curGlobalScvf.ipGlobal());
168 const auto& neighborScvIndices = curLocalScvf.neighboringLocalScvIndices();
169 const auto& posGlobalScv =
fvGeometry().scv(iv.localScv(neighborScvIndices[0]).gridScvIndex());
170 const auto& posVolVars =
elemVolVars()[posGlobalScv];
171 const auto alpha_inside = posVolVars.extrusionFactor()*
vtmv(curGlobalScvf.unitOuterNormal(),
172 posVolVars.permeability(),
175 const auto numOutsideFaces = !curGlobalScvf.boundary() ? curGlobalScvf.numOutsideScvs() : 0;
176 using OutsideAlphaStorage = std::conditional_t< isSurfaceGrid,
178 Dune::ReservedVector<Scalar, 1> >;
179 OutsideAlphaStorage alpha_outside; alpha_outside.resize(numOutsideFaces);
180 std::fill(alpha_outside.begin(), alpha_outside.end(), 0.0);
186 if (!curLocalScvf.isDirichlet())
188 const auto localDofIdx = curLocalScvf.localDofIndex();
190 rho = getRho(posVolVars);
191 deltaG[localDofIdx] = 0.0;
193 if (!curGlobalScvf.boundary())
195 for (
unsigned int idxInOutside = 0; idxInOutside < curGlobalScvf.numOutsideScvs(); ++idxInOutside)
198 const auto negLocalScvIdx = neighborScvIndices[idxInOutside+1];
199 const auto& negGlobalScv =
fvGeometry().scv(iv.localScv(negLocalScvIdx).gridScvIndex());
200 const auto& negVolVars =
elemVolVars()[negGlobalScv];
201 const auto& flipScvf = !isSurfaceGrid ? curGlobalScvf
202 :
fvGeometry().flipScvf(curGlobalScvf.index(), idxInOutside);
204 alpha_outside[idxInOutside] = negVolVars.extrusionFactor()*
vtmv(flipScvf.unitOuterNormal(),
205 negVolVars.permeability(),
208 alpha_outside[idxInOutside] *= -1.0;
210 rho += getRho(negVolVars);
211 deltaG[localDofIdx] += alpha_outside[idxInOutside];
215 rho /= numOutsideFaces + 1;
216 deltaG[localDofIdx] -= alpha_inside;
217 deltaG[localDofIdx] *= rho*Extrusion::area(curGlobalScvf);
221 rho = getRho(
elemVolVars()[curGlobalScvf.outsideScvIdx()]);
224 g[faceIdx] = alpha_inside*rho*Extrusion::area(curGlobalScvf);
229 for (
const auto& alpha : alpha_outside)
230 outsideG[faceIdx][i++] = alpha*rho*Extrusion::area(curGlobalScvf);
235 handle.CA().umv(deltaG, g);
238 using FaceVector =
typename IV::Traits::MatVecTraits::FaceVector;
241 handle.A().mv(deltaG, AG);
244 for (
const auto& localFaceData : iv.localFaceData())
247 if (!localFaceData.isOutsideFace())
250 const auto localScvIdx = localFaceData.ivLocalInsideScvIndex();
251 const auto localScvfIdx = localFaceData.ivLocalScvfIndex();
252 const auto idxInOutside = localFaceData.scvfLocalOutsideScvfIndex();
253 const auto& posLocalScv = iv.localScv(localScvIdx);
254 const auto& wijk = handle.omegas()[localScvfIdx][idxInOutside+1];
257 for (LocalIndexType localDir = 0; localDir < dim; localDir++)
260 const auto& curLocalScvf = iv.localScvf(posLocalScv.localScvfIndex(localDir));
261 if (!curLocalScvf.isDirichlet())
262 outsideG[localScvfIdx][idxInOutside] -= wijk[localDir]*AG[curLocalScvf.localDofIndex()];