deferredCorrection.C
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) 2017 OpenCFD Ltd.
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 \*---------------------------------------------------------------------------*/
27 
28 #include "deferredCorrection.H"
29 
30 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
31 
32 template<class Type>
35 (
37 ) const
38 {
40  (
42  (
43  "deferredCorrection::correction(" + vf.name() + ')',
44  tbaseScheme_().interpolate(vf)
45  )
46  );
48 
49  // Interpolate using the upwind weights to avoid circular reference to
50  // [this] explicit correction
52 /*
53  auto& sfCorrBf = sfCorr.boundaryFieldRef();
54  for (auto& pf : sfCorrBf)
55  {
56  if (!pf.coupled())
57  {
58  pf = pTraits<Type>::zero;
59  }
60  }
61 */
62  return tsfCorr;
63 }
64 
65 
66 namespace Foam
67 {
68  //makeSurfaceInterpolationScheme(deferredCorrection)
71 }
72 
73 // ************************************************************************* //
Foam::tmp
A class for managing temporary objects.
Definition: PtrList.H:61
Foam::upwind
Upwind differencing scheme class.
Definition: upwind.H:56
Foam::deferredCorrection::correction
virtual tmp< GeometricField< Type, fvsPatchField, surfaceMesh > > correction(const GeometricField< Type, fvPatchField, volMesh > &) const
Return the explicit correction to the face-interpolate.
Definition: deferredCorrection.C:35
Foam::tmp::ref
T & ref() const
Definition: tmpI.H:227
Foam::makeSurfaceInterpolationTypeScheme
makeSurfaceInterpolationTypeScheme(LUST, scalar)
Foam
Namespace for OpenFOAM.
Definition: atmBoundaryLayer.C:33
Foam::deferredCorrection
Deferred correction interpolation scheme wrapper around a run-time selectable base scheme.
Definition: deferredCorrection.H:72
Foam::Vector< scalar >
deferredCorrection.H
Foam::GeometricField< Type, fvPatchField, volMesh >
Foam::fac::interpolate
static tmp< GeometricField< Type, faePatchField, edgeMesh > > interpolate(const GeometricField< Type, faPatchField, areaMesh > &tvf, const edgeScalarField &faceFlux, Istream &schemeData)
Interpolate field onto faces using scheme given by Istream.