cellAspectRatio.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) 2020 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 Class
27  Foam::cellAspectRatio
28 
29 Description
30  (Rough approximation of) cell aspect ratio
31 
32 SourceFiles
33  cellAspectRatio.C
34 
35 \*---------------------------------------------------------------------------*/
36 
37 #ifndef cellAspectRatio_H
38 #define cellAspectRatio_H
39 
40 #include "MeshObject.H"
41 #include "polyMesh.H"
42 
43 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
44 
45 namespace Foam
46 {
47 
48 /*---------------------------------------------------------------------------*\
49  Class cellAspectRatio Declaration
50 \*---------------------------------------------------------------------------*/
51 
52 class cellAspectRatio
53 :
54  public MeshObject<polyMesh, MoveableMeshObject, cellAspectRatio>,
55  public scalarField
56 {
57  // Private Typedefs
58 
59  typedef MeshObject
60  <
61  polyMesh,
65 
66 
67  // Private Member Functions
68 
69  //- Construct aspect ratio
70  void calcAspectRatio();
71 
72 
73 public:
74 
75  // Declare name of the class and its debug switch
76  TypeName("cellAspectRatio");
77 
78 
79  // Constructors
80 
81  //- Construct given an polyMesh
82  explicit cellAspectRatio(const polyMesh&);
83 
84 
85  //- Destructor
86  virtual ~cellAspectRatio();
87 
88 
89  // Member functions
90 
91  //- Ignore mesh motion for now
92  virtual bool movePoints()
93  {
94  return false;
95  }
96 };
97 
98 
99 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
100 
101 } // End namespace Foam
102 
103 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
104 
105 #endif
106 
107 // ************************************************************************* //
MoveableMeshObject(const word &objName, const objectRegistry &obr)
Construct from name and instance on registry.
Definition: MeshObject.H:326
(Rough approximation of) cell aspect ratio
Templated abstract base-class for optional mesh objects used to automate their allocation to the mesh...
Definition: MeshObject.H:152
virtual bool movePoints()
Ignore mesh motion for now.
TypeName("cellAspectRatio")
Mesh consisting of general polyhedral cells.
Definition: polyMesh.H:75
virtual ~cellAspectRatio()
Destructor.
cellAspectRatio(const polyMesh &)
Construct given an polyMesh.
Namespace for OpenFOAM.