ENH: autoLayerDriver: better layering information message
[OpenFOAM-2.0.x.git] / src / lagrangian / intermediate / submodels / Kinematic / ParticleForces / SRF / SRFForce.H
blob5c9927473ab3261b8a58353f9382cd01b686965e
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright (C) 2011 OpenFOAM Foundation
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::SRFForce
27 Description
28     Calculates particle SRF reference frame force
30 SourceFiles
31     SRFForce.C
33 \*---------------------------------------------------------------------------*/
35 #ifndef SRFForce_H
36 #define SRFForce_H
38 #include "ParticleForce.H"
39 #include "SRFModel.H"
41 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
43 namespace Foam
46 class fvMesh;
48 /*---------------------------------------------------------------------------*\
49                        Class SRFForce Declaration
50 \*---------------------------------------------------------------------------*/
52 template<class CloudType>
53 class SRFForce
55     public ParticleForce<CloudType>
57     // Private data
59         //- Pointer to the SRF model
60         const typename SRF::SRFModel* srfPtr_;
63 public:
65     //- Runtime type information
66     TypeName("SRF");
69     // Constructors
71         //- Construct from mesh
72         SRFForce
73         (
74             CloudType& owner,
75             const fvMesh& mesh,
76             const dictionary& dict
77         );
79         //- Construct copy
80         SRFForce(const SRFForce& srff);
82         //- Construct and return a clone
83         virtual autoPtr<ParticleForce<CloudType> > clone() const
84         {
85             return autoPtr<ParticleForce<CloudType> >
86             (
87                 new ParticleForce<CloudType>(*this)
88             );
89         }
92     //- Destructor
93     virtual ~SRFForce();
96     // Member Functions
98         // Evaluation
100             //- Cache fields
101             virtual void cacheFields(const bool store);
103             //- Calculate the non-coupled force
104             virtual forceSuSp calcNonCoupled
105             (
106                 const typename CloudType::parcelType& p,
107                 const scalar dt,
108                 const scalar mass,
109                 const scalar Re,
110                 const scalar muc
111             ) const;
115 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
117 } // End namespace Foam
119 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
121 #ifdef NoRepository
122     #include "SRFForce.C"
123 #endif
125 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
127 #endif
129 // ************************************************************************* //