faEdgeMapper.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) 2016-2017 Wikki Ltd
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 "faEdgeMapper.H"
29#include "mapPolyMesh.H"
30#include "demandDrivenData.H"
31
32// * * * * * * * * * * * * * Private Member Functions * * * * * * * * * * * //
33
34void Foam::faEdgeMapper::calcAddressing() const
35{
36 if (directAddrPtr_)
37 {
39 << "Addressing already calculated"
40 << abort(FatalError);
41 }
42
43 hasUnmapped_ = false;
44
45 // Dummy mapping: take value from edge 0
46 directAddrPtr_ = new labelList(size(), Zero);
47}
48
49
50void Foam::faEdgeMapper::clearOut()
51{
52 deleteDemandDrivenData(directAddrPtr_);
53 hasUnmapped_ = false;
54}
55
56
57// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
58
60(
61 const faMesh& mesh,
62 const mapPolyMesh& mpm
63)
64:
65 mesh_(mesh),
66// mpm_(mpm),
67 sizeBeforeMapping_(mesh.nInternalEdges()),
68 hasUnmapped_(false),
69 directAddrPtr_(nullptr)
70{}
71
72
73// * * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * //
74
76{
77 clearOut();
78}
79
80
81// * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
82
84{
85 if (!directAddrPtr_)
86 {
87 calcAddressing();
88 }
89
90 return *directAddrPtr_;
91}
92
93
95{
97 << "Requested interpolative addressing for a direct mapper."
98 << abort(FatalError);
99
100 return labelListList::null();
101}
102
103
105{
107 << "Requested interpolative weights for a direct mapper."
108 << abort(FatalError);
109
110 return scalarListList::null();
111}
112
113
114// ************************************************************************* //
static const List< labelList > & null()
Return a null List.
Definition: ListI.H:109
FA edge mapper. Currently, edge-based finite area data is not mapped, but only resized,...
Definition: faEdgeMapper.H:62
virtual label size() const
Return size.
Definition: faEdgeMapper.H:115
virtual const labelListList & addressing() const
Return interpolated addressing.
Definition: faEdgeMapper.C:94
virtual const scalarListList & weights() const
Return interpolation weights.
Definition: faEdgeMapper.C:104
virtual const labelUList & directAddressing() const
Return direct addressing.
Definition: faEdgeMapper.C:83
virtual ~faEdgeMapper()
Destructor.
Definition: faEdgeMapper.C:75
Finite area mesh (used for 2-D non-Euclidian finite area method) defined using a patch of faces on a ...
Definition: faMesh.H:100
Class containing mesh-to-mesh mapping information after a change in polyMesh topology.
Definition: mapPolyMesh.H:162
dynamicFvMesh & mesh
Template functions to aid in the implementation of demand driven data.
#define FatalErrorInFunction
Report an error message using Foam::FatalError.
Definition: error.H:453
List< label > labelList
A List of labels.
Definition: List.H:66
errorManip< error > abort(error &err)
Definition: errorManip.H:144
static constexpr const zero Zero
Global zero (0)
Definition: zero.H:131
error FatalError
void deleteDemandDrivenData(DataPtr &dataPtr)