Merge branch 'master' of ssh://git.code.sf.net/p/foam-extend/foam-extend-3.2
[foam-extend-3.2.git] / applications / solvers / multiphase / twoPhaseEulerFoam / turbulenceModel / wallFunctions.H
blobea7d1a9b14579d25d67cfa53a98168c24f2c00b8
2     labelList cellBoundaryFaceCount(epsilon.size(), 0);
4     scalar Cmu25 = ::pow(Cmu, 0.25);
5     scalar Cmu75 = ::pow(Cmu, 0.75);
7     const fvPatchList& patches = mesh.boundary();
9     //- Initialise the near-wall P field to zero
10     forAll(patches, patchi)
11     {
12         const fvPatch& currPatch = patches[patchi];
14         if (isType<wallFvPatch>(currPatch))
15         {
16             forAll(currPatch, facei)
17             {
18                 label faceCelli = currPatch.faceCells()[facei];
20                 epsilon[faceCelli] = 0.0;
21                 G[faceCelli] = 0.0;
22             }
23         }
24     }
26     //- Accumulate the wall face contributions to epsilon and G
27     //  Increment cellBoundaryFaceCount for each face for averaging
28     forAll(patches, patchi)
29     {
30         const fvPatch& currPatch = patches[patchi];
32         if (isType<wallFvPatch>(currPatch))
33         {
34             const scalarField& nuw = nutb.boundaryField()[patchi];
36             scalarField magFaceGradU = mag(U.boundaryField()[patchi].snGrad());
38             forAll(currPatch, facei)
39             {
40                 label faceCelli = currPatch.faceCells()[facei];
42                 scalar yPlus =
43                     Cmu25*y[patchi][facei]
44                     *::sqrt(k[faceCelli])
45                     /nub.value();
47                 // For corner cells (with two boundary or more faces),
48                 // epsilon and G in the near-wall cell are calculated
49                 // as an average
51                 cellBoundaryFaceCount[faceCelli]++;
53                 epsilon[faceCelli] +=
54                      Cmu75*::pow(k[faceCelli], 1.5)
55                     /(kappa*y[patchi][facei]);
57                 if (yPlus > 11.6)
58                 {
59                     G[faceCelli] +=
60                         nuw[facei]*magFaceGradU[facei]
61                         *Cmu25*::sqrt(k[faceCelli])
62                         /(kappa*y[patchi][facei]);
63                 }
64             }
65         }
66     }
69     // perform the averaging
71     forAll(patches, patchi)
72     {
73         const fvPatch& curPatch = patches[patchi];
75         if (isType<wallFvPatch>(curPatch))
76         {
77             forAll(curPatch, facei)
78             {
79                 label faceCelli = curPatch.faceCells()[facei];
81                 epsilon[faceCelli] /= cellBoundaryFaceCount[faceCelli];
82                 G[faceCelli] /= cellBoundaryFaceCount[faceCelli];
83             }
84         }
85     }