MachNo.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 OpenFOAM Foundation
9  Copyright (C) 2020 OpenCFD Ltd.
10 -------------------------------------------------------------------------------
11 License
12  This file is part of OpenFOAM.
13 
14  OpenFOAM is free software: you can redistribute it and/or modify it
15  under the terms of the GNU General Public License as published by
16  the Free Software Foundation, either version 3 of the License, or
17  (at your option) any later version.
18 
19  OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
20  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
21  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
22  for more details.
23 
24  You should have received a copy of the GNU General Public License
25  along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
26 
27 Class
28  Foam::functionObjects::MachNo
29 
30 Group
31  grpFieldFunctionObjects
32 
33 Description
34  Computes the Mach number as a \c volScalarField.
35 
36  Operands:
37  \table
38  Operand | Type | Location
39  input | volVectorField | $FOAM_CASE/<time>/<inpField>
40  output file | - | -
41  output field | volScalarField | $FOAM_CASE/<time>/<outField>
42  \endtable
43 
44 Usage
45  Minimal example by using \c system/controlDict.functions:
46  \verbatim
47  MachNo1
48  {
49  // Mandatory entries (unmodifiable)
50  type MachNo;
51  libs (fieldFunctionObjects);
52 
53  // Optional (inherited) entries
54  ...
55  }
56  \endverbatim
57 
58  where the entries mean:
59  \table
60  Property | Description | Type | Req'd | Dflt
61  type | Type name: MachNo | word | yes | -
62  libs | Library name: fieldFunctionObjects | word | yes | -
63  \endtable
64 
65  The inherited entries are elaborated in:
66  - \link functionObject.H \endlink
67  - \link fieldExpression.H \endlink
68 
69  Minimal example by using the \c postProcess utility:
70  \verbatim
71  postProcess -func MachNo
72  \endverbatim
73 
74 See also
75  - Foam::functionObject
76  - Foam::functionObjects::fvMeshFunctionObject
77  - Foam::functionObjects::fieldExpression
78  - ExtendedCodeGuide::functionObjects::field::MachNo
79 
80 SourceFiles
81  MachNo.C
82 
83 \*---------------------------------------------------------------------------*/
84 
85 #ifndef functionObjects_MachNo_H
86 #define functionObjects_MachNo_H
87 
88 #include "fieldExpression.H"
89 
90 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
91 
92 namespace Foam
93 {
94 namespace functionObjects
95 {
96 
97 /*---------------------------------------------------------------------------*\
98  Class MachNo Declaration
99 \*---------------------------------------------------------------------------*/
100 
101 class MachNo
102 :
103  public fieldExpression
104 {
105  // Private Member Functions
106 
107  //- Calculate the Mach number field and return true if successful
108  virtual bool calc();
109 
110 
111 public:
112 
113  //- Runtime type information
114  TypeName("MachNo");
115 
116 
117  // Constructors
118 
119  //- Construct for given objectRegistry and dictionary.
120  // Allow the possibility to load fields from files
121  MachNo
122  (
123  const word& name,
124  const Time& runTime,
125  const dictionary& dict
126  );
127 
128  //- No copy construct
129  MachNo(const MachNo&) = delete;
130 
131  //- No copy assignment
132  void operator=(const MachNo&) = delete;
133 
134 
135  //- Destructor
136  virtual ~MachNo() = default;
137 };
138 
139 
140 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
141 
142 } // End namespace functionObjects
143 } // End namespace Foam
144 
145 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
146 
147 #endif
148 
149 // ************************************************************************* //
runTime
engineTime & runTime
Definition: createEngineTime.H:13
Foam::Time
Class to control time during OpenFOAM simulations that is also the top-level objectRegistry.
Definition: Time.H:73
Foam::word
A class for handling words, derived from Foam::string.
Definition: word.H:65
Foam::functionObjects::MachNo
Computes the Mach number as a volScalarField.
Definition: MachNo.H:134
Foam::functionObjects::MachNo::~MachNo
virtual ~MachNo()=default
Destructor.
dict
dictionary dict
Definition: searchingEngine.H:14
Foam::dictionary
A list of keyword definitions, which are a keyword followed by a number of values (eg,...
Definition: dictionary.H:123
Foam
Namespace for OpenFOAM.
Definition: atmBoundaryLayer.C:33
Foam::functionObject::name
const word & name() const noexcept
Return the name of this functionObject.
Definition: functionObject.C:143
Foam::functionObjects::fieldExpression
Intermediate class for handling field expression function objects (e.g. blendingFactor etc....
Definition: fieldExpression.H:120
Foam::functionObjects::MachNo::operator=
void operator=(const MachNo &)=delete
No copy assignment.
fieldExpression.H
Foam::functionObjects::MachNo::TypeName
TypeName("MachNo")
Runtime type information.
Foam::functionObjects::MachNo::MachNo
MachNo(const word &name, const Time &runTime, const dictionary &dict)
Construct for given objectRegistry and dictionary.
Definition: MachNo.C:74