displacementComponent_pointMeshMover.C
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------*\
2  ========= |
3  \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4  \\ / O peration | Website: https://openfoam.org
5  \\ / A nd | Copyright (C) 2012-2026 OpenFOAM Foundation
6  \\/ M anipulation |
7 -------------------------------------------------------------------------------
8 License
9  This file is part of OpenFOAM.
10 
11  OpenFOAM is free software: you can redistribute it and/or modify it
12  under the terms of the GNU General Public License as published by
13  the Free Software Foundation, either version 3 of the License, or
14  (at your option) any later version.
15 
16  OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
17  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
18  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
19  for more details.
20 
21  You should have received a copy of the GNU General Public License
22  along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
23 
24 \*---------------------------------------------------------------------------*/
25 
27 #include "polyTopoChangeMap.H"
28 
29 // * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
30 
31 namespace Foam
32 {
33 namespace pointMeshMovers
34 {
36 }
37 }
38 
39 
40 // * * * * * * * * * * * * * Private Member Functions * * * * * * * * * * * //
41 
42 Foam::direction Foam::pointMeshMovers::displacementComponent::cmpt
43 (
44  const word& cmptName
45 ) const
46 {
47  if (cmptName == "x")
48  {
49  return vector::X;
50  }
51  else if (cmptName == "y")
52  {
53  return vector::Y;
54  }
55  else if (cmptName == "z")
56  {
57  return vector::Z;
58  }
59  else
60  {
62  << "Given component name " << cmptName << " should be x, y or z"
63  << exit(FatalError);
64 
65  return 0;
66  }
67 }
68 
69 
70 // * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
71 
73 (
74  const polyMesh& mesh,
75  const dictionary& dict,
76  const word& type
77 )
78 :
80  cmptName_(dict.lookup("component")),
81  cmpt_(cmpt(cmptName_)),
82  points0_
83  (
85  (
86  IOobject
87  (
88  "points",
89  mesh.time().constant(),
90  polyMesh::meshSubDir,
91  mesh,
92  IOobject::MUST_READ,
93  IOobject::NO_WRITE,
94  false
95  )
96  ).component(cmpt_)
97  ),
98  pointDisplacement_
99  (
100  IOobject
101  (
102  "pointDisplacement" + cmptName_,
103  mesh.time().name(),
104  mesh,
105  IOobject::MUST_READ,
106  IOobject::AUTO_WRITE
107  ),
108  pointMesh::New(mesh)
109  )
110 {
111  if (points0_.size() != mesh.nPoints())
112  {
114  << "Number of points in mesh " << mesh.nPoints()
115  << " differs from number of points " << points0_.size()
116  << " read from file "
118  (
119  "points",
120  mesh.time().constant(),
122  mesh,
125  false
126  ).filePath()
127  << exit(FatalError);
128  }
129 }
130 
131 
132 // * * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * //
133 
135 {}
136 
137 
138 // * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
139 
141 (
142  const pointField& p
143 )
144 {
145  // No local data to update
146 }
147 
148 
150 (
151  const polyTopoChangeMap& map
152 )
153 {
154  // pointMesh already updates pointFields.
155 
156  // Map points0_. Bit special since we somehow have to come up with
157  // a sensible points0 position for introduced points.
158  // Find out scaling between points0 and current points
159 
160  // Get the new points either from the map or the mesh
161  const scalarField points(poly().points().component(cmpt_));
162 
163  // Get extents of points0 and points and determine scale
164  const scalar scale =
165  (gMax(points0_)-gMin(points0_))
166  /(gMax(points)-gMin(points));
167 
168  scalarField newPoints0(map.pointMap().size());
169 
170  forAll(newPoints0, pointi)
171  {
172  label oldPointi = map.pointMap()[pointi];
173 
174  if (oldPointi >= 0)
175  {
176  label masterPointi = map.reversePointMap()[oldPointi];
177 
178  if (masterPointi == pointi)
179  {
180  newPoints0[pointi] = points0_[oldPointi];
181  }
182  else
183  {
184  // New point. Assume motion is scaling.
185  newPoints0[pointi] =
186  points0_[oldPointi]
187  + scale*(points[pointi]-points[masterPointi]);
188  }
189  }
190  else
191  {
193  << "Cannot work out coordinates of introduced vertices."
194  << " New vertex " << pointi << " at coordinate "
195  << points[pointi] << exit(FatalError);
196  }
197  }
198  points0_.transfer(newPoints0);
199 }
200 
201 
203 (
204  const polyMeshMap& map
205 )
206 {
207  points0_ = poly().points().component(cmpt_);
208  pointDisplacement_ == Zero;
209 }
210 
211 
213 (
214  const polyDistributionMap& map
215 )
216 {}
217 
218 
219 // ************************************************************************* //
#define forAll(list, i)
Loop across all elements in list.
Definition: UList.H:449
A primitive field of type <Type> with automated input and output.
Definition: IOField.H:53
IOobject defines the attributes of an object for which implicit objectRegistry management is supporte...
Definition: IOobject.H:99
void size(const label)
Override size to be inconsistent with allocated storage.
Definition: ListI.H:164
static const word & constant()
Return constant name.
Definition: TimePaths.H:122
A list of keywords followed by any number of values (e.g. words and numbers) or sub-dictionaries.
Definition: dictionary.H:162
const Time & time() const
Return the top-level database.
Definition: fvMesh.H:433
Abstract base class for pointMesh movers.
Abstract base class for component displacement pointMesh movers.
scalarField points0_
Reference point field for this component.
virtual void topoChange(const polyTopoChangeMap &)
Update local data for topology changes.
virtual void distribute(const polyDistributionMap &)
Update corresponding to the given distribution map.
virtual void mapMesh(const polyMeshMap &)
Update from another mesh using the given map.
virtual void movePoints(const pointField &)
Update local data for geometry changes.
displacementComponent(const polyMesh &, const dictionary &, const word &type)
Construct from polyMesh and dictionary and type.
Mesh representing a set of points created from polyMesh.
Definition: pointMesh.H:52
Class containing mesh-to-mesh mapping information after a mesh distribution where we send parts of me...
Class containing mesh-to-mesh mapping information.
Definition: polyMeshMap.H:51
Mesh consisting of general polyhedral cells.
Definition: polyMesh.H:78
static word meshSubDir
Return the mesh sub-directory name (usually "polyMesh")
Definition: polyMesh.H:263
Class containing mesh-to-mesh mapping information after a change in polyMesh topology.
const labelList & reversePointMap() const
Reverse point map.
const labelList & pointMap() const
Old point map.
label nPoints() const
Templated form of IOobject providing type information for file reading and header type checking.
Definition: IOobject.H:545
fileName filePath() const
Return the path for the file for this Type.
Definition: IOobject.H:577
A class for handling words, derived from string.
Definition: word.H:63
Foam::fvMesh mesh(Foam::IOobject(regionName, runTime.name(), runTime, Foam::IOobject::MUST_READ), false)
#define FatalErrorInFunction
Report an error message using Foam::FatalError.
Definition: error.H:334
const pointField & points
const dimensionSet time
defineTypeNameAndDebug(externalDisplacement, 0)
const unitSet & lookup(const word &unitName)
Lookup and return the named unit from the table.
Definition: units.C:346
Namespace for OpenFOAM.
Type gMin(const UList< Type > &f, const label comm)
errorManipArg< error, int > exit(error &err, const int errNo=1)
Definition: errorManip.H:124
static const zero Zero
Definition: zero.H:97
intWM_LABEL_SIZE_t label
A label is an int32_t or int64_t as specified by the pre-processor macro WM_LABEL_SIZE.
Definition: label.H:59
void component(GeometricField< typename GeometricField< Type, GeoMesh, PrimitiveField1 >::cmptType, GeoMesh, PrimitiveField1 > &gcf, const GeometricField< Type, GeoMesh, PrimitiveField2 > &gf, const direction d)
Type gMax(const UList< Type > &f, const label comm)
word name(const LagrangianState state)
Return a string representation of a Lagrangian state enumeration.
error FatalError
tmp< DimensionedField< TypeR, GeoMesh, Field > > New(const tmp< DimensionedField< TypeR, GeoMesh, Field >> &tdf1, const word &name, const dimensionSet &dimensions)
uint8_t direction
Definition: direction.H:45
fileType type(const fileName &, const bool checkVariants=true, const bool followLink=true)
Return the file type: directory or file.
Definition: POSIX.C:488
dictionary dict
volScalarField & p