processorLOD.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) 2017-2023 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::processorLOD
28 
29 Description
30  Base class to generate a parallel distribution map for sending sufficient
31  target objects to cover a description of the source object, based on
32  processor Level Of Detail (LOD) shapes
33 
34 \*---------------------------------------------------------------------------*/
35 
36 #ifndef Foam_processorLOD_H
37 #define Foam_processorLOD_H
38 
39 #include "autoPtr.H"
40 #include "typeInfo.H"
41 #include "mapDistributeBase.H" // For layoutTypes
42 
43 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
44 
45 namespace Foam
46 {
47 
48 // Forward Declarations
49 class mapDistribute;
50 
51 /*---------------------------------------------------------------------------*\
52  Class processorLOD Declaration
53 \*---------------------------------------------------------------------------*/
54 
55 class processorLOD
56 {
57 protected:
58 
59  // Protected Data
60 
61  //- Maximum number of objects per leaf
62  label maxObjectsPerLeaf_;
63 
64  //- Number of objects of this type.
65  //- e.g. number of faces/cells on this processor
66  label nObjectsOfType_;
67 
68 
69 public:
70 
71  //- Runtime type information
72  TypeName("processorLOD");
73 
74  //- Construct from components
76  (
77  const label maxObjectsPerLeaf,
78  const label nObjectsOfType
79  ) noexcept;
80 
81  //- Destructor
82  virtual ~processorLOD() = default;
83 
84 
85  // Member Functions
86 
87  //- Return the parallel distribution map
88  //- (usually linear construct order)
90  (
91  const mapDistributeBase::layoutTypes constructLayout
93  ) = 0;
94 };
95 
96 
97 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
98 
99 } // End namespace Foam
100 
101 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
102 
103 #endif
104 
105 // ************************************************************************* //
virtual ~processorLOD()=default
Destructor.
Base class to generate a parallel distribution map for sending sufficient target objects to cover a d...
Definition: processorLOD.H:48
layoutTypes
The map layout (eg, of the constructMap)
TypeName("processorLOD")
Runtime type information.
label nObjectsOfType_
Number of objects of this type. e.g. number of faces/cells on this processor.
Definition: processorLOD.H:63
label maxObjectsPerLeaf_
Maximum number of objects per leaf.
Definition: processorLOD.H:57
virtual autoPtr< mapDistribute > map(const mapDistributeBase::layoutTypes constructLayout=mapDistributeBase::layoutTypes::linear)=0
Return the parallel distribution map (usually linear construct order)
const direction noexcept
Definition: Scalar.H:258
Class containing processor-to-processor mapping information.
Pointer management similar to std::unique_ptr, with some additional methods and type checking...
Definition: HashPtrTable.H:48
processorLOD(const label maxObjectsPerLeaf, const label nObjectsOfType) noexcept
Construct from components.
Definition: processorLOD.C:31
Namespace for OpenFOAM.