Loading...
Searching...
No Matches
SpatialTensorI.H
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) 2016 OpenFOAM Foundation
9-------------------------------------------------------------------------------
10License
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 "Identity.H"
29
30// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
31
32template<class Cmpt>
34:
36{}
37
38
39template<class Cmpt>
41(
42 const typename SpatialTensor::msType& ms
44:
46{}
47
48
49template<class Cmpt>
51(
52 const Tensor<Cmpt>& t00, const Tensor<Cmpt>& t01,
53 const Tensor<Cmpt>& t10, const Tensor<Cmpt>& t11
54)
55{
56 // Block (0, 0)
57 this->v_[0] = t00.xx(); this->v_[1] = t00.xy(); this->v_[2] = t00.xz();
58 this->v_[6] = t00.yx(); this->v_[7] = t00.yy(); this->v_[8] = t00.yz();
59 this->v_[12] = t00.zx(); this->v_[13] = t00.zy(); this->v_[14] = t00.zz();
60
61 // Block (0, 1)
62 this->v_[3] = t01.xx(); this->v_[4] = t01.xy(); this->v_[5] = t01.xz();
63 this->v_[9] = t01.yx(); this->v_[10] = t01.yy(); this->v_[11] = t01.yz();
64 this->v_[15] = t01.zx(); this->v_[16] = t01.zy(); this->v_[17] = t01.zz();
65
66 // Block (1, 0)
67 this->v_[18] = t10.xx(); this->v_[19] = t10.xy(); this->v_[20] = t10.xz();
68 this->v_[24] = t10.yx(); this->v_[25] = t10.yy(); this->v_[26] = t10.yz();
69 this->v_[30] = t10.zx(); this->v_[31] = t10.zy(); this->v_[32] = t10.zz();
70
71 // Block (1, 1)
72 this->v_[21] = t11.xx(); this->v_[22] = t11.xy(); this->v_[23] = t11.xz();
73 this->v_[27] = t11.yx(); this->v_[28] = t11.yy(); this->v_[29] = t11.yz();
74 this->v_[33] = t11.zx(); this->v_[34] = t11.zy(); this->v_[35] = t11.zz();
75}
76
77
78template<class Cmpt>
80(
81 const Cmpt& t00, const Cmpt& t01, const Cmpt& t02,
82 const Cmpt& t03, const Cmpt& t04, const Cmpt& t05,
83
84 const Cmpt& t10, const Cmpt& t11, const Cmpt& t12,
85 const Cmpt& t13, const Cmpt& t14, const Cmpt& t15,
86
87 const Cmpt& t20, const Cmpt& t21, const Cmpt& t22,
88 const Cmpt& t23, const Cmpt& t24, const Cmpt& t25,
89
90 const Cmpt& t30, const Cmpt& t31, const Cmpt& t32,
91 const Cmpt& t33, const Cmpt& t34, const Cmpt& t35,
92
93 const Cmpt& t40, const Cmpt& t41, const Cmpt& t42,
94 const Cmpt& t43, const Cmpt& t44, const Cmpt& t45,
95
96 const Cmpt& t50, const Cmpt& t51, const Cmpt& t52,
97 const Cmpt& t53, const Cmpt& t54, const Cmpt& t55
98)
99{
100 // Row 0
101 this->v_[0] = t00; this->v_[1] = t01; this->v_[2] = t02;
102 this->v_[3] = t03; this->v_[4] = t04; this->v_[5] = t05;
103
104 // Row 1
105 this->v_[6] = t10; this->v_[7] = t11; this->v_[8] = t12;
106 this->v_[9] = t13; this->v_[10] = t14; this->v_[11] = t15;
107
108 // Row 2
109 this->v_[12] = t20; this->v_[13] = t21; this->v_[14] = t22;
110 this->v_[15] = t23; this->v_[16] = t24; this->v_[17] = t25;
111
112 // Row 3
113 this->v_[18] = t30; this->v_[19] = t31; this->v_[20] = t32;
114 this->v_[21] = t33; this->v_[22] = t34; this->v_[23] = t35;
115
116 // Row 4
117 this->v_[24] = t40; this->v_[25] = t41; this->v_[26] = t42;
118 this->v_[27] = t43; this->v_[28] = t44; this->v_[29] = t45;
119
120 // Row 5
121 this->v_[30] = t50; this->v_[31] = t51; this->v_[32] = t52;
122 this->v_[33] = t53; this->v_[34] = t54; this->v_[35] = t55;
123}
124
125
126template<class Cmpt>
128:
129 SpatialTensor::msType(is)
130{}
131
132
133// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
134
135namespace Foam
136{
138// * * * * * * * * * * * * * * * Global Operators * * * * * * * * * * * * * //
139
140//- Return the cross-product tensor
141template<class Cmpt>
142inline Foam::SpatialTensor<Cmpt> operator^
143(
144 const SpatialVector<Cmpt>& v,
145 const Identity<Cmpt>&
146)
147{
149 (
150 0, -v.wz(), v.wy(), 0, 0, 0,
151 v.wz(), 0, -v.wx(), 0, 0, 0,
152 -v.wy(), v.wx(), 0, 0, 0, 0,
153 0, -v.lz(), v.ly(), 0, -v.wz(), v.wy(),
154 v.lz(), 0, -v.lx(), v.wz(), 0, -v.wx(),
155 -v.ly(), v.lx(), 0, -v.wy(), v.wx(), 0
156 );
157}
158
160//- Return the dual cross-product tensor
161template<class Cmpt>
162inline Foam::SpatialTensor<Cmpt> operator^
163(
164 const SpatialVector<Cmpt>& f,
165 const typename Identity<Cmpt>::dual&
166)
167{
169 (
170 0, -f.wz(), f.wy(), 0, -f.lz(), f.ly(),
171 f.wz(), 0, -f.wx(), f.lz(), 0, -f.lx(),
172 -f.wy(), f.wx(), 0, -f.ly(), f.lx(), 0,
173 0, 0, 0, 0, -f.wz(), f.wy(),
174 0, 0, 0, f.wz(), 0, -f.wx(),
175 0, 0, 0, -f.wy(), f.wx(), 0
176 );
177}
178
179
180// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
181
182} // End namespace Foam
183
184// ************************************************************************* //
The identity type in the dual space.
Definition Identity.H:63
Templated identity and dual space identity tensors derived from SphericalTensor.
Definition Identity.H:46
An Istream is an abstract base class for all input systems (streams, files, token lists etc)....
Definition Istream.H:60
MatrixSpace< SpatialTensor< Cmpt >, Cmpt, Mrows, Ncols > msType
Definition MatrixSpace.H:65
Templated 3D spatial tensor derived from MatrixSpace used to represent transformations of spatial vec...
SpatialTensor()=default
Default Construct.
Templated 3D spatial vector derived from VectorSpace used to represent the anglular and linear compon...
A templated (3 x 3) tensor of objects of <T> derived from MatrixSpace.
Definition Tensor.H:60
const Cmpt & yy() const noexcept
Definition Tensor.H:197
const Cmpt & zy() const noexcept
Definition Tensor.H:200
const Cmpt & yx() const noexcept
Definition Tensor.H:196
const Cmpt & xx() const noexcept
Definition Tensor.H:193
const Cmpt & yz() const noexcept
Definition Tensor.H:198
const Cmpt & zz() const noexcept
Definition Tensor.H:201
const Cmpt & xy() const noexcept
Definition Tensor.H:194
const Cmpt & xz() const noexcept
Definition Tensor.H:195
const Cmpt & zx() const noexcept
Definition Tensor.H:199
A class representing the concept of 0 (zero) that can be used to avoid manipulating objects known to ...
Definition zero.H:58
Namespace for OpenFOAM.
static constexpr const zero Zero
Global zero (0).
Definition zero.H:127
labelList f(nPoints)