gaussDivScheme.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::gaussDivScheme
28 
29 Group
30  grpFvDivSchemes
31 
32 Description
33  Basic second-order div using face-gradients and Gauss' theorem.
34 
35 SourceFiles
36  gaussDivScheme.C
37 
38 \*---------------------------------------------------------------------------*/
39 
40 #ifndef gaussDivScheme_H
41 #define gaussDivScheme_H
42 
43 #include "divScheme.H"
44 
45 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
46 
47 namespace Foam
48 {
49 
50 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
51 
52 namespace fv
53 {
54 
55 /*---------------------------------------------------------------------------*\
56  Class gaussDivScheme Declaration
57 \*---------------------------------------------------------------------------*/
58 
59 template<class Type>
60 class gaussDivScheme
61 :
62  public fv::divScheme<Type>
63 {
64  // Private Member Functions
65 
66  //- No copy construct
67  gaussDivScheme(const gaussDivScheme&) = delete;
68 
69  //- No copy assignment
70  void operator=(const gaussDivScheme&) = delete;
71 
72 
73 public:
74 
75  //- Runtime type information
76  TypeName("Gauss");
77 
78 
79  // Constructors
80 
81  //- Construct null
82  gaussDivScheme(const fvMesh& mesh)
83  :
84  divScheme<Type>(mesh)
85  {}
86 
87  //- Construct from Istream
88  gaussDivScheme(const fvMesh& mesh, Istream& is)
89  :
90  divScheme<Type>(mesh, is)
91  {}
92 
93 
94  // Member Functions
95 
96  tmp
97  <
100  > fvcDiv
101  (
103  );
104 };
105 
106 
107 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
108 
109 } // End namespace fv
110 
111 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
112 
113 } // End namespace Foam
114 
115 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
116 
117 #ifdef NoRepository
118  #include "gaussDivScheme.C"
119 #endif
120 
121 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
122 
123 #endif
124 
125 // ************************************************************************* //
Foam::fvPatchField
Abstract base class with a fat-interface to all derived classes covering all possible ways in which t...
Definition: volSurfaceMapping.H:51
Foam::tmp
A class for managing temporary objects.
Definition: PtrList.H:61
Foam::fv::gaussDivScheme::fvcDiv
tmp< GeometricField< typename innerProduct< vector, Type >::type, fvPatchField, volMesh > > fvcDiv(const GeometricField< Type, fvPatchField, volMesh > &)
Foam::innerProduct
Definition: products.H:141
Foam::volMesh
Mesh data needed to do the Finite Volume discretisation.
Definition: volMesh.H:51
Foam::Istream
An Istream is an abstract base class for all input systems (streams, files, token lists etc)....
Definition: Istream.H:61
Foam::fv::divScheme
Abstract base class for div schemes.
Definition: divScheme.H:69
gaussDivScheme.C
Foam::fvMesh
Mesh data needed to do the Finite Volume discretisation.
Definition: fvMesh.H:85
Foam
Namespace for OpenFOAM.
Definition: atmBoundaryLayer.C:33
Foam::fv::gaussDivScheme::TypeName
TypeName("Gauss")
Runtime type information.
fv
labelList fv(nPoints)
Foam::fv::divScheme::mesh
const fvMesh & mesh() const
Return mesh reference.
Definition: divScheme.H:143
Foam::fv::gaussDivScheme::gaussDivScheme
gaussDivScheme(const fvMesh &mesh, Istream &is)
Construct from Istream.
Definition: gaussDivScheme.H:87
Foam::fv::gaussDivScheme::gaussDivScheme
gaussDivScheme(const fvMesh &mesh)
Construct null.
Definition: gaussDivScheme.H:81
Foam::GeometricField
Generic GeometricField class.
Definition: areaFieldsFwd.H:53
divScheme.H
Foam::fv::gaussDivScheme
Basic second-order div using face-gradients and Gauss' theorem.
Definition: gaussDivScheme.H:59