OpenFOAM
v2512
The open source CFD toolbox
Loading...
Searching...
No Matches
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 Foam_solidBodyMotionSolver_H
39
#define Foam_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
63
// Private Member Functions
64
65
//- No copy construct
66
solidBodyMotionSolver(
const
solidBodyMotionSolver&) =
delete
;
67
68
//- No copy assignment
69
void
operator=(
const
solidBodyMotionSolver&) =
delete
;
70
71
72
public
:
73
74
//- Runtime type information
75
TypeName
(
"solidBody"
);
76
77
78
// Constructors
79
80
//- Construct from mesh and dictionary
81
solidBodyMotionSolver
82
(
83
const
polyMesh
&
mesh
,
84
const
IOdictionary
&
dict
85
);
86
87
88
//- Destructor
89
virtual
~solidBodyMotionSolver
() =
default
;
90
91
92
// Member Functions
93
94
//- Return point location obtained from the current motion field
95
virtual
tmp<pointField>
curPoints
()
const
;
96
97
//- Solve for motion
98
virtual
void
solve
()
99
{}
100
};
101
102
103
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
104
105
}
// End namespace Foam
106
107
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
108
109
#endif
110
111
// ************************************************************************* //
Foam::IOdictionary
IOdictionary is derived from dictionary and IOobject to give the dictionary automatic IO functionalit...
Definition
IOdictionary.H:53
Foam::autoPtr
Pointer management similar to std::unique_ptr, with some additional methods and type checking.
Definition
autoPtr.H:65
Foam::motionSolver::mesh
const polyMesh & mesh() const
Return reference to mesh.
Definition
motionSolver.H:165
Foam::points0MotionSolver::points0MotionSolver
points0MotionSolver(const points0MotionSolver &)=delete
No copy construct.
Foam::polyMesh
Mesh consisting of general polyhedral cells.
Definition
polyMesh.H:79
Foam::solidBodyMotionSolver::curPoints
virtual tmp< pointField > curPoints() const
Return point location obtained from the current motion field.
Definition
solidBodyMotionSolver.C:55
Foam::solidBodyMotionSolver::~solidBodyMotionSolver
virtual ~solidBodyMotionSolver()=default
Destructor.
Foam::solidBodyMotionSolver::TypeName
TypeName("solidBody")
Runtime type information.
Foam::solidBodyMotionSolver::solve
virtual void solve()
Solve for motion.
Definition
solidBodyMotionSolver.H:109
Foam::tmp
A class for managing temporary objects.
Definition
tmp.H:75
Foam
Namespace for OpenFOAM.
Definition
atmBoundaryLayer.C:27
points0MotionSolver.H
dict
dictionary dict
Definition
searchingEngine.H:11
solidBodyMotionFunction.H
TypeName
#define TypeName(TypeNameString)
Declare a ClassName() with extra virtual type info.
Definition
typeInfo.H:68
src
dynamicMesh
motionSolvers
displacement
solidBody
solidBodyMotionSolver.H
Generated by
1.16.1