82 const Element &element,
83 const FVElementGeometry& fvGeometry,
84 const ElementVolumeVariables& elemVolVars,
85 const ElementFaceVariables& elemFaceVars,
86 const SubControlVolumeFace &scvf,
87 const FluxVariablesCache& fluxVarsCache)
89 CellCenterPrimaryVariables flux = ParentType::computeMassFlux(problem, element, fvGeometry,
90 elemVolVars, elemFaceVars, scvf, fluxVarsCache);
93 auto upwindTermK = [](
const auto& volVars)
95 return volVars.viscosityTilde();
98 flux[viscosityTildeEqIdx]
99 = ParentType::advectiveFluxForCellCenter(problem, elemVolVars, elemFaceVars, scvf, upwindTermK);
102 const auto& insideScv = fvGeometry.scv(scvf.insideScvIdx());
103 const auto& outsideScv = fvGeometry.scv(scvf.outsideScvIdx());
104 const auto& insideVolVars = elemVolVars[scvf.insideScvIdx()];
105 const auto& outsideVolVars = elemVolVars[scvf.outsideScvIdx()];
108 Scalar insideCoeff = (insideVolVars.kinematicViscosity() + insideVolVars.viscosityTilde())
109 / insideVolVars.sigma();
110 Scalar outsideCoeff = (outsideVolVars.kinematicViscosity() + outsideVolVars.viscosityTilde())
111 / outsideVolVars.sigma();
114 insideCoeff *= insideVolVars.extrusionFactor();
115 outsideCoeff *= outsideVolVars.extrusionFactor();
119 (outsideScv.dofPosition() - scvf.ipGlobal()).two_norm(),
120 (insideScv.dofPosition() - scvf.ipGlobal()).two_norm());
121 Scalar distance = 0.0;
126 distance = (insideScv.dofPosition() - scvf.ipGlobal()).two_norm();
131 distance = (outsideScv.dofPosition() - insideScv.dofPosition()).two_norm();
134 const auto bcTypes = problem.boundaryTypes(element, scvf);
135 if (!(scvf.boundary() && (bcTypes.isOutflow(Indices::viscosityTildeEqIdx)
136 || bcTypes.isSymmetry())))
138 flux[viscosityTildeEqIdx]
140 * (insideVolVars.viscosityTilde() - outsideVolVars.viscosityTilde())