oneI.H
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------*\
2  ========= |
3  \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4  \\ / O peration | Website: https://openfoam.org
5  \\ / A nd | Copyright (C) 2011-2018 OpenFOAM Foundation
6  \\/ M anipulation |
7 -------------------------------------------------------------------------------
8 License
9  This file is part of OpenFOAM.
10 
11  OpenFOAM is free software: you can redistribute it and/or modify it
12  under the terms of the GNU General Public License as published by
13  the Free Software Foundation, either version 3 of the License, or
14  (at your option) any later version.
15 
16  OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
17  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
18  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
19  for more details.
20 
21  You should have received a copy of the GNU General Public License
22  along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
23 
24 \*---------------------------------------------------------------------------*/
25 
26 #include "one.H"
27 #include "scalar.H"
28 
29 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
30 
31 namespace Foam
32 {
33 
34 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
35 
36 template<class arg2>
37 class innerProduct<one, arg2>
38 {
39 public:
40 
41  typedef arg2 type;
42 };
43 
44 inline const one& operator*(const one& o, const one&)
45 {
46  return o;
47 }
48 
49 template<class Type>
50 inline const Type& operator*(const Type& t, const one&)
51 {
52  return t;
53 }
54 
55 template<class Type>
56 inline const Type& operator*(const one&, const Type& t)
57 {
58  return t;
59 }
60 
61 template<class Type>
62 inline const Type& operator&(const one&, const Type& t)
63 {
64  return t;
65 }
66 
67 inline const one& operator/(const one& o, const one&)
68 {
69  return o;
70 }
71 
72 template<class Type>
73 inline Type operator/(const one&, const Type& t)
74 {
75  return scalar(1)/t;
76 }
77 
78 template<class Type>
79 inline const Type& operator/(const Type& t, const one&)
80 {
81  return t;
82 }
83 
84 inline const one& min(const one& o, const one&)
85 {
86  return o;
87 }
88 
89 template<class Type>
90 inline Type min(const one&, const Type& t)
91 {
92  return min(scalar(1), t);
93 }
94 
95 template<class Type>
96 inline Type min(const Type& t, const one&)
97 {
98  return min(t, scalar(1));
99 }
100 
101 inline const one& max(const one& o, const one&)
102 {
103  return o;
104 }
105 
106 template<class Type>
107 inline Type max(const one&, const Type& t)
108 {
109  return max(scalar(1), t);
110 }
111 
112 template<class Type>
113 inline Type max(const Type& t, const one&)
114 {
115  return max(t, scalar(1));
116 }
117 
118 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
119 
120 } // End namespace Foam
121 
122 // ************************************************************************* //
dimensioned< Type > max(const dimensioned< Type > &, const dimensioned< Type > &)
dimensionedScalar operator/(const scalar s1, const dimensionedScalar &ds2)
tmp< GeometricField< Type, fvPatchField, volMesh > > operator &(const fvMatrix< Type > &, const DimensionedField< Type, volMesh > &)
tmp< fvMatrix< Type > > operator*(const volScalarField::Internal &, const fvMatrix< Type > &)
dimensioned< Type > min(const dimensioned< Type > &, const dimensioned< Type > &)
Namespace for OpenFOAM.
A class representing the concept of 1 (scalar(1)) used to avoid unnecessary manipulations for objects...
Definition: one.H:50