OpenFOAM: API Guide
v2112
The open source CFD toolbox
solidBodyMotionSolver.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) 2016 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::solidBodyMotionSolver
28
29
Description
30
Solid-body motion of the mesh specified by a run-time selectable
31
motion function.
32
33
SourceFiles
34
solidBodyMotionSolver.C
35
36
\*---------------------------------------------------------------------------*/
37
38
#ifndef solidBodyMotionSolver_H
39
#define solidBodyMotionSolver_H
40
41
#include "
points0MotionSolver.H
"
42
#include "
solidBodyMotionFunction.H
"
43
44
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
45
46
namespace
Foam
47
{
48
49
/*---------------------------------------------------------------------------*\
50
Class solidBodyMotionSolver Declaration
51
\*---------------------------------------------------------------------------*/
52
53
class
solidBodyMotionSolver
54
:
55
public
points0MotionSolver
56
{
57
// Private data
58
59
//- The motion control function
60
autoPtr<solidBodyMotionFunction>
SBMFPtr_;
61
62
//- Points to move when cell zone is supplied
63
labelList
pointIDs_;
64
65
//- Flag to indicate whether all cells should move
66
bool
moveAllCells_;
67
68
69
// Private Member Functions
70
71
//- No copy construct
72
solidBodyMotionSolver
(
const
solidBodyMotionSolver
&) =
delete
;
73
74
//- No copy assignment
75
void
operator=(
const
solidBodyMotionSolver
&) =
delete
;
76
77
78
public
:
79
80
//- Runtime type information
81
TypeName
(
"solidBody"
);
82
83
84
// Constructors
85
86
//- Construct from mesh and dictionary
87
solidBodyMotionSolver
88
(
89
const
polyMesh
&,
90
const
IOdictionary
&
91
);
92
93
94
//- Destructor
95
~solidBodyMotionSolver
();
96
97
98
// Member Functions
99
100
//- Return point location obtained from the current motion field
101
virtual
tmp<pointField>
curPoints
()
const
;
102
103
//- Solve for motion
104
virtual
void
solve
()
105
{}
106
};
107
108
109
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
110
111
}
// End namespace Foam
112
113
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
114
115
#endif
116
117
// ************************************************************************* //
Foam::IOdictionary
IOdictionary is derived from dictionary and IOobject to give the dictionary automatic IO functionalit...
Definition:
IOdictionary.H:54
Foam::solidBodyMotionSolver
Solid-body motion of the mesh specified by a run-time selectable motion function.
Definition:
solidBodyMotionSolver.H:52
Foam::points0MotionSolver
Virtual base class for displacement motion solvers, where the point motion is relative to a set of fi...
Definition:
points0MotionSolver.H:57
Foam::solidBodyMotionSolver::TypeName
TypeName("solidBody")
Runtime type information.
solidBodyMotionFunction.H
Foam::tmp
A class for managing temporary objects.
Definition:
PtrList.H:61
Foam::polyMesh
Mesh consisting of general polyhedral cells.
Definition:
polyMesh.H:77
points0MotionSolver.H
Foam
Namespace for OpenFOAM.
Definition:
atmBoundaryLayer.C:33
Foam::autoPtr
Pointer management similar to std::unique_ptr, with some additional methods and type checking.
Definition:
HashPtrTable.H:53
Foam::List< label >
Foam::solidBodyMotionSolver::~solidBodyMotionSolver
~solidBodyMotionSolver()
Destructor.
Definition:
solidBodyMotionSolver.C:154
Foam::solidBodyMotionSolver::curPoints
virtual tmp< pointField > curPoints() const
Return point location obtained from the current motion field.
Definition:
solidBodyMotionSolver.C:160
Foam::solidBodyMotionSolver::solve
virtual void solve()
Solve for motion.
Definition:
solidBodyMotionSolver.H:103
src
dynamicMesh
motionSolvers
displacement
solidBody
solidBodyMotionSolver.H
Generated by
1.8.17
OPENFOAM® is a registered
trademark
of OpenCFD Ltd.