67 void update(
const ElementContext& elemCtx,
unsigned scvfIdx,
unsigned timeIdx)
71 const auto& extQuants = elemCtx.extensiveQuantities(scvfIdx, timeIdx);
72 const auto& stencil = elemCtx.stencil(timeIdx);
73 const auto& scvf = stencil.interiorFace(scvfIdx);
74 const unsigned insideScvIdx = scvf.interiorIndex();
75 const unsigned outsideScvIdx = scvf.exteriorIndex();
77 const unsigned globalI = elemCtx.globalSpaceIndex(insideScvIdx, timeIdx);
78 const unsigned globalJ = elemCtx.globalSpaceIndex(outsideScvIdx, timeIdx);
79 const auto& fractureMapper = elemCtx.problem().fractureMapper();
80 if (!fractureMapper.isFractureEdge(globalI, globalJ)) {
86 elemCtx.problem().fractureFaceIntrinsicPermeability(fractureIntrinsicPermeability_,
87 elemCtx, scvfIdx, timeIdx);
89 auto distDirection = elemCtx.pos(outsideScvIdx, timeIdx);
90 distDirection -= elemCtx.pos(insideScvIdx, timeIdx);
91 distDirection /= distDirection.two_norm();
93 const auto& problem = elemCtx.problem();
94 fractureWidth_ = problem.fractureWidth(elemCtx, insideScvIdx,
95 outsideScvIdx, timeIdx);
96 assert(fractureWidth_ < scvf.area());
98 for (
unsigned phaseIdx = 0; phaseIdx < numPhases; ++phaseIdx) {
99 const auto& pGrad = extQuants.potentialGrad(phaseIdx);
101 const unsigned upstreamIdx =
static_cast<unsigned>(extQuants.upstreamIndex(phaseIdx));
102 const auto& up = elemCtx.intensiveQuantities(upstreamIdx, timeIdx);
105 fractureIntrinsicPermeability_.mv(pGrad,
106 fractureFilterVelocity_[phaseIdx]);
107 fractureFilterVelocity_[phaseIdx] *= -up.fractureMobility(phaseIdx);
112 fractureVolumeFlux_[phaseIdx] = 0;
113 for (
unsigned dimIdx = 0; dimIdx < dimWorld; ++dimIdx) {
114 fractureVolumeFlux_[phaseIdx] +=
115 (fractureFilterVelocity_[phaseIdx][dimIdx] * distDirection[dimIdx])
116 * (fractureWidth_ / 2.0) / scvf.area();