MPPICInterFoam 中如何通过alphac得到alpha1和alpha2?
-
大家好,本人最近在研究MPPICInterFoam中的代码,在createFields中,有如下代码。对alphac进行定义之后,最后两行通过 alphac=1-theta 对alphac进行了更新,但是我好奇alpha1和alpha2是如何更新的呢?请大佬帮忙解答一下,谢谢。
volScalarField alphac ( IOobject ( "alphac", runTime.timeName(), mesh, IOobject::READ_IF_PRESENT, IOobject::AUTO_WRITE ), mesh, dimensionedScalar(dimless, Zero), zeroGradientFvPatchScalarField::typeName ); alphac.oldTime(); volScalarField alphacRho(alphac*rho); alphacRho.oldTime(); Info<< "Constructing kinematicCloud " << endl; basicKinematicMPPICCloud kinematicCloud ( "kinematicCloud", rho, U, mu, g ); // Particle fraction upper limit scalar alphacMin ( 1.0 - ( kinematicCloud.particleProperties().subDict("constantProperties") .get<scalar>("alphaMax") ) ); // Update alphac from the particle locations alphac = max(1.0 - kinematicCloud.theta(), alphacMin); alphac.correctBoundaryConditions();
-
@jasper-0 在 MPPICInterFoam 中如何通过alphac得到alpha1和alpha2? 中说:
MPPICInterFoam
你这个看起来不是openfoam.org 原生的solver吧?
如果是下面的这个solver的话,alpha1 和 alpha2 会自动更新https://github.com/TonkomoLLC/MPPICInterDyMFoam/blob/master/MPPICInterDyMFoam/createFields.H
volScalarField& alpha1(mixture.alpha1()); volScalarField& alpha2(mixture.alpha2());
-
@tens 在 MPPICInterFoam 中如何通过alphac得到alpha1和alpha2? 中说:
通过alphaEqn.H中的206-226行有如下代码,这几行代码应该是求解出来了乘以alphac之后的alpha1,那alpha2怎么是1-alpha1呢?不是应该alphac-alpha1吗?还望高手解答一下啊
else { alphaPhi10 = talphaPhi1Un; MULES::explicitSolve ( alphac, alpha1, phiCN, alphaPhi10, Sp, (Su + divU*min(alpha1(), scalar(1)))(), oneField(), zeroField() ); } alpha2 = 1.0 - alpha1; mixture.correct(); }
-
@jasper-0 在 MPPICInterFoam 中如何通过alphac得到alpha1和alpha2? 中说:
@tens 感谢大佬的解答!也就是说通过以下代码求得的alpha1是占连续相的体积分数?那最后结果跑出来后要想得到总的alpha1是不是要在paraview里面做计算alpha1*alphac?
MULES::explicitSolve ( alphac, alpha1, phiCN, alphaPhi10, Sp, (Su + divU*min(alpha1(), scalar(1)))(), oneField(), zeroField() ); }
我发现interFoam中alpha1(即alpha1)的求解对应下面这个公式,
而MPPICInterFoam中通过以上代码求得的alphan为
公式右边第二项 是用alpha占连续相的体积分数算出来的,
而 和 都是总的相分数, -
@jasper-0 这个公式是哪里看到的,字母对应的意义不理解,在程序中相体积分数应该是通过控制方程求的吧
fvScalarMatrix alpha1Eqn ( ( LTS ? fv::localEulerDdtScheme<scalar>(mesh).fvmDdt(alphac, alpha1) : fv::EulerDdtScheme<scalar>(mesh).fvmDdt(alpha1) ) + fv::gaussConvectionScheme<scalar> ( mesh, phiCN, upwind<scalar>(mesh, phiCN) ).fvmDiv(phiCN, alpha1) - fvm::Sp(fvc::ddt(alphac) + fvc::div(phiCN), alpha1) == Su + fvm::Sp(Sp + divU, alpha1) ); alpha1Eqn.solve();
-
@tens 这一步应该是用upwind格式求出来alpha1之后然后下面再通过MULES::correct进行修正。如果不进行修正的话,就是我之前提到的MULES::explicitSolve,在MULESTemplates.C里面定义了这个函数:
template<class RdeltaTType, class RhoType, class SpType, class SuType> void Foam::MULES::explicitSolve ( const RdeltaTType& rDeltaT, const RhoType& rho, volScalarField& psi, const surfaceScalarField& phiPsi, const SpType& Sp, const SuType& Su ) { Info<< "MULES: Solving for " << psi.name() << endl; const fvMesh& mesh = psi.mesh(); scalarField& psiIf = psi; const scalarField& psi0 = psi.oldTime(); psiIf = 0.0; fvc::surfaceIntegrate(psiIf, phiPsi); if (mesh.moving()) { psiIf = ( mesh.Vsc0()().field()*rho.oldTime().field() *psi0*rDeltaT/mesh.Vsc()().field() + Su.field() - psiIf )/(rho.field()*rDeltaT - Sp.field()); } else { psiIf = ( rho.oldTime().field()*psi0*rDeltaT + Su.field() - psiIf )/(rho.field()*rDeltaT - Sp.field()); } psi.correctBoundaryConditions(); } 其中
psiIf = ( rho.oldTime().field()*psi0*rDeltaT + Su.field() - psiIf )/(rho.field()*rDeltaT - Sp.field());
2/45