processorPointPatch.C
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) 2011-2016 OpenFOAM Foundation
9-------------------------------------------------------------------------------
10License
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\*---------------------------------------------------------------------------*/
27
28#include "processorPointPatch.H"
29#include "pointBoundaryMesh.H"
31#include "pointMesh.H"
32#include "faceList.H"
33#include "primitivePatch.H"
34#include "emptyPolyPatch.H"
35
36// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
37
38namespace Foam
39{
42 (
46 );
47}
48
49
50// * * * * * * * * * * * * * Protected Member Functions * * * * * * * * * * //
51
52void Foam::processorPointPatch::initGeometry(PstreamBuffers& pBufs)
53{
54 // Algorithm:
55 // Depending on whether the patch is a owner or neighbour, get the primitive
56 // patch points and filter away the points from the global patch.
57
58 // Create the reversed patch and pick up its points
59 // so that the order is correct
60 const polyPatch& pp = patch();
61
62 faceList masterFaces(pp.size());
63
64 forAll(pp, facei)
65 {
66 masterFaces[facei] = pp[facei].reverseFace();
67 }
68
69 reverseMeshPoints_ = primitiveFacePatch
70 (
71 masterFaces,
72 pp.points()
73 ).meshPoints();
74}
75
76
77void Foam::processorPointPatch::calcGeometry(PstreamBuffers& pBufs)
78{}
79
80
82(
83 PstreamBuffers&,
84 const pointField&
85)
86{}
87
88
89void Foam::processorPointPatch::movePoints(PstreamBuffers&, const pointField&)
90{}
91
92
93void Foam::processorPointPatch::initUpdateMesh(PstreamBuffers& pBufs)
94{
96 processorPointPatch::initGeometry(pBufs);
97}
98
99
100void Foam::processorPointPatch::updateMesh(PstreamBuffers& pBufs)
101{
104}
105
106
107// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
108
110(
111 const polyPatch& patch,
112 const pointBoundaryMesh& bm
113)
114:
115 coupledFacePointPatch(patch, bm),
116 procPolyPatch_(refCast<const processorPolyPatch>(patch))
117{}
118
119
120// ************************************************************************* //
Macros for easy insertion into run-time selection tables.
#define addToRunTimeSelectionTable(baseType, thisType, argNames)
Add to construction table with typeName as the key.
coupled patch for post-processing. Used as the base class for processor and cyclic pointPatches
void calcGeometry()
Calculate the geometry for the patches.
A pointPatch based on a polyPatch.
virtual const polyPatch & patch() const
Return the polyPatch.
virtual void initUpdateMesh(PstreamBuffers &)
Initialise the update of the patch topology.
virtual void initMovePoints()
Initialise the patches for moving points.
Definition: fvPatch.C:188
void movePoints()
Update for new mesh geometry.
void updateMesh()
Update for new mesh topology.
Foam::pointBoundaryMesh.
A patch is a list of labels that address the faces in the global face list.
Definition: polyPatch.H:75
Processor patch boundary needs to be such that the ordering of points in the patch is the same on bot...
Neighbour processor patch.
#define defineTypeNameAndDebug(Type, DebugSwitch)
Define the typeName and debug information.
Definition: className.H:121
Namespace for OpenFOAM.
To & refCast(From &r)
Reference type cast template function.
Definition: typeInfo.H:131
vectorField pointField
pointField is a vectorField.
Definition: pointFieldFwd.H:44
PrimitivePatch< List< face >, const pointField & > primitiveFacePatch
A PrimitivePatch with List storage for the faces, const reference for the point field.
List< face > faceList
A List of faces.
Definition: faceListFwd.H:47
#define forAll(list, i)
Loop across all elements in list.
Definition: stdFoam.H:333