Forward compatibility: flex
[foam-extend-3.2.git] / src / dynamicMesh / meshMotion / fvMotionSolver / pointPatchFields / derived / oscillatingDisplacement / oscillatingDisplacementPointPatchVectorField.C
blob8c5aa0a2e3459339eb9064f67e7f78268d56a8cc
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | foam-extend: Open Source CFD
4    \\    /   O peration     | Version:     3.2
5     \\  /    A nd           | Web:         http://www.foam-extend.org
6      \\/     M anipulation  | For copyright notice see file Copyright
7 -------------------------------------------------------------------------------
8 License
9     This file is part of foam-extend.
11     foam-extend is free software: you can redistribute it and/or modify it
12     under the terms of the GNU General Public License as published by the
13     Free Software Foundation, either version 3 of the License, or (at your
14     option) any later version.
16     foam-extend is distributed in the hope that it will be useful, but
17     WITHOUT ANY WARRANTY; without even the implied warranty of
18     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
19     General Public License for more details.
21     You should have received a copy of the GNU General Public License
22     along with foam-extend.  If not, see <http://www.gnu.org/licenses/>.
24 \*---------------------------------------------------------------------------*/
26 #include "oscillatingDisplacementPointPatchVectorField.H"
27 #include "pointPatchFields.H"
28 #include "addToRunTimeSelectionTable.H"
29 #include "foamTime.H"
30 #include "polyMesh.H"
32 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
34 namespace Foam
37 // * * * * * * * * * * * * * * * * Constructors  * * * * * * * * * * * * * * //
39 oscillatingDisplacementPointPatchVectorField::
40 oscillatingDisplacementPointPatchVectorField
42     const pointPatch& p,
43     const DimensionedField<vector, pointMesh>& iF
46     fixedValuePointPatchVectorField(p, iF),
47     amplitude_(vector::zero),
48     omega_(0.0)
52 oscillatingDisplacementPointPatchVectorField::
53 oscillatingDisplacementPointPatchVectorField
55     const pointPatch& p,
56     const DimensionedField<vector, pointMesh>& iF,
57     const dictionary& dict
60     fixedValuePointPatchVectorField(p, iF, dict),
61     amplitude_(dict.lookup("amplitude")),
62     omega_(readScalar(dict.lookup("omega")))
64     if (!dict.found("value"))
65     {
66         updateCoeffs();
67     }
71 oscillatingDisplacementPointPatchVectorField::
72 oscillatingDisplacementPointPatchVectorField
74     const oscillatingDisplacementPointPatchVectorField& ptf,
75     const pointPatch& p,
76     const DimensionedField<vector, pointMesh>& iF,
77     const PointPatchFieldMapper& mapper
80     fixedValuePointPatchVectorField(ptf, p, iF, mapper),
81     amplitude_(ptf.amplitude_),
82     omega_(ptf.omega_)
86 oscillatingDisplacementPointPatchVectorField::
87 oscillatingDisplacementPointPatchVectorField
89     const oscillatingDisplacementPointPatchVectorField& ptf,
90     const DimensionedField<vector, pointMesh>& iF
93     fixedValuePointPatchVectorField(ptf, iF),
94     amplitude_(ptf.amplitude_),
95     omega_(ptf.omega_)
99 // * * * * * * * * * * * * * * * Member Functions  * * * * * * * * * * * * * //
101 void oscillatingDisplacementPointPatchVectorField::updateCoeffs()
103     if (this->updated())
104     {
105         return;
106     }
108     const polyMesh& mesh = this->dimensionedInternalField().mesh()();
109     const Time& t = mesh.time();
111     Field<vector>::operator=(amplitude_*sin(omega_*t.value()));
113     fixedValuePointPatchVectorField::updateCoeffs();
117 void oscillatingDisplacementPointPatchVectorField::write(Ostream& os) const
119     pointPatchField<vector>::write(os);
120     os.writeKeyword("amplitude")
121         << amplitude_ << token::END_STATEMENT << nl;
122     os.writeKeyword("omega")
123         << omega_ << token::END_STATEMENT << nl;
124     writeEntry("value", os);
128 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
130 makePointPatchTypeField
132     pointPatchVectorField,
133     oscillatingDisplacementPointPatchVectorField
136 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
138 } // End namespace Foam
140 // ************************************************************************* //