-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathYEqn.H
87 lines (70 loc) · 2.07 KB
/
YEqn.H
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
vk = Zero;
diffsh = Zero;
DiffError = Zero;
tmp<fv::convectionScheme<scalar>> mvConvection
(
fv::convectionScheme<scalar>::New
(
mesh,
fields,
phi,
mesh.divScheme("div(phi,Yi_h)")
)
);
forAll(Y, i)
{
const volScalarField& Yi = Y[i];
const volScalarField Diffi = rho*diff[i];
DiffError += Diffi*fvc::grad(Yi);
}
const surfaceScalarField phiUc = linearInterpolate(DiffError) & mesh.Sf();
{
reaction->correct();
volScalarField Yt(0.0*Y[0]);
forAll(Y, i)
{
volScalarField& Yi = Y[i];
const volScalarField Diffi = rho*diff[i];
forAll(T, icell)
{
Hsi[icell] = composition.Hs(i, p[icell], T[icell]);
}
volScalarField::Boundary& HsiBf = Hsi.boundaryFieldRef();
forAll(HsiBf, patchi)
{
scalarField& HsiPatch = HsiBf[patchi];
const scalarField& pp = p.boundaryField()[patchi];
const scalarField& Tp = T.boundaryField()[patchi];
forAll(HsiPatch, facei)
{
HsiPatch[facei] = composition.Hs(i, pp[facei], Tp[facei]);
}
}
vk += Hsi*(Diffi*fvc::grad(Yi) - Yi*DiffError);
diffsh += fvc::laplacian(thermo.alpha()*Hsi, Yi);
if (i != inertIndex && composition.active(i))
{
volScalarField DEff = Diffi + turbulence->mut()/Sct;
fvScalarMatrix YiEqn
(
fvm::ddt(rho, Yi)
+ mvConvection->fvmDiv(phi, Yi)
//- fvm::laplacian(turbulence->muEff(), Yi) // original reactingFoam solver
- fvm::laplacian(DEff, Yi)
+ mvConvection->fvmDiv(phiUc, Yi)
// soret effect not included yet
==
reaction->R(Yi)
+ fvOptions(rho, Yi)
);
YiEqn.relax();
fvOptions.constrain(YiEqn);
YiEqn.solve("Yi");
fvOptions.correct(Yi);
Yi.max(0.0);
Yt += Yi;
}
}
Y[inertIndex] = scalar(1) - Yt;
Y[inertIndex].max(0.0);
}