tractionDisplacementCorrectionFvPatchVectorField.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) 2011-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 \*---------------------------------------------------------------------------*/
27 
30 #include "volFields.H"
31 
32 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
33 
34 namespace Foam
35 {
36 
37 // * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
38 
41 (
42  const fvPatch& p,
43  const DimensionedField<vector, volMesh>& iF
44 )
45 :
46  fixedGradientFvPatchVectorField(p, iF),
47  traction_(p.size(), Zero),
48  pressure_(p.size(), Zero)
49 {
50  fvPatchVectorField::operator=(patchInternalField());
51  gradient() = Zero;
52 }
53 
54 
55 tractionDisplacementCorrectionFvPatchVectorField::
56 tractionDisplacementCorrectionFvPatchVectorField
57 (
58  const tractionDisplacementCorrectionFvPatchVectorField& tdpvf,
59  const fvPatch& p,
60  const DimensionedField<vector, volMesh>& iF,
61  const fvPatchFieldMapper& mapper
62 )
63 :
64  fixedGradientFvPatchVectorField(tdpvf, p, iF, mapper),
65  traction_(tdpvf.traction_, mapper),
66  pressure_(tdpvf.pressure_, mapper)
67 {}
68 
69 
70 tractionDisplacementCorrectionFvPatchVectorField::
71 tractionDisplacementCorrectionFvPatchVectorField
72 (
73  const fvPatch& p,
74  const DimensionedField<vector, volMesh>& iF,
75  const dictionary& dict
76 )
77 :
78  fixedGradientFvPatchVectorField(p, iF),
79  traction_("traction", dict, p.size()),
80  pressure_("pressure", dict, p.size())
81 {
82  fvPatchVectorField::operator=(patchInternalField());
83  gradient() = Zero;
84 }
85 
86 
87 tractionDisplacementCorrectionFvPatchVectorField::
88 tractionDisplacementCorrectionFvPatchVectorField
89 (
90  const tractionDisplacementCorrectionFvPatchVectorField& tdpvf
91 )
92 :
93  fixedGradientFvPatchVectorField(tdpvf),
94  traction_(tdpvf.traction_),
95  pressure_(tdpvf.pressure_)
96 {}
97 
98 
99 tractionDisplacementCorrectionFvPatchVectorField::
100 tractionDisplacementCorrectionFvPatchVectorField
101 (
102  const tractionDisplacementCorrectionFvPatchVectorField& tdpvf,
103  const DimensionedField<vector, volMesh>& iF
104 )
105 :
106  fixedGradientFvPatchVectorField(tdpvf, iF),
107  traction_(tdpvf.traction_),
108  pressure_(tdpvf.pressure_)
109 {}
110 
111 
112 // * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
113 
114 void tractionDisplacementCorrectionFvPatchVectorField::autoMap
115 (
116  const fvPatchFieldMapper& m
117 )
118 {
119  fixedGradientFvPatchVectorField::autoMap(m);
120  traction_.autoMap(m);
121  pressure_.autoMap(m);
122 }
123 
124 
125 // Reverse-map the given fvPatchField onto this fvPatchField
126 void tractionDisplacementCorrectionFvPatchVectorField::rmap
127 (
128  const fvPatchVectorField& ptf,
129  const labelList& addr
130 )
131 {
132  fixedGradientFvPatchVectorField::rmap(ptf, addr);
133 
134  const tractionDisplacementCorrectionFvPatchVectorField& dmptf =
135  refCast<const tractionDisplacementCorrectionFvPatchVectorField>(ptf);
136 
137  traction_.rmap(dmptf.traction_, addr);
138  pressure_.rmap(dmptf.pressure_, addr);
139 }
140 
141 
142 // Update the coefficients associated with the patch field
143 void tractionDisplacementCorrectionFvPatchVectorField::updateCoeffs()
144 {
145  if (updated())
146  {
147  return;
148  }
149 
150  const dictionary& mechanicalProperties = db().lookupObject<IOdictionary>
151  (
152  "mechanicalProperties"
153  );
154 
155  const fvPatchField<scalar>& rho =
156  patch().lookupPatchField<volScalarField, scalar>("rho");
157 
158  const fvPatchField<scalar>& rhoE =
159  patch().lookupPatchField<volScalarField, scalar>("E");
160 
161  const fvPatchField<scalar>& nu =
162  patch().lookupPatchField<volScalarField, scalar>("nu");
163 
164  scalarField E(rhoE/rho);
165  scalarField mu(E/(2.0*(1.0 + nu)));
166  scalarField lambda(nu*E/((1.0 + nu)*(1.0 - 2.0*nu)));
167 
168  if (mechanicalProperties.get<bool>("planeStress"))
169  {
170  lambda = nu*E/((1.0 + nu)*(1.0 - nu));
171  }
172 
173  vectorField n(patch().nf());
174 
175  const fvPatchField<symmTensor>& sigmaD =
176  patch().lookupPatchField<volSymmTensorField, symmTensor>("sigmaD");
177 
178  const fvPatchField<tensor>& sigmaExp =
179  patch().lookupPatchField<volTensorField, tensor>("sigmaExp");
180 
181  gradient() =
182  (
183  (traction_ + pressure_*n)/rho - (n & (sigmaD + sigmaExp))
184  )/(2.0*mu + lambda);
185 
186  fixedGradientFvPatchVectorField::updateCoeffs();
187 }
188 
189 
190 // Write
192 {
194  traction_.writeEntry("traction", os);
195  pressure_.writeEntry("pressure", os);
196  writeEntry("value", os);
197 }
198 
199 
200 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
201 
203 (
205  tractionDisplacementCorrectionFvPatchVectorField
206 );
207 
208 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
209 
210 } // End namespace Foam
211 
212 // ************************************************************************* //
#define makePatchTypeField(PatchTypeField, typePatchTypeField)
Definition: fvPatchField.H:916
GeometricField< symmTensor, fvPatchField, volMesh > volSymmTensorField
Definition: volFieldsFwd.H:88
dictionary dict
fvPatchField< vector > fvPatchVectorField
volScalarField & rhoE
GeometricField< tensor, fvPatchField, volMesh > volTensorField
Definition: volFieldsFwd.H:89
Tensor< scalar > tensor
Definition: symmTensor.H:57
Macros for easy insertion into run-time selection tables.
GeometricField< scalar, fvPatchField, volMesh > volScalarField
Definition: volFieldsFwd.H:84
void write(vtk::formatter &fmt, const Type &val, const label n=1)
Component-wise write of a value (N times)
SymmTensor< scalar > symmTensor
SymmTensor of scalars, i.e. SymmTensor<scalar>.
Definition: symmTensor.H:55
dimensionedScalar lambda("lambda", dimTime/sqr(dimLength), laminarTransport)
Field< scalar > scalarField
Specialisation of Field<T> for scalar.
OBJstream os(runTime.globalPath()/outputName)
tractionDisplacementCorrectionFvPatchVectorField(const fvPatch &, const DimensionedField< vector, volMesh > &)
Construct from patch and internal field.
const dimensionedScalar mu
Atomic mass unit.
const std::string patch
OpenFOAM patch number as a std::string.
label n
Field< vector > vectorField
Specialisation of Field<T> for vector.
List< label > labelList
A List of labels.
Definition: List.H:62
volScalarField & p
volScalarField & nu
Namespace for OpenFOAM.
static constexpr const zero Zero
Global zero (0)
Definition: zero.H:157