Forward compatibility: flex
[foam-extend-3.2.git] / src / dynamicMesh / meshMotion / fvMotionSolver / pointPatchFields / derived / oscillatingVelocity / oscillatingVelocityPointPatchVectorField.C
blobed00456268a8745538b207c2f923a9c72147b93d
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 "oscillatingVelocityPointPatchVectorField.H"
27 #include "pointPatchFields.H"
28 #include "addToRunTimeSelectionTable.H"
29 #include "foamTime.H"
30 #include "polyMesh.H"
32 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
34 namespace Foam
37 // * * * * * * * * * * * * * * * * Constructors  * * * * * * * * * * * * * * //
39 oscillatingVelocityPointPatchVectorField::
40 oscillatingVelocityPointPatchVectorField
42     const pointPatch& p,
43     const DimensionedField<vector, pointMesh>& iF
46     fixedValuePointPatchVectorField(p, iF),
47     amplitude_(vector::zero),
48     omega_(0.0),
49     p0_(p.localPoints())
53 oscillatingVelocityPointPatchVectorField::
54 oscillatingVelocityPointPatchVectorField
56     const pointPatch& p,
57     const DimensionedField<vector, pointMesh>& iF,
58     const dictionary& dict
61     fixedValuePointPatchVectorField(p, iF, dict),
62     amplitude_(dict.lookup("amplitude")),
63     omega_(readScalar(dict.lookup("omega")))
65     if (!dict.found("value"))
66     {
67         updateCoeffs();
68     }
70     if (dict.found("p0"))
71     {
72         p0_ = vectorField("p0", dict , p.size());
73     }
74     else
75     {
76         p0_ = p.localPoints();
77     }
81 oscillatingVelocityPointPatchVectorField::
82 oscillatingVelocityPointPatchVectorField
84     const oscillatingVelocityPointPatchVectorField& ptf,
85     const pointPatch& p,
86     const DimensionedField<vector, pointMesh>& iF,
87     const PointPatchFieldMapper& mapper
90     fixedValuePointPatchVectorField(ptf, p, iF, mapper),
91     amplitude_(ptf.amplitude_),
92     omega_(ptf.omega_),
93     p0_(ptf.p0_)
97 oscillatingVelocityPointPatchVectorField::
98 oscillatingVelocityPointPatchVectorField
100     const oscillatingVelocityPointPatchVectorField& ptf,
101     const DimensionedField<vector, pointMesh>& iF
104     fixedValuePointPatchVectorField(ptf, iF),
105     amplitude_(ptf.amplitude_),
106     omega_(ptf.omega_),
107     p0_(ptf.p0_)
111 // * * * * * * * * * * * * * * * Member Functions  * * * * * * * * * * * * * //
113 void oscillatingVelocityPointPatchVectorField::updateCoeffs()
115     if (this->updated())
116     {
117         return;
118     }
120     const polyMesh& mesh = this->dimensionedInternalField().mesh()();
121     const Time& t = mesh.time();
122     const pointPatch& p = this->patch();
124     Field<vector>::operator=
125     (
126         (p0_ + amplitude_*sin(omega_*t.value()) - p.localPoints())
127        /t.deltaT().value()
128     );
130     fixedValuePointPatchVectorField::updateCoeffs();
134 void oscillatingVelocityPointPatchVectorField::write(Ostream& os) const
136     pointPatchField<vector>::write(os);
137     os.writeKeyword("amplitude")
138         << amplitude_ << token::END_STATEMENT << nl;
139     os.writeKeyword("omega")
140         << omega_ << token::END_STATEMENT << nl;
141     p0_.writeEntry("p0", os);
142     writeEntry("value", os);
146 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
148 makePointPatchTypeField
150     pointPatchVectorField,
151     oscillatingVelocityPointPatchVectorField
154 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
156 } // End namespace Foam
158 // ************************************************************************* //