patchSeedSet.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) 2012-2014 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::patchSeedSet
28 
29 Description
30  Initialises points on or just off patch
31 
32  For a dictionary specification:
33  \table
34  Property | Description | Required | Default
35  type | patchSeed | yes |
36  axis | x, y, z, xyz, distance | yes |
37  patches | List of patch names or regexs | yes |
38  maxPoints | Max number of points to seed | yes |
39  points | List of selected locations | no | empty
40  \endtable
41 
42 SourceFiles
43  patchSeedSet.C
44 
45 \*---------------------------------------------------------------------------*/
46 
47 #ifndef patchSeedSet_H
48 #define patchSeedSet_H
49 
50 #include "sampledSet.H"
51 #include "DynamicList.H"
52 #include "HashSet.H"
53 #include "Random.H"
54 
55 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
56 
57 namespace Foam
58 {
59 
60 /*---------------------------------------------------------------------------*\
61  Class patchSeedSet Declaration
62 \*---------------------------------------------------------------------------*/
63 
64 class patchSeedSet
65 :
66  public sampledSet
67 {
68  // Private data
69 
70  //- Patches to sample
71  const labelHashSet patchSet_;
72 
73  //- Maximum number of patch faces to seed (if in random subset mode)
74  const label maxPoints_;
75 
76  //- Random number generator (if maxPoints < num patch faces)
77  autoPtr<Random> rndGenPtr_;
78 
79  //- Patch faces to seed selected based on nearness to supplied points
80  const pointField selectedLocations_;
81 
82 
83  // Private Member Functions
84 
85  //- Determine (random) samples on patch
86  void calcPatchSamples
87  (
88  const label nAvailable,
89  const label nPatchPoints,
90  DynamicList<point>& samplingPts,
91  DynamicList<label>& samplingCells,
92  DynamicList<label>& samplingFaces,
93  DynamicList<label>& samplingSegments,
94  DynamicList<scalar>& samplingCurveDist
95  );
96 
97  //- Determine samples provided by supplied points
98  void calcSelectedLocations
99  (
100  const label nAvailable,
101  const label nPatchPoints,
102  DynamicList<point>& samplingPts,
103  DynamicList<label>& samplingCells,
104  DynamicList<label>& samplingFaces,
105  DynamicList<label>& samplingSegments,
106  DynamicList<scalar>& samplingCurveDist
107  );
108 
109  //- Samples all points in sampleCoords.
110  void calcSamples
111  (
112  DynamicList<point>& samplingPts,
113  DynamicList<label>& samplingCells,
114  DynamicList<label>& samplingFaces,
115  DynamicList<label>& samplingSegments,
116  DynamicList<scalar>& samplingCurveDist
117  );
118 
119  //- Uses calcSamples to obtain samples. Copies them into *this.
120  void genSamples();
121 
122 
123 public:
124 
125  //- Runtime type information
126  TypeName("patchSeed");
127 
128 
129  // Constructors
130 
131  //- Construct from dictionary
133  (
134  const word& name,
135  const polyMesh& mesh,
136  const meshSearch& searchEngine,
137  const dictionary& dict
138  );
139 
140 
141  //- Destructor
142  virtual ~patchSeedSet() = default;
143 };
144 
145 
146 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
147 
148 } // End namespace Foam
149 
150 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
151 
152 #endif
153 
154 // ************************************************************************* //
Various (local, not parallel) searches on polyMesh; uses (demand driven) octree to search...
Definition: meshSearch.H:56
dictionary dict
A list of keyword definitions, which are a keyword followed by a number of values (eg...
Definition: dictionary.H:129
patchSeedSet(const word &name, const polyMesh &mesh, const meshSearch &searchEngine, const dictionary &dict)
Construct from dictionary.
Definition: patchSeedSet.C:398
HashSet< label, Hash< label > > labelHashSet
A HashSet of labels, uses label hasher.
Definition: HashSet.H:85
vectorField pointField
pointField is a vectorField.
Definition: pointFieldFwd.H:38
A class for handling words, derived from Foam::string.
Definition: word.H:63
const word & name() const noexcept
The coord-set name.
Definition: coordSet.H:152
const polyMesh & mesh() const noexcept
Definition: sampledSet.H:373
TypeName("patchSeed")
Runtime type information.
const meshSearch & searchEngine() const noexcept
Definition: sampledSet.H:378
Mesh consisting of general polyhedral cells.
Definition: polyMesh.H:74
Namespace for OpenFOAM.
virtual ~patchSeedSet()=default
Destructor.