6 IOobject::groupName(
"rAU",
phase1.name()),
11 *
rho1/runTime.deltaT()
16 IOobject::groupName(
"rAU",
phase2.name()),
21 *
rho2/runTime.deltaT()
44 tmp<surfaceScalarField>
DbyA1 53 tmp<surfaceScalarField>
DbyA2 75 if (implicitPhasePressure)
100 IOobject::groupName(
"HbyA",
phase1.name()),
108 *
rho1*
U1.oldTime()/runTime.deltaT()
113 IOobject::groupName(
"HbyA",
phase2.name()),
121 *
rho2*
U2.oldTime()/runTime.deltaT()
155 surfaceScalarField::Boundary& phiCorrCoeff1Bf =
156 phiCorrCoeff1.boundaryFieldRef();
158 surfaceScalarField::Boundary& phiCorrCoeff2Bf =
159 phiCorrCoeff2.boundaryFieldRef();
167 || isA<cyclicAMIFvPatch>(
mesh.boundary()[
patchi])
170 phiCorrCoeff1Bf[
patchi] = 0;
171 phiCorrCoeff2Bf[
patchi] = 0;
179 IOobject::groupName(
"phiHbyA",
phase1.name()),
184 - fvc::flux(
U1.oldTime())
193 IOobject::groupName(
"phiHbyA",
phase2.name()),
198 - fvc::flux(
U2.oldTime())
216 MRF.makeRelative(phiHbyA);
228 p_rgh.boundaryFieldRef(),
230 phiHbyA.boundaryField()
235 )/(
mesh.magSf().boundaryField()*rAUf.boundaryField())
238 tmp<fvScalarMatrix> pEqnComp1;
239 tmp<fvScalarMatrix> pEqnComp2;
244 if (
phase1.compressible())
248 IOobject::groupName(
"phid",
phase1.name()),
267 pEqnComp1.ref().relax();
270 if (
phase2.compressible())
274 IOobject::groupName(
"phid",
phase2.name()),
292 pEqnComp2.ref().relax();
297 if (
phase1.compressible())
307 if (
phase2.compressible())
318 if (
fluid.transfersMass())
320 if (pEqnComp1.valid())
329 if (pEqnComp2.valid())
343 while (
pimple.correctNonOrthogonal())
355 if (pEqnComp1.valid())
360 if (pEqnComp2.valid())
368 mesh.solver(p_rgh.select(
pimple.finalInnerIter()))
373 if (
pimple.finalNonOrthogonalIter())
375 phi = phiHbyA + pEqnIncomp.flux();
388 phiHbyA2 + alpharAUf2*mSfGradp
393 ((phi1s + rAUKd1*phi2s) - (phi2s + rAUKd2*phi1s))
402 if (
phase1.compressible())
404 phase1.divU(-pEqnComp1 & p_rgh);
406 if (
phase2.compressible())
408 phase2.divU(-pEqnComp2 & p_rgh);
414 mSfGradp = pEqnIncomp.flux()/
rAUf;
437 U1.correctBoundaryConditions();
441 U2.correctBoundaryConditions();
460 p_rgh.correctBoundaryConditions();
volScalarField rAU1(IOobject::groupName("rAU", phase1.name()), 1.0/(U1Eqn.A()+max(phase1.residualAlpha()-alpha1, scalar(0))*rho1/runTime.deltaT()))
tmp< fvMatrix< Type > > correction(const fvMatrix< Type > &)
Return the correction form of the given matrix.
fvMatrix< scalar > fvScalarMatrix
tmp< surfaceScalarField > phiF2
volVectorField F(fluid.F())
surfaceScalarField alphaf1("alphaf1", fvc::interpolate(alpha1))
surfaceScalarField & phi2
dimensioned< Type > max(const dimensioned< Type > &, const dimensioned< Type > &)
tmp< GeometricField< Type, fvPatchField, volMesh > > div(const GeometricField< Type, fvsPatchField, surfaceMesh > &ssf)
surfaceScalarField & alphaPhi2
const dictionary & pimple
tmp< GeometricField< Type, fvPatchField, volMesh > > Sp(const volScalarField &sp, const GeometricField< Type, fvPatchField, volMesh > &vf)
surfaceScalarField & phi1
tmp< surfaceScalarField > interpolate(const RhoType &rho)
GeometricField< vector, fvPatchField, volMesh > volVectorField
tmp< GeometricField< Type, fvPatchField, volMesh > > laplacian(const GeometricField< Type, fvPatchField, volMesh > &vf, const word &name)
surfaceScalarField phir(phic *interface.nHatf())
const surfaceScalarField & ghf
tmp< GeometricField< Type, fvPatchField, volMesh > > ddt(const dimensioned< Type > dt, const fvMesh &mesh)
surfaceScalarField snGradAlpha1(fvc::snGrad(alpha1)*mesh.magSf())
GeometricField< scalar, fvPatchField, volMesh > volScalarField
dimensionedScalar pos(const dimensionedScalar &ds)
tmp< surfaceScalarField > DbyA1(fvc::interpolate(rAU1 *(D+phase1.turbulence().pPrime())))
volScalarField Kd(fluid.Kd())
surfaceScalarField ghSnGradRho(ghf *fvc::snGrad(rho)*mesh.magSf())
surfaceScalarField alpharAUf1(fvc::interpolate(max(alpha1, phase1.residualAlpha())*rAU1))
surfaceScalarField alpharAUf2(fvc::interpolate(max(alpha2, phase2.residualAlpha())*rAU2))
const dimensionedVector & g
setSnGrad< fixedFluxPressureFvPatchScalarField >(p_rgh.boundaryFieldRef(),(phiHbyA.boundaryField()-MRF.relative(phib))/(mesh.magSf().boundaryField()*rAUf.boundaryField()))
dimensionedScalar pMin("pMin", dimPressure, fluid)
surfaceScalarField rAUf("rAUf", fvc::interpolate(rAU))
tmp< GeometricField< typename outerProduct< vector, Type >::type, fvPatchField, volMesh >> reconstruct(const GeometricField< Type, fvsPatchField, surfaceMesh > &ssf)
volScalarField rAU2(IOobject::groupName("rAU", phase2.name()), 1.0/(U2Eqn.A()+max(phase2.residualAlpha()-alpha2, scalar(0))*rho2/runTime.deltaT()))
tmp< surfaceScalarField > phiF1
const volScalarField & gh
volScalarField p_rgh_0(p_rgh)
tmp< surfaceScalarField > DbyA2(fvc::interpolate(rAU2 *(D+phase2.turbulence().pPrime())))
tmp< GeometricField< Type, fvPatchField, volMesh > > average(const GeometricField< Type, fvsPatchField, surfaceMesh > &ssf)
Area-weighted average a surfaceField creating a volField.
dimensioned< scalar > mag(const dimensioned< Type > &)
surfaceScalarField alphaf2("alphaf2", scalar(1)-alphaf1)
tmp< surfaceScalarField > flux(const volVectorField &vvf)
Return the face-flux field obtained from the given volVectorField.
GeometricField< scalar, fvsPatchField, surfaceMesh > surfaceScalarField
tmp< GeometricField< Type, fvPatchField, volMesh > > Su(const GeometricField< Type, fvPatchField, volMesh > &su, const GeometricField< Type, fvPatchField, volMesh > &vf)
void deleteDemandDrivenData(DataPtr &dataPtr)
surfaceScalarField & alphaPhi1
tmp< GeometricField< Type, fvsPatchField, surfaceMesh > > snGrad(const GeometricField< Type, fvPatchField, volMesh > &vf, const word &name)