FreeFOAM The Cross-Platform CFD Toolkit
Hosted by SourceForge:
Get FreeFOAM at SourceForge.net.
            Fast, secure and Free Open Source software downloads

turbGen.C

Go to the documentation of this file.
00001 /*---------------------------------------------------------------------------*\
00002   =========                 |
00003   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
00004    \\    /   O peration     |
00005     \\  /    A nd           | Copyright (C) 1991-2010 OpenCFD Ltd.
00006      \\/     M anipulation  |
00007 -------------------------------------------------------------------------------
00008 License
00009     This file is part of OpenFOAM.
00010 
00011     OpenFOAM is free software: you can redistribute it and/or modify it
00012     under the terms of the GNU General Public License as published by
00013     the Free Software Foundation, either version 3 of the License, or
00014     (at your option) any later version.
00015 
00016     OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
00017     ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
00018     FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
00019     for more details.
00020 
00021     You should have received a copy of the GNU General Public License
00022     along with OpenFOAM.  If not, see <http://www.gnu.org/licenses/>.
00023 
00024 \*---------------------------------------------------------------------------*/
00025 
00026 #include <randomProcesses/fft.H>
00027 #include "turbGen.H"
00028 #include <randomProcesses/Kmesh.H>
00029 #include <OpenFOAM/primitiveFields.H>
00030 #include "Ek.H"
00031 #include <OpenFOAM/mathematicalConstants.H>
00032 
00033 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
00034 
00035 namespace Foam
00036 {
00037 
00038 // * * * * * * * * * * * * * * * * Constructors  * * * * * * * * * * * * * * //
00039 
00040 // from components
00041 turbGen::turbGen(const Kmesh& k, const scalar EA, const scalar K0)
00042 :
00043     K(k),
00044     Ea(EA),
00045     k0(K0),
00046     RanGen(label(0))
00047 {}
00048 
00049 
00050 // * * * * * * * * * * * * * * * Member Functions  * * * * * * * * * * * * * //
00051 
00052 // generate and return a velocity field
00053 vectorField turbGen::U()
00054 {
00055     scalar pi2=2*mathematicalConstant::pi;
00056 
00057     vectorField s(K.size());
00058     scalarField rndPhases(K.size());
00059 
00060     forAll(K, i)
00061     {
00062         s[i] = RanGen.vector01();
00063         rndPhases[i] = RanGen.scalar01();
00064     }
00065 
00066     s = K ^ s;
00067     s = s/(mag(s) + 1.0e-20);
00068 
00069     s = Ek(Ea, k0, mag(K))*s;
00070 
00071     complexVectorField up = fft::reverseTransform
00072     (
00073         ComplexField(cos(pi2*rndPhases)*s, sin(pi2*rndPhases)*s),
00074         K.nn()
00075     );
00076 
00077     return ReImSum(up);
00078 }
00079 
00080 
00081 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
00082 
00083 } // End namespace Foam
00084 
00085 // ************************ vim: set sw=4 sts=4 et: ************************ //
00086 
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines