Merge branch 'master' of ssh://git.code.sf.net/p/foam-extend/foam-extend-3.2
[foam-extend-3.2.git] / src / randomProcesses / fft / kShellIntegration.C
blobc993f0bb13c197847e5534a664a7fc3ff94c1b4e
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | foam-extend: Open Source CFD
4    \\    /   O peration     | Version:     3.2
5     \\  /    A nd           | Web:         http://www.foam-extend.org
6      \\/     M anipulation  | For copyright notice see file Copyright
7 -------------------------------------------------------------------------------
8 License
9     This file is part of foam-extend.
11     foam-extend is free software: you can redistribute it and/or modify it
12     under the terms of the GNU General Public License as published by the
13     Free Software Foundation, either version 3 of the License, or (at your
14     option) any later version.
16     foam-extend is distributed in the hope that it will be useful, but
17     WITHOUT ANY WARRANTY; without even the implied warranty of
18     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
19     General Public License for more details.
21     You should have received a copy of the GNU General Public License
22     along with foam-extend.  If not, see <http://www.gnu.org/licenses/>.
24 \*---------------------------------------------------------------------------*/
26 #include "kShellIntegration.H"
27 #include "mathematicalConstants.H"
29 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
31 Foam::graph Foam::kShellIntegration
33     const complexVectorField& Ek,
34     const Kmesh& K
37     // evaluate the radial component of the spectra as an average
38     // over the shells of thickness dk
40     graph kShellMeanEk = kShellMean(Ek, K);
41     const scalarField& x = kShellMeanEk.x();
42     scalarField& y = *kShellMeanEk.begin()();
44     // now multiply by 4pi k^2 (the volume of each shell) to get the
45     // spectra E(k). int E(k) dk is now the total energy in a box
46     // of side 2pi
48     y *= sqr(x)*4.0*mathematicalConstant::pi;
50     // now scale this to get the energy in a box of side l0
52     scalar l0(K.sizeOfBox()[0]*(scalar(K.nn()[0])/(scalar(K.nn()[0])-1.0)));
53     scalar factor = pow((l0/(2.0*mathematicalConstant::pi)),3.0);
55     y *= factor;
57     // and divide by the number of points in the box, to give the
58     // energy density.
60     y /= scalar(K.size());
62     return kShellMeanEk;
66 // kShellMean : average over the points in a k-shell to evaluate the
67 // radial part of the energy spectrum.
69 Foam::graph Foam::kShellMean
71     const complexVectorField& Ek,
72     const Kmesh& K
75     const label tnp = Ek.size();
76     const label NoSubintervals = label
77     (
78         pow(scalar(tnp), 1.0/vector::dim)*pow(1.0/vector::dim, 0.5) - 0.5
79     );
81     scalarField k1D(NoSubintervals);
82     scalarField Ek1D(NoSubintervals);
83     scalarField EWeight(NoSubintervals);
85     scalar kmax = K.max()*pow(1.0/vector::dim,0.5);
86     scalar delta_k = kmax/(NoSubintervals);
88     forAll(Ek1D, a)
89     {
90         k1D[a] = (a + 1)*delta_k;
91         Ek1D[a] = 0.0;
92         EWeight[a] = 0;
93     }
95     forAll(K, l)
96     {
97         scalar kmag = mag(K[l]);
99         for (label a=0; a<NoSubintervals; a++)
100         {
101             if
102             (
103                 kmag <= ((a + 1)*delta_k + delta_k/2.0)
104              && kmag > ((a + 1)*delta_k - delta_k/2.0)
105             )
106             {
107                 scalar dist = delta_k/2.0 - mag((a + 1)*delta_k - kmag);
109                 Ek1D[a] += dist*
110                 magSqr
111                 (
112                     vector
113                     (
114                         mag(Ek[l].x()),
115                         mag(Ek[l].y()),
116                         mag(Ek[l].z())
117                     )
118                  );
120                 EWeight[a] += dist;
121             }
122         }
123     }
125     for (label a=0; a<NoSubintervals; a++)
126     {
127         if (EWeight[a] > 0)
128         {
129             Ek1D[a] /= EWeight[a];
130         }
131     }
133     return graph("E(k)", "k", "E(k)", k1D, Ek1D);
137 // ************************************************************************* //