PureUpwindFitScheme.H
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------*\
2  ========= |
3  \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4  \\ / O peration |
5  \\ / A nd | www.openfoam.com
6  \\/ M anipulation |
7 -------------------------------------------------------------------------------
8  Copyright (C) 2011-2016 OpenFOAM Foundation
9 -------------------------------------------------------------------------------
10 License
11  This file is part of OpenFOAM.
12 
13  OpenFOAM is free software: you can redistribute it and/or modify it
14  under the terms of the GNU General Public License as published by
15  the Free Software Foundation, either version 3 of the License, or
16  (at your option) any later version.
17 
18  OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
19  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
20  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
21  for more details.
22 
23  You should have received a copy of the GNU General Public License
24  along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
25 
26 Class
27  Foam::PureUpwindFitScheme
28 
29 Group
30  grpFvSurfaceInterpolationSchemes
31 
32 Description
33  Upwind biased fit surface interpolation scheme that applies an explicit
34  correction to upwind.
35 
36 \*---------------------------------------------------------------------------*/
37 
38 #ifndef PureUpwindFitScheme_H
39 #define PureUpwindFitScheme_H
40 
41 #include "UpwindFitData.H"
42 #include "upwind.H"
43 #include "Switch.H"
44 
45 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
46 
47 namespace Foam
48 {
49 
50 /*---------------------------------------------------------------------------*\
51  Class PureUpwindFitScheme Declaration
52 \*---------------------------------------------------------------------------*/
53 
54 template<class Type, class Polynomial, class Stencil>
56 :
57  public upwind<Type>
58 {
59  // Private Data
60 
61  //- Factor the fit is allowed to deviate from linear.
62  // This limits the amount of high-order correction and increases
63  // stability on bad meshes
64  const scalar linearLimitFactor_;
65 
66  //- Weights for central stencil
67  const scalar centralWeight_;
68 
69 
70  // Private Member Functions
71 
72  //- No copy construct
74 
75  //- No copy assignment
76  void operator=(const PureUpwindFitScheme&) = delete;
77 
78 
79 public:
80 
81  //- Runtime type information
82  TypeName("PureUpwindFitScheme");
83 
84 
85  // Constructors
86 
87  //- Construct from mesh and Istream
88  // The name of the flux field is read from the Istream and looked-up
89  // from the mesh objectRegistry
91  :
92  upwind<Type>
93  (
94  mesh,
95  mesh.lookupObject<surfaceScalarField>(word(is))
96  ),
97  linearLimitFactor_(readScalar(is)),
98  centralWeight_(1000)
99  {}
100 
101 
102  //- Construct from mesh, faceFlux and Istream
104  (
105  const fvMesh& mesh,
106  const surfaceScalarField& faceFlux,
107  Istream& is
108  )
109  :
110  upwind<Type>(mesh, faceFlux),
111  linearLimitFactor_(readScalar(is)),
112  centralWeight_(1000)
113  {}
114 
115 
116  // Member Functions
117 
118  //- Return true if this scheme uses an explicit correction
119  virtual bool corrected() const
120  {
121  return true;
122  }
123 
124  //- Return the explicit correction to the face-interpolate
127  (
129  ) const
130  {
131  const fvMesh& mesh = this->mesh();
132 
133  // Use the owner/neighbour splitting constructor
135 
136  const UpwindFitData<Polynomial>& ufd =
138  (
139  mesh,
140  stencil,
141  false, //offset to upwind
142  linearLimitFactor_,
143  centralWeight_
144  );
145 
146  const List<scalarList>& fo = ufd.owncoeffs();
147  const List<scalarList>& fn = ufd.neicoeffs();
148 
149  return stencil.weightedSum(this->faceFlux_, vf, fo, fn);
150  }
151 };
152 
153 
154 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
155 
156 } // End namespace Foam
157 
158 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
159 
160 // Add the patch constructor functions to the hash tables
161 
162 #define makePureUpwindFitSurfaceInterpolationTypeScheme\
163 ( \
164  SS, \
165  POLYNOMIAL, \
166  STENCIL, \
167  TYPE \
168 ) \
169  \
170 typedef PureUpwindFitScheme<TYPE, POLYNOMIAL, STENCIL> \
171  PureUpwindFitScheme##TYPE##POLYNOMIAL##STENCIL##_; \
172 defineTemplateTypeNameAndDebugWithName \
173  (PureUpwindFitScheme##TYPE##POLYNOMIAL##STENCIL##_, #SS, 0); \
174  \
175 surfaceInterpolationScheme<TYPE>::addMeshConstructorToTable \
176 <PureUpwindFitScheme<TYPE, POLYNOMIAL, STENCIL>> \
177  add##SS##STENCIL##TYPE##MeshConstructorToTable_; \
178  \
179 surfaceInterpolationScheme<TYPE>::addMeshFluxConstructorToTable \
180 <PureUpwindFitScheme<TYPE, POLYNOMIAL, STENCIL>> \
181  add##SS##STENCIL##TYPE##MeshFluxConstructorToTable_;
182 
183 #define makePureUpwindFitSurfaceInterpolationScheme(SS, POLYNOMIAL, STENCIL) \
184  \
185 makePureUpwindFitSurfaceInterpolationTypeScheme(SS,POLYNOMIAL,STENCIL,scalar) \
186 makePureUpwindFitSurfaceInterpolationTypeScheme(SS,POLYNOMIAL,STENCIL,vector) \
187 makePureUpwindFitSurfaceInterpolationTypeScheme \
188 ( \
189  SS, \
190  POLYNOMIAL, \
191  STENCIL, \
192  sphericalTensor \
193 ) \
194 makePureUpwindFitSurfaceInterpolationTypeScheme \
195 ( \
196  SS, \
197  POLYNOMIAL, \
198  STENCIL, \
199  symmTensor \
200 ) \
201 makePureUpwindFitSurfaceInterpolationTypeScheme(SS,POLYNOMIAL,STENCIL,tensor)
202 
203 
204 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
205 
206 #endif
207 
208 // ************************************************************************* //
Foam::word
A class for handling words, derived from Foam::string.
Definition: word.H:65
Foam::tmp
A class for managing temporary objects.
Definition: PtrList.H:61
Foam::PureUpwindFitScheme::corrected
virtual bool corrected() const
Return true if this scheme uses an explicit correction.
Definition: PureUpwindFitScheme.H:118
Foam::upwind
Upwind differencing scheme class.
Definition: upwind.H:56
Foam::MeshObject::New
static const Type & New(const Mesh &mesh, Args &&... args)
Get existing or create a new MeshObject.
Definition: MeshObject.C:48
Foam::UpwindFitData::neicoeffs
const List< scalarList > & neicoeffs() const
Return reference to neighbour fit coefficients.
Definition: UpwindFitData.H:115
Foam::extendedUpwindCellToFaceStencil
Creates upwind stencil by shifting a centred stencil to upwind and downwind faces and optionally remo...
Definition: extendedUpwindCellToFaceStencil.H:61
Foam::Istream
An Istream is an abstract base class for all input systems (streams, files, token lists etc)....
Definition: Istream.H:61
upwind.H
Switch.H
Foam::objectRegistry::lookupObject
const Type & lookupObject(const word &name, const bool recursive=false) const
Definition: objectRegistryTemplates.C:434
Foam::PureUpwindFitScheme::correction
virtual tmp< GeometricField< Type, fvsPatchField, surfaceMesh > > correction(const GeometricField< Type, fvPatchField, volMesh > &vf) const
Return the explicit correction to the face-interpolate.
Definition: PureUpwindFitScheme.H:126
UpwindFitData.H
Foam::UpwindFitData
Data for the quadratic fit correction interpolation scheme to be used with upwind biased stencil.
Definition: UpwindFitData.H:57
Foam::extendedUpwindCellToFaceStencil::weightedSum
tmp< GeometricField< Type, fvsPatchField, surfaceMesh > > weightedSum(const surfaceScalarField &phi, const GeometricField< Type, fvPatchField, volMesh > &fld, const List< List< scalar >> &ownWeights, const List< List< scalar >> &neiWeights) const
Sum vol field contributions to create face values.
Foam::UpwindFitData::owncoeffs
const List< scalarList > & owncoeffs() const
Return reference to owner fit coefficients.
Definition: UpwindFitData.H:109
Foam::fvMesh
Mesh data needed to do the Finite Volume discretisation.
Definition: fvMesh.H:85
Foam
Namespace for OpenFOAM.
Definition: atmBoundaryLayer.C:33
Foam::PureUpwindFitScheme
Upwind biased fit surface interpolation scheme that applies an explicit correction to upwind.
Definition: PureUpwindFitScheme.H:54
Foam::limitedSurfaceInterpolationScheme::faceFlux_
const surfaceScalarField & faceFlux_
Definition: limitedSurfaceInterpolationScheme.H:74
Foam::PureUpwindFitScheme::TypeName
TypeName("PureUpwindFitScheme")
Runtime type information.
Foam::List< scalarList >
Foam::surfaceInterpolationScheme::mesh
const fvMesh & mesh() const
Return mesh reference.
Definition: surfaceInterpolationScheme.H:144
Foam::GeometricField< scalar, fvsPatchField, surfaceMesh >