Where Online Learning is simpler!
The C and C++ Include Header Files
/usr/include/c++/13/numbers
$ cat -n /usr/include/c++/13/numbers 1 //
-*- C++ -*- 2 3 // Copyright (C) 2019-2023 Free Software Foundation, Inc. 4 // 5 // This file is part of the GNU ISO C++ Library. This library is free 6 // software; you can redistribute it and/or modify it under the 7 // terms of the GNU General Public License as published by the 8 // Free Software Foundation; either version 3, or (at your option) 9 // any later version. 10 11 // This library is distributed in the hope that it will be useful, 12 // but WITHOUT ANY WARRANTY; without even the implied warranty of 13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 14 // GNU General Public License for more details. 15 16 // Under Section 7 of GPL version 3, you are granted additional 17 // permissions described in the GCC Runtime Library Exception, version 18 // 3.1, as published by the Free Software Foundation. 19 20 // You should have received a copy of the GNU General Public License and 21 // a copy of the GCC Runtime Library Exception along with this program; 22 // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see 23 //
. 24 25 /** @file include/numbers 26 * This is a Standard C++ Library header. 27 */ 28 29 #ifndef _GLIBCXX_NUMBERS 30 #define _GLIBCXX_NUMBERS 1 31 32 #pragma GCC system_header 33 34 #if __cplusplus > 201703L 35 36 #include
37 38 namespace std _GLIBCXX_VISIBILITY(default) 39 { 40 _GLIBCXX_BEGIN_NAMESPACE_VERSION 41 42 /** @defgroup math_constants Mathematical constants 43 * @ingroup numerics 44 * @{ 45 */ 46 47 /// Namespace for mathematical constants 48 namespace numbers 49 { 50 #define __cpp_lib_math_constants 201907L 51 52 /// @cond undocumented 53 template
54 using _Enable_if_floating = enable_if_t
, _Tp>; 55 /// @endcond 56 57 /// e 58 template
59 inline constexpr _Tp e_v 60 = _Enable_if_floating<_Tp>(2.718281828459045235360287471352662498L); 61 62 /// log_2 e 63 template
64 inline constexpr _Tp log2e_v 65 = _Enable_if_floating<_Tp>(1.442695040888963407359924681001892137L); 66 67 /// log_10 e 68 template
69 inline constexpr _Tp log10e_v 70 = _Enable_if_floating<_Tp>(0.434294481903251827651128918916605082L); 71 72 /// pi 73 template
74 inline constexpr _Tp pi_v 75 = _Enable_if_floating<_Tp>(3.141592653589793238462643383279502884L); 76 77 /// 1/pi 78 template
79 inline constexpr _Tp inv_pi_v 80 = _Enable_if_floating<_Tp>(0.318309886183790671537767526745028724L); 81 82 /// 1/sqrt(pi) 83 template
84 inline constexpr _Tp inv_sqrtpi_v 85 = _Enable_if_floating<_Tp>(0.564189583547756286948079451560772586L); 86 87 /// log_e 2 88 template
89 inline constexpr _Tp ln2_v 90 = _Enable_if_floating<_Tp>(0.693147180559945309417232121458176568L); 91 92 /// log_e 10 93 template
94 inline constexpr _Tp ln10_v 95 = _Enable_if_floating<_Tp>(2.302585092994045684017991454684364208L); 96 97 /// sqrt(2) 98 template
99 inline constexpr _Tp sqrt2_v 100 = _Enable_if_floating<_Tp>(1.414213562373095048801688724209698079L); 101 102 /// sqrt(3) 103 template
104 inline constexpr _Tp sqrt3_v 105 = _Enable_if_floating<_Tp>(1.732050807568877293527446341505872367L); 106 107 /// 1/sqrt(3) 108 template
109 inline constexpr _Tp inv_sqrt3_v 110 = _Enable_if_floating<_Tp>(0.577350269189625764509148780501957456L); 111 112 /// The Euler-Mascheroni constant 113 template
114 inline constexpr _Tp egamma_v 115 = _Enable_if_floating<_Tp>(0.577215664901532860606512090082402431L); 116 117 /// The golden ratio, (1+sqrt(5))/2 118 template
119 inline constexpr _Tp phi_v 120 = _Enable_if_floating<_Tp>(1.618033988749894848204586834365638118L); 121 122 inline constexpr double e = e_v
; 123 inline constexpr double log2e = log2e_v
; 124 inline constexpr double log10e = log10e_v
; 125 inline constexpr double pi = pi_v
; 126 inline constexpr double inv_pi = inv_pi_v
; 127 inline constexpr double inv_sqrtpi = inv_sqrtpi_v
; 128 inline constexpr double ln2 = ln2_v
; 129 inline constexpr double ln10 = ln10_v
; 130 inline constexpr double sqrt2 = sqrt2_v
; 131 inline constexpr double sqrt3 = sqrt3_v
; 132 inline constexpr double inv_sqrt3 = inv_sqrt3_v
; 133 inline constexpr double egamma = egamma_v
; 134 inline constexpr double phi = phi_v
; 135 136 #define __glibcxx_numbers(TYPE, SUFFIX) \ 137 /* e */ \ 138 template<> \ 139 inline constexpr TYPE e_v
\ 140 = 2.718281828459045235360287471352662498##SUFFIX; \ 141 \ 142 /* log_2 e */ \ 143 template<> \ 144 inline constexpr TYPE log2e_v
\ 145 = 1.442695040888963407359924681001892137##SUFFIX; \ 146 \ 147 /* log_10 e */ \ 148 template<> \ 149 inline constexpr TYPE log10e_v
\ 150 = 0.434294481903251827651128918916605082##SUFFIX; \ 151 \ 152 /* pi */ \ 153 template<> \ 154 inline constexpr TYPE pi_v
\ 155 = 3.141592653589793238462643383279502884##SUFFIX; \ 156 \ 157 /* 1/pi */ \ 158 template<> \ 159 inline constexpr TYPE inv_pi_v
\ 160 = 0.318309886183790671537767526745028724##SUFFIX; \ 161 \ 162 /* 1/sqrt(pi) */ \ 163 template<> \ 164 inline constexpr TYPE inv_sqrtpi_v
\ 165 = 0.564189583547756286948079451560772586##SUFFIX; \ 166 \ 167 /* log_e 2 */ \ 168 template<> \ 169 inline constexpr TYPE ln2_v
\ 170 = 0.693147180559945309417232121458176568##SUFFIX; \ 171 \ 172 /* log_e 10 */ \ 173 template<> \ 174 inline constexpr TYPE ln10_v
\ 175 = 2.302585092994045684017991454684364208##SUFFIX; \ 176 \ 177 /* sqrt(2) */ \ 178 template<> \ 179 inline constexpr TYPE sqrt2_v
\ 180 = 1.414213562373095048801688724209698079##SUFFIX; \ 181 \ 182 /* sqrt(3) */ \ 183 template<> \ 184 inline constexpr TYPE sqrt3_v
\ 185 = 1.732050807568877293527446341505872367##SUFFIX; \ 186 \ 187 /* 1/sqrt(3) */ \ 188 template<> \ 189 inline constexpr TYPE inv_sqrt3_v
\ 190 = 0.577350269189625764509148780501957456##SUFFIX; \ 191 \ 192 /* The Euler-Mascheroni constant */ \ 193 template<> \ 194 inline constexpr TYPE egamma_v
\ 195 = 0.577215664901532860606512090082402431##SUFFIX; \ 196 \ 197 /* The golden ratio, (1+sqrt(5))/2 */ \ 198 template<> \ 199 inline constexpr TYPE phi_v
\ 200 = 1.618033988749894848204586834365638118##SUFFIX 201 202 #ifdef __STDCPP_FLOAT16_T__ 203 __glibcxx_numbers (_Float16, F16); 204 #endif 205 206 #ifdef __STDCPP_FLOAT32_T__ 207 __glibcxx_numbers (_Float32, F32); 208 #endif 209 210 #ifdef __STDCPP_FLOAT64_T__ 211 __glibcxx_numbers (_Float64, F64); 212 #endif 213 214 #ifdef __STDCPP_FLOAT128_T__ 215 __glibcxx_numbers (_Float128, F128); 216 #endif 217 218 #ifdef __STDCPP_BFLOAT128_T__ 219 __glibcxx_numbers (__gnu_cxx::__bfloat16_t, BF16); 220 #endif 221 222 #if !defined(__STRICT_ANSI__) && defined(_GLIBCXX_USE_FLOAT128) && !defined(__CUDACC__) 223 __glibcxx_numbers (__float128, Q); 224 #endif // USE_FLOAT128 225 226 #undef __glibcxx_numbers 227 228 } // namespace numbers 229 /// @} 230 _GLIBCXX_END_NAMESPACE_VERSION 231 } // namespace std 232 233 #endif // C++20 234 #endif // _GLIBCXX_NUMBERS
Contact us
|
About us
|
Term of use
|
Copyright © 2000-2025 MyWebUniversity.com ™