fourthGrad.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::fv::fourthGrad
28 
29 Group
30  grpFvGradSchemes
31 
32 Description
33  Second-order gradient scheme using least-squares.
34 
35 SourceFiles
36  fourthGrad.C
37 
38 \*---------------------------------------------------------------------------*/
39 
40 #ifndef fourthGrad_H
41 #define fourthGrad_H
42 
43 #include "gradScheme.H"
44 
45 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
46 
47 namespace Foam
48 {
49 
50 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
51 
52 namespace fv
53 {
54 
55 /*---------------------------------------------------------------------------*\
56  Class fourthGrad Declaration
57 \*---------------------------------------------------------------------------*/
58 
59 template<class Type>
60 class fourthGrad
61 :
62  public fv::gradScheme<Type>
63 {
64  // Private Member Functions
65 
66  //- No copy construct
67  fourthGrad(const fourthGrad&) = delete;
68 
69  //- No copy assignment
70  void operator=(const fourthGrad&) = delete;
71 
72 
73 public:
74 
75  //- Runtime type information
76  TypeName("fourth");
77 
78 
79  // Constructors
80 
81  //- Construct from Istream
82  fourthGrad(const fvMesh& mesh, Istream&)
83  :
84  gradScheme<Type>(mesh)
85  {}
86 
87 
88  // Member Functions
89 
90  //- Return the gradient of the given field to the gradScheme::grad
91  // for optional caching
92  virtual tmp
93  <
96  > calcGrad
97  (
99  const word& name
100  ) const;
101 };
102 
103 
104 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
105 
106 } // End namespace fv
107 
108 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
109 
110 } // End namespace Foam
111 
112 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
113 
114 #ifdef NoRepository
115  #include "fourthGrad.C"
116 #endif
117 
118 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
119 
120 #endif
121 
122 // ************************************************************************* //
Foam::fvPatchField
Abstract base class with a fat-interface to all derived classes covering all possible ways in which t...
Definition: volSurfaceMapping.H:50
Foam::fv::fourthGrad
Second-order gradient scheme using least-squares.
Definition: fourthGrad.H:59
Foam::word
A class for handling words, derived from Foam::string.
Definition: word.H:62
Foam::tmp
A class for managing temporary objects.
Definition: PtrList.H:59
Foam::volMesh
Mesh data needed to do the Finite Volume discretisation.
Definition: volMesh.H:50
Foam::outerProduct::type
typeOfRank< typename pTraits< arg1 >::cmptType, direction(pTraits< arg1 >::rank)+direction(pTraits< arg2 >::rank) >::type type
Definition: products.H:114
fourthGrad.C
Foam::fv::fourthGrad::calcGrad
virtual tmp< GeometricField< typename outerProduct< vector, Type >::type, fvPatchField, volMesh > > calcGrad(const GeometricField< Type, fvPatchField, volMesh > &vsf, const word &name) const
Return the gradient of the given field to the gradScheme::grad.
Foam::fv::fourthGrad::fourthGrad
fourthGrad(const fvMesh &mesh, Istream &)
Construct from Istream.
Definition: fourthGrad.H:81
Foam::Istream
An Istream is an abstract base class for all input systems (streams, files, token lists etc)....
Definition: Istream.H:61
Foam::name
word name(const complex &c)
Return string representation of complex.
Definition: complex.C:76
Foam::fv::gradScheme::mesh
const fvMesh & mesh() const
Return mesh reference.
Definition: gradScheme.H:124
gradScheme.H
Foam::fv::gradScheme
Abstract base class for gradient schemes.
Definition: gradScheme.H:62
Foam::fvMesh
Mesh data needed to do the Finite Volume discretisation.
Definition: fvMesh.H:84
Foam
Namespace for OpenFOAM.
Definition: atmBoundaryLayer.C:33
fv
labelList fv(nPoints)
Foam::fv::fourthGrad::TypeName
TypeName("fourth")
Runtime type information.
Foam::GeometricField
Generic GeometricField class.
Definition: areaFieldsFwd.H:53