sphericalTensorField.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 
28 #include "sphericalTensorField.H"
29 #include "transformField.H"
30 
31 #define TEMPLATE
32 #include "FieldFunctionsM.C"
33 
34 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
35 
36 namespace Foam
37 {
38 
39 // * * * * * * * * * * * * * * * Global Functions * * * * * * * * * * * * * //
40 
45 
48 
49 
50 template<>
52 (
53  const tensorField& tf
54 )
55 {
56  return sph(tf);
57 }
58 
59 template<>
60 tmp<Field<sphericalTensor>> transformFieldMask<sphericalTensor>
61 (
62  const tmp<tensorField>& ttf
63 )
64 {
65  tmp<Field<sphericalTensor>> ret =
67  ttf.clear();
68  return ret;
69 }
70 
71 
72 template<>
73 tmp<Field<sphericalTensor>> transformFieldMask<sphericalTensor>
74 (
75  const symmTensorField& stf
76 )
77 {
78  return sph(stf);
79 }
80 
81 template<>
82 tmp<Field<sphericalTensor>> transformFieldMask<sphericalTensor>
83 (
84  const tmp<symmTensorField>& tstf
85 )
86 {
87  tmp<Field<sphericalTensor>> ret =
89  tstf.clear();
90  return ret;
91 }
92 
93 
94 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
95 
96 } // End namespace Foam
97 
98 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
99 
100 #include "undefFieldFunctionsM.H"
101 
102 // ************************************************************************* //
#define BINARY_OPERATOR(ReturnType, Type1, Type2, Op, OpName, OpFunc)
void divide(DimensionedField< Type, GeoMesh > &result, const DimensionedField< Type, GeoMesh > &f1, const DimensionedField< scalar, GeoMesh > &f2)
Field< symmTensor > symmTensorField
Specialisation of Field<T> for symmTensor.
#define UNARY_FUNCTION(ReturnType, Type1, Func, Dfunc)
dimensionedSphericalTensor inv(const dimensionedSphericalTensor &dt)
dimensionedScalar det(const dimensionedSphericalTensor &dt)
SphericalTensor< Cmpt > sph(const DiagTensor< Cmpt > &dt)
Return the spherical part of a DiagTensor as a SphericalTensor.
Definition: DiagTensorI.H:110
tmp< Field< Type1 > > transformFieldMask(const Field< Type2 > &fld)
Spatial transformation functions for primitive fields.
Generic templated field type.
Definition: Field.H:62
tmp< Field< sphericalTensor > > transformFieldMask< sphericalTensor >(const tensorField &tf)
dimensionedScalar tr(const dimensionedSphericalTensor &dt)
SphericalTensor< scalar > sphericalTensor
SphericalTensor of scalars, i.e. SphericalTensor<scalar>.
A class for managing temporary objects.
Definition: HashPtrTable.H:50
#define BINARY_TYPE_OPERATOR(ReturnType, Type1, Type2, Op, OpName, OpFunc)
Namespace for OpenFOAM.