Transferred copyright to the OpenFOAM Foundation
[OpenFOAM-2.0.x.git] / applications / solvers / combustion / PDRFoam / bEqn.H
blob348e4b8991ab7c6a1ec2908094fcfbf5ee474816
1 tmp<fv::convectionScheme<scalar> > mvConvection
3     fv::convectionScheme<scalar>::New
4     (
5         mesh,
6         fields,
7         phi,
8         mesh.divScheme("div(phi,ft_b_h_hu)")
9     )
12 volScalarField Db("Db", turbulence->muEff());
14 if (ign.ignited())
16     // Calculate the unstrained laminar flame speed
17     // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
18     Su = unstrainedLaminarFlameSpeed()();
20     const volScalarField& Xi = flameWrinkling->Xi();
22     // progress variable
23     // ~~~~~~~~~~~~~~~~~
24     volScalarField c("c", 1.0 - b);
26     // Unburnt gas density
27     // ~~~~~~~~~~~~~~~~~~~
28     volScalarField rhou(thermo.rhou());
30     // Calculate flame normal etc.
31     // ~~~~~~~~~~~~~~~~~~~~~~~~~~~
33     //volVectorField n(fvc::grad(b));
34     volVectorField n(fvc::reconstruct(fvc::snGrad(b)*mesh.magSf()));
36     volScalarField mgb("mgb", mag(n));
38     dimensionedScalar dMgb("dMgb", mgb.dimensions(), SMALL);
40     {
41         volScalarField bc(b*c);
43         dMgb += 1.0e-3*
44             (bc*mgb)().weightedAverage(mesh.V())
45            /(bc.weightedAverage(mesh.V()) + SMALL);
46     }
48     mgb += dMgb;
50     surfaceVectorField Sfhat(mesh.Sf()/mesh.magSf());
51     surfaceVectorField nfVec(fvc::interpolate(n));
52     nfVec += Sfhat*(fvc::snGrad(b) - (Sfhat & nfVec));
53     nfVec /= (mag(nfVec) + dMgb);
54     surfaceScalarField nf("nf", mesh.Sf() & nfVec);
55     n /= mgb;
57 #   include "StCorr.H"
59     // Calculate turbulent flame speed flux
60     // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
61     surfaceScalarField phiSt("phiSt", fvc::interpolate(rhou*StCorr*St)*nf);
63 #   include "StCourantNo.H"
65     Db = flameWrinkling->Db();
67     // Create b equation
68     // ~~~~~~~~~~~~~~~~~
69     fvScalarMatrix bEqn
70     (
71         betav*fvm::ddt(rho, b)
72       + mvConvection->fvmDiv(phi, b)
73       + fvm::div(phiSt, b)
74       - fvm::Sp(fvc::div(phiSt), b)
75       - fvm::laplacian(Db, b)
76     );
79     // Add ignition cell contribution to b-equation
80     // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
81 #   include "ignite.H"
83     // Solve for b
84     // ~~~~~~~~~~~
85     bEqn.solve();
87     Info<< "min(b) = " << min(b).value() << endl;
89     if (composition.contains("ft"))
90     {
91         volScalarField& ft = composition.Y("ft");
93         Info<< "Combustion progress = "
94             << 100*(1.0 - b)().weightedAverage(mesh.V()*ft).value() << "%"
95             << endl;
96     }
97     else
98     {
99         Info<< "Combustion progress = "
100             << 100*(1.0 - b)().weightedAverage(mesh.V()).value() << "%"
101             << endl;
102     }
104     // Correct the flame-wrinkling
105     flameWrinkling->correct(mvConvection);
107     St = Xi*Su;