WallModel.H
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------*\
2  ========= |
3  \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4  \\ / O peration | Website: https://openfoam.org
5  \\ / A nd | Copyright (C) 2011-2018 OpenFOAM Foundation
6  \\/ M anipulation |
7 -------------------------------------------------------------------------------
8 License
9  This file is part of OpenFOAM.
10 
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.
15 
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.
20 
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/>.
23 
24 Class
25  Foam::WallModel
26 
27 Description
28  Templated wall interaction class
29 
30 SourceFiles
31  WallModel.C
32  WallModelNew.C
33 
34 \*---------------------------------------------------------------------------*/
35 
36 #ifndef WallModel_H
37 #define WallModel_H
38 
39 #include "IOdictionary.H"
40 #include "autoPtr.H"
41 #include "runTimeSelectionTables.H"
42 #include "WallSiteData.H"
43 
44 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
45 
46 namespace Foam
47 {
48 
49 /*---------------------------------------------------------------------------*\
50  Class WallModel Declaration
51 \*---------------------------------------------------------------------------*/
52 
53 template<class CloudType>
54 class WallModel
55 {
56  // Private data
57 
58  //- The CollisionModel dictionary
59  const dictionary& dict_;
60 
61  //- Reference to the owner cloud class
62  CloudType& owner_;
63 
64  //- The coefficients dictionary
65  const dictionary coeffDict_;
66 
67 
68 public:
69 
70  //- Runtime type information
71  TypeName("wallModel");
72 
73  //- Declare runtime constructor selection table
75  (
76  autoPtr,
77  WallModel,
78  dictionary,
79  (
80  const dictionary& dict,
82  ),
83  (dict, owner)
84  );
85 
86 
87  // Constructors
88 
89  //- Construct from components
90  WallModel
91  (
92  const dictionary& dict,
93  CloudType& owner,
94  const word& type
95  );
96 
97 
98  //- Destructor
99  virtual ~WallModel();
100 
101 
102  //- Selector
103  static autoPtr<WallModel<CloudType>> New
104  (
105  const dictionary& dict,
106  CloudType& owner
107  );
108 
109 
110  // Access
111 
112  //- Return the owner cloud object
113  const CloudType& owner() const;
114 
115  //- Return non-const access to the owner cloud object
116  CloudType& owner();
117 
118  //- Return the dictionary
119  const dictionary& dict() const;
120 
121  //- Return the coefficients dictionary
122  const dictionary& coeffDict() const;
123 
124 
125  // Member Functions
126 
127  //- Return the effective radius for a particle for the model
128  virtual scalar pREff(const typename CloudType::parcelType& p) const = 0;
129 
130  //- Whether the WallModel has a timestep limit that will
131  // require subCycling
132  virtual bool controlsTimestep() const = 0;
133 
134  //- For WallModels that control the timestep, calculate the
135  // number of subCycles needed to satisfy the minimum
136  // allowable timestep
137  virtual label nSubCycles() const = 0;
138 
139  //- Calculate the wall interaction for a parcel
140  virtual void evaluateWall
141  (
142  typename CloudType::parcelType& p,
143  const List<point>& flatSitePoints,
144  const List<WallSiteData<vector>>& flatSiteData,
145  const List<point>& sharpSitePoints,
146  const List<WallSiteData<vector>>& sharpSiteData
147  ) const = 0;
148 };
149 
150 
151 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
152 
153 } // End namespace Foam
154 
155 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
157 #define makeWallModel(CloudType) \
158  \
159  defineNamedTemplateTypeNameAndDebug(Foam::WallModel<Foam::CloudType>, 0); \
160  \
161  namespace Foam \
162  { \
163  defineTemplateRunTimeSelectionTable \
164  ( \
165  WallModel<Foam::CloudType>, \
166  dictionary \
167  ); \
168  }
169 
171 #define makeWallModelType(SS, CloudType) \
172  \
173  defineNamedTemplateTypeNameAndDebug(Foam::SS<Foam::CloudType>, 0); \
174  \
175  Foam::WallModel<Foam::CloudType>:: \
176  adddictionaryConstructorToTable<Foam::SS<Foam::CloudType>> \
177  add##SS##CloudType##ConstructorToTable_;
178 
179 
180 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
181 
182 #ifdef NoRepository
183  #include "WallModel.C"
184 #endif
185 
186 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
187 
188 #endif
189 
190 // ************************************************************************* //
virtual label nSubCycles() const =0
For WallModels that control the timestep, calculate the.
intWM_LABEL_SIZE_t label
A label is an int32_t or int64_t as specified by the pre-processor macro WM_LABEL_SIZE.
Definition: label.H:59
DSMCCloud< dsmcParcel > CloudType
const dictionary & coeffDict() const
Return the coefficients dictionary.
Definition: WallModel.C:78
const CloudType & owner() const
Return the owner cloud object.
Definition: WallModel.C:55
virtual void evaluateWall(typename CloudType::parcelType &p, const List< point > &flatSitePoints, const List< WallSiteData< vector >> &flatSiteData, const List< point > &sharpSitePoints, const List< WallSiteData< vector >> &sharpSiteData) const =0
Calculate the wall interaction for a parcel.
WallModel(const dictionary &dict, CloudType &owner, const word &type)
Construct from components.
Definition: WallModel.C:32
declareRunTimeSelectionTable(autoPtr, WallModel, dictionary,(const dictionary &dict, CloudType &owner),(dict, owner))
Declare runtime constructor selection table.
ParcelType parcelType
Type of parcel the cloud was instantiated for.
Definition: DSMCCloud.H:218
fileName::Type type(const fileName &, const bool followLink=true)
Return the file type: DIRECTORY or FILE.
Definition: POSIX.C:481
const dictionary & dict() const
Return the dictionary.
Definition: WallModel.C:70
TypeName("wallModel")
Runtime type information.
virtual bool controlsTimestep() const =0
Whether the WallModel has a timestep limit that will.
static autoPtr< WallModel< CloudType > > New(const dictionary &dict, CloudType &owner)
Selector.
Definition: WallModelNew.C:33
virtual ~WallModel()
Destructor.
Definition: WallModel.C:47
virtual scalar pREff(const typename CloudType::parcelType &p) const =0
Return the effective radius for a particle for the model.
Macros to ease declaration of run-time selection tables.
volScalarField & p
Namespace for OpenFOAM.