1 /*---------------------------------------------------------------------------*\
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 -------------------------------------------------------------------------------
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/>.
25 Foam::SphericalTensor2D
28 Templated 2D sphericalTensor derived from VectorSpace adding construction
29 from 1 component, element access using ii() member function and the
30 inner-product (dot-product) and outer-product operators.
33 SphericalTensor2DTemplateI.H
35 \*---------------------------------------------------------------------------*/
37 #ifndef SphericalTensor2DTemplate_H
38 #define SphericalTensor2DTemplate_H
40 #include "VectorSpace.H"
42 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
47 /*---------------------------------------------------------------------------*\
48 Class SphericalTensor2D Declaration
49 \*---------------------------------------------------------------------------*/
52 class SphericalTensor2D
54 public VectorSpace<SphericalTensor2D<Cmpt>, Cmpt, 1>
63 rank = 2 // Rank of SphericalTensor2D is 2
67 // Static data members
69 static const char* const typeName;
70 static const char* componentNames[];
71 static const SphericalTensor2D zero;
72 static const SphericalTensor2D one;
73 static const SphericalTensor2D max;
74 static const SphericalTensor2D min;
75 static const SphericalTensor2D I;
76 static const SphericalTensor2D oneThirdI;
77 static const SphericalTensor2D twoThirdsI;
80 //- Component labeling enumeration
81 enum components { II };
87 inline SphericalTensor2D();
89 //- Construct given VectorSpace
90 inline SphericalTensor2D
92 const VectorSpace<SphericalTensor2D<Cmpt>, Cmpt, 1>&
95 //- Construct given the component
96 inline SphericalTensor2D(const Cmpt& tii);
98 //- Construct from Istream
99 inline SphericalTensor2D(Istream&);
106 inline const Cmpt& ii() const;
111 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
113 } // End namespace Foam
115 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
117 // Include inline implementations
118 #include "SphericalTensor2DTemplateI.H"
120 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
124 // ************************************************************************* //