ENH: twoPhaseEulerFoam: cached some fields in the kinetic theory model for lookup elsewhere

This commit is contained in:
william
2014-03-20 11:56:27 +00:00
committed by Andrew Heather
parent 920946e594
commit 9183fe2060
2 changed files with 50 additions and 17 deletions

View File

@ -132,6 +132,34 @@ Foam::RASModels::kineticTheoryModel::kineticTheoryModel
), ),
U.mesh(), U.mesh(),
dimensionedScalar("zero", dimensionSet(0, 2, -1, 0, 0), 0.0) dimensionedScalar("zero", dimensionSet(0, 2, -1, 0, 0), 0.0)
),
gs0_
(
IOobject
(
IOobject::groupName("gs0", phase.name()),
U.time().timeName(),
U.mesh(),
IOobject::NO_READ,
IOobject::NO_WRITE
),
U.mesh(),
dimensionedScalar("zero", dimensionSet(0, 0, 0, 0, 0), 0.0)
),
kappa_
(
IOobject
(
IOobject::groupName("kappa", phase.name()),
U.time().timeName(),
U.mesh(),
IOobject::NO_READ,
IOobject::NO_WRITE
),
U.mesh(),
dimensionedScalar("zero", dimensionSet(0, 2, -1, 0, 0), 0.0)
) )
{ {
if (type == typeName) if (type == typeName)
@ -371,17 +399,17 @@ void Foam::RASModels::kineticTheoryModel::correct()
volSymmTensorField D(symm(gradU)); volSymmTensorField D(symm(gradU));
// Calculating the radial distribution function // Calculating the radial distribution function
volScalarField gs0(radialModel_->g0(alpha, alphaMinFriction_, alphaMax_)); gs0_ = radialModel_->g0(alpha, alphaMinFriction_, alphaMax_);
if (!equilibrium_) if (!equilibrium_)
{ {
// particle viscosity (Table 3.2, p.47) // particle viscosity (Table 3.2, p.47)
nut_ = viscosityModel_->nu(alpha, Theta_, gs0, rho, da, e_); nut_ = viscosityModel_->nu(alpha, Theta_, gs0_, rho, da, e_);
volScalarField ThetaSqrt(sqrt(Theta_)); volScalarField ThetaSqrt(sqrt(Theta_));
// Bulk viscosity p. 45 (Lun et al. 1984). // Bulk viscosity p. 45 (Lun et al. 1984).
lambda_ = (4.0/3.0)*sqr(alpha)*da*gs0*(1.0 + e_)*ThetaSqrt/sqrtPi; lambda_ = (4.0/3.0)*sqr(alpha)*da*gs0_*(1.0 + e_)*ThetaSqrt/sqrtPi;
// Stress tensor, Definitions, Table 3.1, p. 43 // Stress tensor, Definitions, Table 3.1, p. 43
volSymmTensorField tau(2.0*nut_*D + (lambda_ - (2.0/3.0)*nut_)*tr(D)*I); volSymmTensorField tau(2.0*nut_*D + (lambda_ - (2.0/3.0)*nut_)*tr(D)*I);
@ -391,7 +419,7 @@ void Foam::RASModels::kineticTheoryModel::correct()
( (
12.0*(1.0 - sqr(e_)) 12.0*(1.0 - sqr(e_))
*max(sqr(alpha), residualAlpha_) *max(sqr(alpha), residualAlpha_)
*gs0*(1.0/da)*ThetaSqrt/sqrtPi *gs0_*(1.0/da)*ThetaSqrt/sqrtPi
); );
// NB, drag = K*alpha*alpha2, // NB, drag = K*alpha*alpha2,
@ -426,17 +454,14 @@ void Foam::RASModels::kineticTheoryModel::correct()
granularPressureModel_->granularPressureCoeff granularPressureModel_->granularPressureCoeff
( (
alpha, alpha,
gs0, gs0_,
rho, rho,
e_ e_
)/rho )/rho
); );
// 'thermal' conductivity (Table 3.3, p. 49) // 'thermal' conductivity (Table 3.3, p. 49)
volScalarField kappa kappa_ = conductivityModel_->kappa(alpha, Theta_, gs0_, rho, da, e_);
(
conductivityModel_->kappa(alpha, Theta_, gs0, rho, da, e_)
);
// Construct the granular temperature equation (Eq. 3.20, p. 44) // Construct the granular temperature equation (Eq. 3.20, p. 44)
// NB. note that there are two typos in Eq. 3.20: // NB. note that there are two typos in Eq. 3.20:
@ -450,7 +475,7 @@ void Foam::RASModels::kineticTheoryModel::correct()
+ fvm::div(alphaPhi, Theta_) + fvm::div(alphaPhi, Theta_)
- fvc::Sp(fvc::ddt(alpha) + fvc::div(alphaPhi), Theta_) - fvc::Sp(fvc::ddt(alpha) + fvc::div(alphaPhi), Theta_)
) )
- fvm::laplacian(kappa, Theta_, "laplacian(kappa, Theta)") - fvm::laplacian(kappa_, Theta_, "laplacian(kappa, Theta)")
== ==
fvm::SuSp(-((PsCoeff*I) && gradU), Theta_) fvm::SuSp(-((PsCoeff*I) && gradU), Theta_)
+ (tau && gradU) + (tau && gradU)
@ -466,23 +491,23 @@ void Foam::RASModels::kineticTheoryModel::correct()
{ {
// Equilibrium => dissipation == production // Equilibrium => dissipation == production
// Eq. 4.14, p.82 // Eq. 4.14, p.82
volScalarField K1(2.0*(1.0 + e_)*rho*gs0); volScalarField K1(2.0*(1.0 + e_)*rho*gs0_);
volScalarField K3 volScalarField K3
( (
0.5*da*rho* 0.5*da*rho*
( (
(sqrtPi/(3.0*(3.0-e_))) (sqrtPi/(3.0*(3.0-e_)))
*(1.0 + 0.4*(1.0 + e_)*(3.0*e_ - 1.0)*alpha*gs0) *(1.0 + 0.4*(1.0 + e_)*(3.0*e_ - 1.0)*alpha*gs0_)
+1.6*alpha*gs0*(1.0 + e_)/sqrtPi +1.6*alpha*gs0_*(1.0 + e_)/sqrtPi
) )
); );
volScalarField K2 volScalarField K2
( (
4.0*da*rho*(1.0 + e_)*alpha*gs0/(3.0*sqrtPi) - 2.0*K3/3.0 4.0*da*rho*(1.0 + e_)*alpha*gs0_/(3.0*sqrtPi) - 2.0*K3/3.0
); );
volScalarField K4(12.0*(1.0 - sqr(e_))*rho*gs0/(da*sqrtPi)); volScalarField K4(12.0*(1.0 - sqr(e_))*rho*gs0_/(da*sqrtPi));
volScalarField trD volScalarField trD
( (
@ -508,6 +533,8 @@ void Foam::RASModels::kineticTheoryModel::correct()
(l1 + sqrt(l2 + l3)) (l1 + sqrt(l2 + l3))
/(2.0*max(alpha, residualAlpha_)*K4) /(2.0*max(alpha, residualAlpha_)*K4)
); );
kappa_ = conductivityModel_->kappa(alpha, Theta_, gs0_, rho, da, e_);
} }
Theta_.max(0); Theta_.max(0);
@ -515,12 +542,12 @@ void Foam::RASModels::kineticTheoryModel::correct()
{ {
// particle viscosity (Table 3.2, p.47) // particle viscosity (Table 3.2, p.47)
nut_ = viscosityModel_->nu(alpha, Theta_, gs0, rho, da, e_); nut_ = viscosityModel_->nu(alpha, Theta_, gs0_, rho, da, e_);
volScalarField ThetaSqrt(sqrt(Theta_)); volScalarField ThetaSqrt(sqrt(Theta_));
// Bulk viscosity p. 45 (Lun et al. 1984). // Bulk viscosity p. 45 (Lun et al. 1984).
lambda_ = (4.0/3.0)*sqr(alpha)*da*gs0*(1.0 + e_)*ThetaSqrt/sqrtPi; lambda_ = (4.0/3.0)*sqr(alpha)*da*gs0_*(1.0 + e_)*ThetaSqrt/sqrtPi;
// Frictional pressure // Frictional pressure
volScalarField pf volScalarField pf

View File

@ -128,6 +128,12 @@ class kineticTheoryModel
//- The granular bulk viscosity //- The granular bulk viscosity
volScalarField lambda_; volScalarField lambda_;
//- The granular radial distribution
volScalarField gs0_;
//- The granular "thermal" conductivity
volScalarField kappa_;
// Private Member Functions // Private Member Functions