Merge branch 'master' of ssh://git.code.sf.net/p/foam-extend/foam-extend-3.2
[foam-extend-3.2.git] / src / lagrangian / intermediate / particleForces / particleForces.H
blob8aadcc69940978e22919c37276cf15b63d040592
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 Class
25     Foam::particleForces
27 Description
28     Provides a mechanism to calculate particle forces
29     Note: forces are force per unit mass (accelerations)
31 SourceFiles
32     particleForces.C
34 \*---------------------------------------------------------------------------*/
36 #ifndef particleForces_H
37 #define particleForces_H
39 #include "dictionary.H"
40 #include "Switch.H"
41 #include "vector.H"
42 #include "volFieldsFwd.H"
44 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
46 namespace Foam
49 // Forward class declarations
50 class fvMesh;
52 /*---------------------------------------------------------------------------*\
53                       Class particleForces Declaration
54 \*---------------------------------------------------------------------------*/
56 class particleForces
58     // Private data
60         //- Reference to the mesh database
61         const fvMesh& mesh_;
63         //- The particleForces dictionary
64         const dictionary& dict_;
66         //- Gravity
67         const vector g_;
69         //- Velocity gradient field
70         const volTensorField* gradUPtr_;
73         // Forces to include in particle motion evaluation
75             //- Gravity
76             Switch gravity_;
78             //- Virtual mass
79             Switch virtualMass_;
81             //- Virtual mass force coefficient
82             scalar Cvm_;
84             //- Pressure gradient
85             Switch pressureGradient_;
88         // Additional info
90             //- Name of velucity field - default = "U"
91             const word UName_;
94 public:
96     // Constructors
98         //- Construct from mesh, dictionary and gravity
99         particleForces
100         (
101             const fvMesh& mesh,
102             const dictionary& dict,
103             const vector& g
104         );
106         //- Construct copy
107         particleForces(const particleForces& f);
110     //- Destructor
111     ~particleForces();
114     // Member Functions
116         // Access
118             //- Return the particleForces dictionary
119             const dictionary& dict() const;
121             //- Return the gravity vector
122             const vector& g() const;
124             //- Return gravity force activate switch
125             Switch gravity() const;
127             //- Return virtual mass force activate switch
128             Switch virtualMass() const;
130             //- Return virtual mass force coefficient
131             Switch Cvm() const;
133             //- Return pressure gradient force activate switch
134             Switch pressureGradient() const;
136             //- Return name of velocity field
137             const word& UName() const;
140        // Evaluation
142             //- Cache carrier fields
143             void cacheFields(const bool store);
145             //- Calculate action/reaction forces between carrier and particles
146             vector calcCoupled
147             (
148                 const label cellI,
149                 const scalar dt,
150                 const scalar rhoc,
151                 const scalar rho,
152                 const vector& Uc,
153                 const vector& U
154             ) const;
156             //- Calculate external forces applied to the particles
157             vector calcNonCoupled
158             (
159                 const label cellI,
160                 const scalar dt,
161                 const scalar rhoc,
162                 const scalar rho,
163                 const vector& Uc,
164                 const vector& U
165             ) const;
169 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
171 } // End namespace Foam
173 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
175 #endif
177 // ************************************************************************* //