leastSquaresFaGrad.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) 2016-2017 Wikki 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 Class
27  Foam::fa::leastSquaresFaGrad
28 
29 Description
30  Second-order gradient scheme using least-squares.
31 
32 Author
33  Hrvoje Jasak, Wikki Ltd.
34 
35 SourceFiles
36  leastSquaresFaGrad.C
37 
38 \*---------------------------------------------------------------------------*/
39 
40 #ifndef leastSquaresFaGrad_H
41 #define leastSquaresFaGrad_H
42 
43 #include "faGradScheme.H"
44 
45 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
46 
47 namespace Foam
48 {
49 
50 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
51 
52 namespace fa
53 {
54 
55 /*---------------------------------------------------------------------------*\
56  Class leastSquaresFaGrad Declaration\*-------------------
57 \*---------------------------------------------------------------------------*/
58 
59 template<class Type>
61 :
62  public fa::gradScheme<Type>
63 {
64  // Private Member Functions
65 
66  //- No copy construct
67  leastSquaresFaGrad(const leastSquaresFaGrad&) = delete;
68 
69  //- No copy assignment
70  void operator=(const leastSquaresFaGrad&) = delete;
71 
72 
73 public:
74 
75  //- Runtime type information
76  TypeName("leastSquares");
77 
78 
79  // Constructors
80 
81  //- Construct from mesh
83  :
84  gradScheme<Type>(mesh)
85  {}
86 
87  //- Construct from Istream
89  :
90  gradScheme<Type>(mesh)
91  {}
92 
93 
94  // Member Functions
95 
96  virtual tmp
97  <
100  > grad
101  (
103  ) const;
104 };
105 
106 
107 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
108 
109 } // End namespace fa
110 
111 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
112 
113 } // End namespace Foam
114 
115 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
116 
117 #ifdef NoRepository
118  #include "leastSquaresFaGrad.C"
119 #endif
120 
121 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
122 
123 #endif
124 
125 // ************************************************************************* //
Foam::faPatchField
faPatchField<Type> abstract base class. This class gives a fat-interface to all derived classes cover...
Definition: areaFieldsFwd.H:50
Foam::fa::leastSquaresFaGrad
Second-order gradient scheme using least-squares.
Definition: leastSquaresFaGrad.H:59
Foam::tmp
A class for managing temporary objects.
Definition: PtrList.H:61
Foam::outerProduct::type
typeOfRank< typename pTraits< arg1 >::cmptType, direction(pTraits< arg1 >::rank)+direction(pTraits< arg2 >::rank) >::type type
Definition: products.H:114
Foam::fa::gradScheme::mesh
const faMesh & mesh() const
Return mesh reference.
Definition: faGradScheme.H:121
faGradScheme.H
leastSquaresFaGrad.C
Foam::Istream
An Istream is an abstract base class for all input systems (streams, files, token lists etc)....
Definition: Istream.H:61
Foam::areaMesh
Mesh data needed to do the Finite Area discretisation.
Definition: areaFaMesh.H:53
Foam::fa::leastSquaresFaGrad::leastSquaresFaGrad
leastSquaresFaGrad(const faMesh &mesh)
Construct from mesh.
Definition: leastSquaresFaGrad.H:81
Foam::fa::gradScheme
Abstract base class for finite area calculus gradient schemes.
Definition: faGradScheme.H:63
Foam
Namespace for OpenFOAM.
Definition: atmBoundaryLayer.C:33
Foam::fa::leastSquaresFaGrad::grad
virtual tmp< GeometricField< typename outerProduct< vector, Type >::type, faPatchField, areaMesh > > grad(const GeometricField< Type, faPatchField, areaMesh > &) const
Calculate and return the grad of the given field.
Foam::fa::leastSquaresFaGrad::leastSquaresFaGrad
leastSquaresFaGrad(const faMesh &mesh, Istream &)
Construct from Istream.
Definition: leastSquaresFaGrad.H:87
Foam::faMesh
Finite area mesh. Used for 2-D non-Euclidian finite area method.
Definition: faMesh.H:82
Foam::GeometricField
Generic GeometricField class.
Definition: areaFieldsFwd.H:53
Foam::fa::leastSquaresFaGrad::TypeName
TypeName("leastSquares")
Runtime type information.