floatScalar.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-2020 OpenCFD Ltd.
10-------------------------------------------------------------------------------
11License
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
27Typedef
28 Foam::floatScalar
29
30Description
31 Floating-point single precision scalar type.
32
33SourceFiles
34 floatScalar.C
35
36\*---------------------------------------------------------------------------*/
37
38#ifndef floatScalar_H
39#define floatScalar_H
40
41#include "scalarFwd.H"
42#include "doubleFloat.H"
43#include "direction.H"
44#include "word.H"
45
46// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
47
48// Typedef (floatScalar) in scalarFwd.H
49
50namespace Foam
51{
52
53// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
54
55// Largest and smallest scalar values allowed in certain parts of the code.
56// See std::numeric_limits max(), min(), epsilon()
57constexpr floatScalar floatScalarGREAT = 1.0e+6;
59constexpr floatScalar floatScalarVGREAT = 1.0e+37;
61constexpr floatScalar floatScalarSMALL = 1.0e-6;
63constexpr floatScalar floatScalarVSMALL = 1.0e-37;
65
66
67#define Scalar floatScalar
68#define ScalarVGREAT floatScalarVGREAT
69#define ScalarVSMALL floatScalarVSMALL
70#define ScalarROOTVGREAT floatScalarROOTVGREAT
71#define ScalarROOTVSMALL floatScalarROOTVSMALL
72#define ScalarRead readFloat
73
74
75inline Scalar mag(const Scalar s)
76{
77 return ::fabsf(s);
78}
79
80inline Scalar hypot(const Scalar x, const Scalar y)
81{
82 return ::hypotf(x, y);
83}
84
85inline Scalar atan2(const Scalar y, const Scalar x)
86{
87 return ::atan2f(y, x);
88}
89
90// Single-precision transcendental functions (with 'f' appended to the name)
91#define transFunc(func) \
92inline Scalar func(const Scalar s) \
93{ \
94 return ::func##f(s); \
95}
96
97
98// Single-precision bessel functions.
99// May not be available on all systems
100#ifdef Foam_no_besselFunc
101 // Not available
102 #define besselFunc(func) \
103 inline Scalar func(const Scalar s) \
104 { \
105 std::cerr<< "No '" << #func << "' function\n"; \
106 return 0; \
107 }
108 #define besselFunc2(func) \
109 inline Scalar func(const int n, const Scalar s) \
110 { \
111 std::cerr<< "No '" << #func << "' function\n"; \
112 return 0; \
113 }
114#elif defined(__APPLE__)
115 // Darwin: no float version (use a cast)
116 #define besselFunc(func) \
117 inline Scalar func(const Scalar s) \
118 { \
119 return ::func(s); \
120 }
121 #define besselFunc2(func) \
122 inline Scalar func(const int n, const Scalar s) \
123 { \
124 return Scalar(::func(n, double(s))); \
125 }
126#elif defined(__MINGW32__)
127 // Mingw: with '_' prefix, no float version (use a cast)
128 #define besselFunc(func) \
129 inline Scalar func(const Scalar s) \
130 { \
131 return _##func(s); \
132 }
133 #define besselFunc2(func) \
134 inline Scalar func(const int n, const Scalar s) \
135 { \
136 return Scalar(_##func(n, double(s))); \
137 }
138#else
139 // With 'f' (float) appended to the name
140 #define besselFunc(func) \
141 inline Scalar func(const Scalar s) \
142 { \
143 return ::func##f(s); \
144 }
145 #define besselFunc2(func) \
146 inline Scalar func(const int n, const Scalar s) \
147 { \
148 return ::func##f(n, s); \
149 }
150#endif
151
152
153// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
154
155} // End namespace Foam
156
157// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
158
159#include "Scalar.H"
160
161#undef Scalar
162#undef ScalarVGREAT
163#undef ScalarVSMALL
164#undef ScalarROOTVGREAT
165#undef ScalarROOTVSMALL
166#undef ScalarRead
167#undef transFunc
168#undef besselFunc
169#undef besselFunc2
170
171
172// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
173
174#endif
175
176// ************************************************************************* //
scalar y
Direction is an 8-bit unsigned integer type used to represent Cartesian directions,...
#define Scalar
Definition: doubleScalar.C:41
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))
Namespace for OpenFOAM.
constexpr floatScalar floatScalarVGREAT
Definition: floatScalar.H:59
constexpr floatScalar floatScalarGREAT
Definition: floatScalar.H:57
constexpr floatScalar floatScalarROOTVGREAT
Definition: floatScalar.H:60
constexpr floatScalar floatScalarROOTVSMALL
Definition: floatScalar.H:64
constexpr floatScalar floatScalarSMALL
Definition: floatScalar.H:61
dimensionedScalar atan2(const dimensionedScalar &x, const dimensionedScalar &y)
dimensioned< typename typeOfMag< Type >::type > mag(const dimensioned< Type > &dt)
dimensionedScalar hypot(const dimensionedScalar &x, const dimensionedScalar &y)
float floatScalar
A typedef for float.
Definition: scalarFwd.H:45
constexpr floatScalar floatScalarROOTSMALL
Definition: floatScalar.H:62
constexpr floatScalar floatScalarVSMALL
Definition: floatScalar.H:63
constexpr floatScalar floatScalarROOTGREAT
Definition: floatScalar.H:58
Typedefs for float/double/scalar without requiring scalar.H.