doubleScalar.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) 2011-2015 OpenFOAM Foundation
9  Copyright (C) 2017-2019 OpenCFD Ltd.
10 -------------------------------------------------------------------------------
11 License
12  This file is part of OpenFOAM.
13 
14  OpenFOAM is free software: you can redistribute it and/or modify it
15  under the terms of the GNU General Public License as published by
16  the Free Software Foundation, either version 3 of the License, or
17  (at your option) any later version.
18 
19  OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
20  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
21  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
22  for more details.
23 
24  You should have received a copy of the GNU General Public License
25  along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
26 
27 Typedef
28  Foam::doubleScalar
29 
30 Description
31  Floating-point double precision scalar type.
32 
33 SourceFiles
34  doubleScalar.C
35 
36 \*---------------------------------------------------------------------------*/
37 
38 #ifndef doubleScalar_H
39 #define doubleScalar_H
40 
41 #include "doubleFloat.H"
42 #include "direction.H"
43 #include "word.H"
44 
45 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
46 
47 namespace Foam
48 {
49 
50 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
51 
52 typedef double doubleScalar;
53 
54 // Largest and smallest scalar values allowed in certain parts of the code.
55 // See std::numeric_limits max(), min(), epsilon()
56 constexpr doubleScalar doubleScalarGREAT = 1.0e+15;
57 constexpr doubleScalar doubleScalarVGREAT = 1.0e+300;
58 constexpr doubleScalar doubleScalarROOTVGREAT = 1.0e+150;
59 constexpr doubleScalar doubleScalarSMALL = 1.0e-15;
61 constexpr doubleScalar doubleScalarVSMALL = 1.0e-300;
62 constexpr doubleScalar doubleScalarROOTVSMALL = 1.0e-150;
63 
64 
65 #define Scalar doubleScalar
66 #define ScalarVGREAT doubleScalarVGREAT
67 #define ScalarVSMALL doubleScalarVSMALL
68 #define ScalarROOTVGREAT doubleScalarROOTVGREAT
69 #define ScalarROOTVSMALL doubleScalarROOTVSMALL
70 #define ScalarRead readDouble
71 
72 
73 inline Scalar mag(const Scalar s)
74 {
75  return ::fabs(s);
76 }
77 
78 inline Scalar hypot(const Scalar x, const Scalar y)
79 {
80  return ::hypot(x, y);
81 }
82 
83 inline Scalar atan2(const Scalar y, const Scalar x)
84 {
85  return ::atan2(y, x);
86 }
87 
88 
89 // Normal (double-precision) transcendental functions
90 #define transFunc(func) \
91 inline Scalar func(const Scalar s) \
92 { \
93  return ::func(s); \
94 }
95 
96 // Normal (double-precision) bessel functions.
97 // May not be available on all systems
98 #ifdef Foam_no_besselFunc
99  // Not available
100  #define besselFunc(func) \
101  inline Scalar func(const Scalar s) \
102  { \
103  std::cerr<< "No '" << #func << "' function\n"; \
104  return 0; \
105  }
106  #define besselFunc2(func) \
107  inline Scalar func(const int n, const Scalar s) \
108  { \
109  std::cerr<< "No '" << #func << "' function\n"; \
110  return 0; \
111  }
112 #elif defined(__MINGW32__)
113  // Mingw: with '_' prefix
114  #define besselFunc(func) \
115  inline Scalar func(const Scalar s) \
116  { \
117  return _##func(s); \
118  }
119  #define besselFunc2(func) \
120  inline Scalar func(const int n, const Scalar s) \
121  { \
122  return _##func(n, s); \
123  }
124 #else
125  #define besselFunc(func) \
126  inline Scalar func(const Scalar s) \
127  { \
128  return ::func(s); \
129  }
130  #define besselFunc2(func) \
131  inline Scalar func(const int n, const Scalar s) \
132  { \
133  return ::func(n, s); \
134  }
135 #endif
136 
137 
138 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
139 
140 } // End namespace Foam
141 
142 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
143 
144 #include "Scalar.H"
145 
146 #undef Scalar
147 #undef ScalarVGREAT
148 #undef ScalarVSMALL
149 #undef ScalarROOTVGREAT
150 #undef ScalarROOTVSMALL
151 #undef ScalarRead
152 #undef transFunc
153 #undef besselFunc
154 #undef besselFunc2
155 
156 
157 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
158 
159 #endif
160 
161 // ************************************************************************* //
Foam::doubleScalar
double doubleScalar
Floating-point double precision scalar type.
Definition: doubleScalar.H:52
Foam::doubleScalarROOTVGREAT
constexpr doubleScalar doubleScalarROOTVGREAT
Definition: doubleScalar.H:58
s
gmvFile<< "tracers "<< particles.size()<< nl;for(const passiveParticle &p :particles){ gmvFile<< p.position().x()<< " ";}gmvFile<< nl;for(const passiveParticle &p :particles){ gmvFile<< p.position().y()<< " ";}gmvFile<< nl;for(const passiveParticle &p :particles){ gmvFile<< p.position().z()<< " ";}gmvFile<< nl;forAll(lagrangianScalarNames, i){ word name=lagrangianScalarNames[i];IOField< scalar > s(IOobject(name, runTime.timeName(), cloud::prefix, mesh, IOobject::MUST_READ, IOobject::NO_WRITE))
Definition: gmvOutputSpray.H:25
doubleFloat.H
Foam::atan2
dimensionedScalar atan2(const dimensionedScalar &x, const dimensionedScalar &y)
Definition: dimensionedScalar.C:312
Foam::doubleScalarROOTSMALL
constexpr doubleScalar doubleScalarROOTSMALL
Definition: doubleScalar.H:60
Foam::doubleScalarSMALL
constexpr doubleScalar doubleScalarSMALL
Definition: doubleScalar.H:59
Foam::hypot
doubleScalar hypot(const doubleScalar x, const doubleScalar y)
Definition: doubleScalar.H:78
Foam::hypot
dimensionedScalar hypot(const dimensionedScalar &x, const dimensionedScalar &y)
Definition: dimensionedScalar.C:327
Foam::doubleScalarVGREAT
constexpr doubleScalar doubleScalarVGREAT
Definition: doubleScalar.H:57
Foam
Namespace for OpenFOAM.
Definition: atmBoundaryLayer.C:33
Foam::doubleScalarVSMALL
constexpr doubleScalar doubleScalarVSMALL
Definition: doubleScalar.H:61
direction.H
Direction is an 8-bit unsigned integer type used to represent the Cartesian directions etc.
Scalar
#define Scalar
Definition: doubleScalar.H:65
Foam::mag
dimensioned< typename typeOfMag< Type >::type > mag(const dimensioned< Type > &dt)
x
x
Definition: LISASMDCalcMethod2.H:52
Foam::atan2
doubleScalar atan2(const doubleScalar y, const doubleScalar x)
Definition: doubleScalar.H:83
Foam::doubleScalarROOTVSMALL
constexpr doubleScalar doubleScalarROOTVSMALL
Definition: doubleScalar.H:62
word.H
Foam::doubleScalarGREAT
constexpr doubleScalar doubleScalarGREAT
Definition: doubleScalar.H:56
Scalar.H
y
scalar y
Definition: LISASMDCalcMethod1.H:14