Initial commit for version 2.0.x patch release
[OpenFOAM-2.0.x.git] / src / lagrangian / intermediate / submodels / Kinematic / ParticleForces / Gravity / GravityForce.H
blob192aef8aa59b532e80311ab53394700b6a4a954b
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright (C) 2011-2011 OpenCFD Ltd.
6      \\/     M anipulation  |
7 -------------------------------------------------------------------------------
8 License
9     This file is part of OpenFOAM.
11     OpenFOAM is free software: you can redistribute it and/or modify it
12     under the terms of the GNU General Public License as published by
13     the Free Software Foundation, either version 3 of the License, or
14     (at your option) any later version.
16     OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
17     ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
18     FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
19     for more details.
21     You should have received a copy of the GNU General Public License
22     along with OpenFOAM.  If not, see <http://www.gnu.org/licenses/>.
24 Class
25     Foam::GravityForce
27 Description
28     Calculates particle gravity force
30 SourceFiles
31     GravityForceI.H
32     GravityForce.C
34 \*---------------------------------------------------------------------------*/
36 #ifndef GravityForce_H
37 #define GravityForce_H
39 #include "ParticleForce.H"
41 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
43 namespace Foam
46 class fvMesh;
48 /*---------------------------------------------------------------------------*\
49                        Class GravityForce Declaration
50 \*---------------------------------------------------------------------------*/
52 template<class CloudType>
53 class GravityForce
55     public ParticleForce<CloudType>
57     // Private data
59         //- Reference to the acceleration due to gravity
60         const vector& g_;
63 public:
65     //- Runtime type information
66     TypeName("gravity");
69     // Constructors
71         //- Construct from mesh
72         GravityForce
73         (
74             CloudType& owner,
75             const fvMesh& mesh,
76             const dictionary& dict
77         );
79         //- Construct copy
80         GravityForce(const GravityForce& gf);
82         //- Construct and return a clone
83         virtual autoPtr<ParticleForce<CloudType> > clone() const
84         {
85             return autoPtr<ParticleForce<CloudType> >
86             (
87                 new GravityForce<CloudType>(*this)
88             );
89         }
92     //- Destructor
93     virtual ~GravityForce();
96     // Member Functions
98         // Access
100             //- Return the acceleration due to gravity
101             inline const vector& g() const;
104         // Evaluation
106             //- Calculate the non-coupled force
107             virtual forceSuSp calcNonCoupled
108             (
109                 const typename CloudType::parcelType& p,
110                 const scalar dt,
111                 const scalar mass,
112                 const scalar Re,
113                 const scalar muc
114             ) const;
118 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
120 } // End namespace Foam
122 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
124 #include "GravityForceI.H"
126 #ifdef NoRepository
127     #include "GravityForce.C"
128 #endif
130 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
132 #endif
134 // ************************************************************************* //