math.h 52 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763
  1. // -*- C++ -*-
  2. //===----------------------------------------------------------------------===//
  3. //
  4. // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
  5. // See https://llvm.org/LICENSE.txt for license information.
  6. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  7. //
  8. //===----------------------------------------------------------------------===//
  9. #ifndef _LIBCPP_MATH_H
  10. #define _LIBCPP_MATH_H
  11. /*
  12. math.h synopsis
  13. Macros:
  14. HUGE_VAL
  15. HUGE_VALF // C99
  16. HUGE_VALL // C99
  17. INFINITY // C99
  18. NAN // C99
  19. FP_INFINITE // C99
  20. FP_NAN // C99
  21. FP_NORMAL // C99
  22. FP_SUBNORMAL // C99
  23. FP_ZERO // C99
  24. FP_FAST_FMA // C99
  25. FP_FAST_FMAF // C99
  26. FP_FAST_FMAL // C99
  27. FP_ILOGB0 // C99
  28. FP_ILOGBNAN // C99
  29. MATH_ERRNO // C99
  30. MATH_ERREXCEPT // C99
  31. math_errhandling // C99
  32. Types:
  33. float_t // C99
  34. double_t // C99
  35. // C90
  36. floating_point abs(floating_point x);
  37. floating_point acos (arithmetic x);
  38. float acosf(float x);
  39. long double acosl(long double x);
  40. floating_point asin (arithmetic x);
  41. float asinf(float x);
  42. long double asinl(long double x);
  43. floating_point atan (arithmetic x);
  44. float atanf(float x);
  45. long double atanl(long double x);
  46. floating_point atan2 (arithmetic y, arithmetic x);
  47. float atan2f(float y, float x);
  48. long double atan2l(long double y, long double x);
  49. floating_point ceil (arithmetic x);
  50. float ceilf(float x);
  51. long double ceill(long double x);
  52. floating_point cos (arithmetic x);
  53. float cosf(float x);
  54. long double cosl(long double x);
  55. floating_point cosh (arithmetic x);
  56. float coshf(float x);
  57. long double coshl(long double x);
  58. floating_point exp (arithmetic x);
  59. float expf(float x);
  60. long double expl(long double x);
  61. floating_point fabs (arithmetic x);
  62. float fabsf(float x);
  63. long double fabsl(long double x);
  64. floating_point floor (arithmetic x);
  65. float floorf(float x);
  66. long double floorl(long double x);
  67. floating_point fmod (arithmetic x, arithmetic y);
  68. float fmodf(float x, float y);
  69. long double fmodl(long double x, long double y);
  70. floating_point frexp (arithmetic value, int* exp);
  71. float frexpf(float value, int* exp);
  72. long double frexpl(long double value, int* exp);
  73. floating_point ldexp (arithmetic value, int exp);
  74. float ldexpf(float value, int exp);
  75. long double ldexpl(long double value, int exp);
  76. floating_point log (arithmetic x);
  77. float logf(float x);
  78. long double logl(long double x);
  79. floating_point log10 (arithmetic x);
  80. float log10f(float x);
  81. long double log10l(long double x);
  82. floating_point modf (floating_point value, floating_point* iptr);
  83. float modff(float value, float* iptr);
  84. long double modfl(long double value, long double* iptr);
  85. floating_point pow (arithmetic x, arithmetic y);
  86. float powf(float x, float y);
  87. long double powl(long double x, long double y);
  88. floating_point sin (arithmetic x);
  89. float sinf(float x);
  90. long double sinl(long double x);
  91. floating_point sinh (arithmetic x);
  92. float sinhf(float x);
  93. long double sinhl(long double x);
  94. floating_point sqrt (arithmetic x);
  95. float sqrtf(float x);
  96. long double sqrtl(long double x);
  97. floating_point tan (arithmetic x);
  98. float tanf(float x);
  99. long double tanl(long double x);
  100. floating_point tanh (arithmetic x);
  101. float tanhf(float x);
  102. long double tanhl(long double x);
  103. // C99
  104. bool signbit(arithmetic x);
  105. int fpclassify(arithmetic x);
  106. bool isfinite(arithmetic x);
  107. bool isinf(arithmetic x);
  108. bool isnan(arithmetic x);
  109. bool isnormal(arithmetic x);
  110. bool isgreater(arithmetic x, arithmetic y);
  111. bool isgreaterequal(arithmetic x, arithmetic y);
  112. bool isless(arithmetic x, arithmetic y);
  113. bool islessequal(arithmetic x, arithmetic y);
  114. bool islessgreater(arithmetic x, arithmetic y);
  115. bool isunordered(arithmetic x, arithmetic y);
  116. floating_point acosh (arithmetic x);
  117. float acoshf(float x);
  118. long double acoshl(long double x);
  119. floating_point asinh (arithmetic x);
  120. float asinhf(float x);
  121. long double asinhl(long double x);
  122. floating_point atanh (arithmetic x);
  123. float atanhf(float x);
  124. long double atanhl(long double x);
  125. floating_point cbrt (arithmetic x);
  126. float cbrtf(float x);
  127. long double cbrtl(long double x);
  128. floating_point copysign (arithmetic x, arithmetic y);
  129. float copysignf(float x, float y);
  130. long double copysignl(long double x, long double y);
  131. floating_point erf (arithmetic x);
  132. float erff(float x);
  133. long double erfl(long double x);
  134. floating_point erfc (arithmetic x);
  135. float erfcf(float x);
  136. long double erfcl(long double x);
  137. floating_point exp2 (arithmetic x);
  138. float exp2f(float x);
  139. long double exp2l(long double x);
  140. floating_point expm1 (arithmetic x);
  141. float expm1f(float x);
  142. long double expm1l(long double x);
  143. floating_point fdim (arithmetic x, arithmetic y);
  144. float fdimf(float x, float y);
  145. long double fdiml(long double x, long double y);
  146. floating_point fma (arithmetic x, arithmetic y, arithmetic z);
  147. float fmaf(float x, float y, float z);
  148. long double fmal(long double x, long double y, long double z);
  149. floating_point fmax (arithmetic x, arithmetic y);
  150. float fmaxf(float x, float y);
  151. long double fmaxl(long double x, long double y);
  152. floating_point fmin (arithmetic x, arithmetic y);
  153. float fminf(float x, float y);
  154. long double fminl(long double x, long double y);
  155. floating_point hypot (arithmetic x, arithmetic y);
  156. float hypotf(float x, float y);
  157. long double hypotl(long double x, long double y);
  158. int ilogb (arithmetic x);
  159. int ilogbf(float x);
  160. int ilogbl(long double x);
  161. floating_point lgamma (arithmetic x);
  162. float lgammaf(float x);
  163. long double lgammal(long double x);
  164. long long llrint (arithmetic x);
  165. long long llrintf(float x);
  166. long long llrintl(long double x);
  167. long long llround (arithmetic x);
  168. long long llroundf(float x);
  169. long long llroundl(long double x);
  170. floating_point log1p (arithmetic x);
  171. float log1pf(float x);
  172. long double log1pl(long double x);
  173. floating_point log2 (arithmetic x);
  174. float log2f(float x);
  175. long double log2l(long double x);
  176. floating_point logb (arithmetic x);
  177. float logbf(float x);
  178. long double logbl(long double x);
  179. long lrint (arithmetic x);
  180. long lrintf(float x);
  181. long lrintl(long double x);
  182. long lround (arithmetic x);
  183. long lroundf(float x);
  184. long lroundl(long double x);
  185. double nan (const char* str);
  186. float nanf(const char* str);
  187. long double nanl(const char* str);
  188. floating_point nearbyint (arithmetic x);
  189. float nearbyintf(float x);
  190. long double nearbyintl(long double x);
  191. floating_point nextafter (arithmetic x, arithmetic y);
  192. float nextafterf(float x, float y);
  193. long double nextafterl(long double x, long double y);
  194. floating_point nexttoward (arithmetic x, long double y);
  195. float nexttowardf(float x, long double y);
  196. long double nexttowardl(long double x, long double y);
  197. floating_point remainder (arithmetic x, arithmetic y);
  198. float remainderf(float x, float y);
  199. long double remainderl(long double x, long double y);
  200. floating_point remquo (arithmetic x, arithmetic y, int* pquo);
  201. float remquof(float x, float y, int* pquo);
  202. long double remquol(long double x, long double y, int* pquo);
  203. floating_point rint (arithmetic x);
  204. float rintf(float x);
  205. long double rintl(long double x);
  206. floating_point round (arithmetic x);
  207. float roundf(float x);
  208. long double roundl(long double x);
  209. floating_point scalbln (arithmetic x, long ex);
  210. float scalblnf(float x, long ex);
  211. long double scalblnl(long double x, long ex);
  212. floating_point scalbn (arithmetic x, int ex);
  213. float scalbnf(float x, int ex);
  214. long double scalbnl(long double x, int ex);
  215. floating_point tgamma (arithmetic x);
  216. float tgammaf(float x);
  217. long double tgammal(long double x);
  218. floating_point trunc (arithmetic x);
  219. float truncf(float x);
  220. long double truncl(long double x);
  221. */
  222. #include <__config>
  223. #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
  224. # pragma GCC system_header
  225. #endif
  226. #include_next <math.h>
  227. #ifdef __cplusplus
  228. // We support including .h headers inside 'extern "C"' contexts, so switch
  229. // back to C++ linkage before including these C++ headers.
  230. extern "C++" {
  231. #include <limits>
  232. #include <stdlib.h>
  233. #include <type_traits>
  234. // signbit
  235. #ifdef signbit
  236. template <class _A1>
  237. _LIBCPP_INLINE_VISIBILITY
  238. bool
  239. __libcpp_signbit(_A1 __lcpp_x) _NOEXCEPT
  240. {
  241. #if __has_builtin(__builtin_signbit)
  242. return __builtin_signbit(__lcpp_x);
  243. #else
  244. return signbit(__lcpp_x);
  245. #endif
  246. }
  247. #undef signbit
  248. template <class _A1>
  249. inline _LIBCPP_INLINE_VISIBILITY
  250. typename std::enable_if<std::is_floating_point<_A1>::value, bool>::type
  251. signbit(_A1 __lcpp_x) _NOEXCEPT
  252. {
  253. return __libcpp_signbit((typename std::__promote<_A1>::type)__lcpp_x);
  254. }
  255. template <class _A1>
  256. inline _LIBCPP_INLINE_VISIBILITY
  257. typename std::enable_if<
  258. std::is_integral<_A1>::value && std::is_signed<_A1>::value, bool>::type
  259. signbit(_A1 __lcpp_x) _NOEXCEPT
  260. { return __lcpp_x < 0; }
  261. template <class _A1>
  262. inline _LIBCPP_INLINE_VISIBILITY
  263. typename std::enable_if<
  264. std::is_integral<_A1>::value && !std::is_signed<_A1>::value, bool>::type
  265. signbit(_A1) _NOEXCEPT
  266. { return false; }
  267. #elif defined(_LIBCPP_MSVCRT)
  268. template <typename _A1>
  269. inline _LIBCPP_INLINE_VISIBILITY
  270. typename std::enable_if<std::is_floating_point<_A1>::value, bool>::type
  271. signbit(_A1 __lcpp_x) _NOEXCEPT
  272. {
  273. return ::signbit(static_cast<typename std::__promote<_A1>::type>(__lcpp_x));
  274. }
  275. template <class _A1>
  276. inline _LIBCPP_INLINE_VISIBILITY
  277. typename std::enable_if<
  278. std::is_integral<_A1>::value && std::is_signed<_A1>::value, bool>::type
  279. signbit(_A1 __lcpp_x) _NOEXCEPT
  280. { return __lcpp_x < 0; }
  281. template <class _A1>
  282. inline _LIBCPP_INLINE_VISIBILITY
  283. typename std::enable_if<
  284. std::is_integral<_A1>::value && !std::is_signed<_A1>::value, bool>::type
  285. signbit(_A1) _NOEXCEPT
  286. { return false; }
  287. #endif // signbit
  288. // fpclassify
  289. #ifdef fpclassify
  290. template <class _A1>
  291. _LIBCPP_INLINE_VISIBILITY
  292. int
  293. __libcpp_fpclassify(_A1 __lcpp_x) _NOEXCEPT
  294. {
  295. #if __has_builtin(__builtin_fpclassify)
  296. return __builtin_fpclassify(FP_NAN, FP_INFINITE, FP_NORMAL, FP_SUBNORMAL,
  297. FP_ZERO, __lcpp_x);
  298. #else
  299. return fpclassify(__lcpp_x);
  300. #endif
  301. }
  302. #undef fpclassify
  303. template <class _A1>
  304. inline _LIBCPP_INLINE_VISIBILITY
  305. typename std::enable_if<std::is_floating_point<_A1>::value, int>::type
  306. fpclassify(_A1 __lcpp_x) _NOEXCEPT
  307. {
  308. return __libcpp_fpclassify((typename std::__promote<_A1>::type)__lcpp_x);
  309. }
  310. template <class _A1>
  311. inline _LIBCPP_INLINE_VISIBILITY
  312. typename std::enable_if<std::is_integral<_A1>::value, int>::type
  313. fpclassify(_A1 __lcpp_x) _NOEXCEPT
  314. { return __lcpp_x == 0 ? FP_ZERO : FP_NORMAL; }
  315. #elif defined(_LIBCPP_MSVCRT)
  316. template <typename _A1>
  317. inline _LIBCPP_INLINE_VISIBILITY
  318. typename std::enable_if<std::is_floating_point<_A1>::value, bool>::type
  319. fpclassify(_A1 __lcpp_x) _NOEXCEPT
  320. {
  321. return ::fpclassify(static_cast<typename std::__promote<_A1>::type>(__lcpp_x));
  322. }
  323. template <class _A1>
  324. inline _LIBCPP_INLINE_VISIBILITY
  325. typename std::enable_if<std::is_integral<_A1>::value, int>::type
  326. fpclassify(_A1 __lcpp_x) _NOEXCEPT
  327. { return __lcpp_x == 0 ? FP_ZERO : FP_NORMAL; }
  328. #endif // fpclassify
  329. // isfinite
  330. #ifdef isfinite
  331. template <class _A1>
  332. _LIBCPP_INLINE_VISIBILITY
  333. bool
  334. __libcpp_isfinite(_A1 __lcpp_x) _NOEXCEPT
  335. {
  336. #if __has_builtin(__builtin_isfinite)
  337. return __builtin_isfinite(__lcpp_x);
  338. #else
  339. return isfinite(__lcpp_x);
  340. #endif
  341. }
  342. #undef isfinite
  343. template <class _A1>
  344. inline _LIBCPP_INLINE_VISIBILITY
  345. typename std::enable_if<
  346. std::is_arithmetic<_A1>::value && std::numeric_limits<_A1>::has_infinity,
  347. bool>::type
  348. isfinite(_A1 __lcpp_x) _NOEXCEPT
  349. {
  350. return __libcpp_isfinite((typename std::__promote<_A1>::type)__lcpp_x);
  351. }
  352. template <class _A1>
  353. inline _LIBCPP_INLINE_VISIBILITY
  354. typename std::enable_if<
  355. std::is_arithmetic<_A1>::value && !std::numeric_limits<_A1>::has_infinity,
  356. bool>::type
  357. isfinite(_A1) _NOEXCEPT
  358. { return true; }
  359. #endif // isfinite
  360. // isinf
  361. #ifdef isinf
  362. template <class _A1>
  363. _LIBCPP_INLINE_VISIBILITY
  364. bool
  365. __libcpp_isinf(_A1 __lcpp_x) _NOEXCEPT
  366. {
  367. #if __has_builtin(__builtin_isinf)
  368. return __builtin_isinf(__lcpp_x);
  369. #else
  370. return isinf(__lcpp_x);
  371. #endif
  372. }
  373. #undef isinf
  374. template <class _A1>
  375. inline _LIBCPP_INLINE_VISIBILITY
  376. typename std::enable_if<
  377. std::is_arithmetic<_A1>::value && std::numeric_limits<_A1>::has_infinity,
  378. bool>::type
  379. isinf(_A1 __lcpp_x) _NOEXCEPT
  380. {
  381. return __libcpp_isinf((typename std::__promote<_A1>::type)__lcpp_x);
  382. }
  383. template <class _A1>
  384. inline _LIBCPP_INLINE_VISIBILITY
  385. typename std::enable_if<
  386. std::is_arithmetic<_A1>::value && !std::numeric_limits<_A1>::has_infinity,
  387. bool>::type
  388. isinf(_A1) _NOEXCEPT
  389. { return false; }
  390. #if defined(_LIBCPP_PREFERRED_OVERLOAD) && !defined(__CUDACC__)
  391. inline _LIBCPP_INLINE_VISIBILITY
  392. bool
  393. isinf(float __lcpp_x) _NOEXCEPT { return __libcpp_isinf(__lcpp_x); }
  394. inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_PREFERRED_OVERLOAD
  395. bool
  396. isinf(double __lcpp_x) _NOEXCEPT { return __libcpp_isinf(__lcpp_x); }
  397. inline _LIBCPP_INLINE_VISIBILITY
  398. bool
  399. isinf(long double __lcpp_x) _NOEXCEPT { return __libcpp_isinf(__lcpp_x); }
  400. #endif
  401. #endif // isinf
  402. // isnan
  403. #ifdef isnan
  404. template <class _A1>
  405. _LIBCPP_INLINE_VISIBILITY
  406. bool
  407. __libcpp_isnan(_A1 __lcpp_x) _NOEXCEPT
  408. {
  409. #if __has_builtin(__builtin_isnan)
  410. return __builtin_isnan(__lcpp_x);
  411. #else
  412. return isnan(__lcpp_x);
  413. #endif
  414. }
  415. #undef isnan
  416. template <class _A1>
  417. inline _LIBCPP_INLINE_VISIBILITY
  418. typename std::enable_if<std::is_floating_point<_A1>::value, bool>::type
  419. isnan(_A1 __lcpp_x) _NOEXCEPT
  420. {
  421. return __libcpp_isnan((typename std::__promote<_A1>::type)__lcpp_x);
  422. }
  423. template <class _A1>
  424. inline _LIBCPP_INLINE_VISIBILITY
  425. typename std::enable_if<std::is_integral<_A1>::value, bool>::type
  426. isnan(_A1) _NOEXCEPT
  427. { return false; }
  428. #if defined(_LIBCPP_PREFERRED_OVERLOAD) && !defined(__CUDACC__)
  429. inline _LIBCPP_INLINE_VISIBILITY
  430. bool
  431. isnan(float __lcpp_x) _NOEXCEPT { return __libcpp_isnan(__lcpp_x); }
  432. inline _LIBCPP_INLINE_VISIBILITY _LIBCPP_PREFERRED_OVERLOAD
  433. bool
  434. isnan(double __lcpp_x) _NOEXCEPT { return __libcpp_isnan(__lcpp_x); }
  435. inline _LIBCPP_INLINE_VISIBILITY
  436. bool
  437. isnan(long double __lcpp_x) _NOEXCEPT { return __libcpp_isnan(__lcpp_x); }
  438. #endif
  439. #endif // isnan
  440. // isnormal
  441. #ifdef isnormal
  442. template <class _A1>
  443. _LIBCPP_INLINE_VISIBILITY
  444. bool
  445. __libcpp_isnormal(_A1 __lcpp_x) _NOEXCEPT
  446. {
  447. #if __has_builtin(__builtin_isnormal)
  448. return __builtin_isnormal(__lcpp_x);
  449. #else
  450. return isnormal(__lcpp_x);
  451. #endif
  452. }
  453. #undef isnormal
  454. template <class _A1>
  455. inline _LIBCPP_INLINE_VISIBILITY
  456. typename std::enable_if<std::is_floating_point<_A1>::value, bool>::type
  457. isnormal(_A1 __lcpp_x) _NOEXCEPT
  458. {
  459. return __libcpp_isnormal((typename std::__promote<_A1>::type)__lcpp_x);
  460. }
  461. template <class _A1>
  462. inline _LIBCPP_INLINE_VISIBILITY
  463. typename std::enable_if<std::is_integral<_A1>::value, bool>::type
  464. isnormal(_A1 __lcpp_x) _NOEXCEPT
  465. { return __lcpp_x != 0; }
  466. #endif // isnormal
  467. // isgreater
  468. #ifdef isgreater
  469. template <class _A1, class _A2>
  470. _LIBCPP_INLINE_VISIBILITY
  471. bool
  472. __libcpp_isgreater(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  473. {
  474. return isgreater(__lcpp_x, __lcpp_y);
  475. }
  476. #undef isgreater
  477. template <class _A1, class _A2>
  478. inline _LIBCPP_INLINE_VISIBILITY
  479. typename std::enable_if
  480. <
  481. std::is_arithmetic<_A1>::value &&
  482. std::is_arithmetic<_A2>::value,
  483. bool
  484. >::type
  485. isgreater(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  486. {
  487. typedef typename std::__promote<_A1, _A2>::type type;
  488. return __libcpp_isgreater((type)__lcpp_x, (type)__lcpp_y);
  489. }
  490. #endif // isgreater
  491. // isgreaterequal
  492. #ifdef isgreaterequal
  493. template <class _A1, class _A2>
  494. _LIBCPP_INLINE_VISIBILITY
  495. bool
  496. __libcpp_isgreaterequal(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  497. {
  498. return isgreaterequal(__lcpp_x, __lcpp_y);
  499. }
  500. #undef isgreaterequal
  501. template <class _A1, class _A2>
  502. inline _LIBCPP_INLINE_VISIBILITY
  503. typename std::enable_if
  504. <
  505. std::is_arithmetic<_A1>::value &&
  506. std::is_arithmetic<_A2>::value,
  507. bool
  508. >::type
  509. isgreaterequal(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  510. {
  511. typedef typename std::__promote<_A1, _A2>::type type;
  512. return __libcpp_isgreaterequal((type)__lcpp_x, (type)__lcpp_y);
  513. }
  514. #endif // isgreaterequal
  515. // isless
  516. #ifdef isless
  517. template <class _A1, class _A2>
  518. _LIBCPP_INLINE_VISIBILITY
  519. bool
  520. __libcpp_isless(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  521. {
  522. return isless(__lcpp_x, __lcpp_y);
  523. }
  524. #undef isless
  525. template <class _A1, class _A2>
  526. inline _LIBCPP_INLINE_VISIBILITY
  527. typename std::enable_if
  528. <
  529. std::is_arithmetic<_A1>::value &&
  530. std::is_arithmetic<_A2>::value,
  531. bool
  532. >::type
  533. isless(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  534. {
  535. typedef typename std::__promote<_A1, _A2>::type type;
  536. return __libcpp_isless((type)__lcpp_x, (type)__lcpp_y);
  537. }
  538. #endif // isless
  539. // islessequal
  540. #ifdef islessequal
  541. template <class _A1, class _A2>
  542. _LIBCPP_INLINE_VISIBILITY
  543. bool
  544. __libcpp_islessequal(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  545. {
  546. return islessequal(__lcpp_x, __lcpp_y);
  547. }
  548. #undef islessequal
  549. template <class _A1, class _A2>
  550. inline _LIBCPP_INLINE_VISIBILITY
  551. typename std::enable_if
  552. <
  553. std::is_arithmetic<_A1>::value &&
  554. std::is_arithmetic<_A2>::value,
  555. bool
  556. >::type
  557. islessequal(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  558. {
  559. typedef typename std::__promote<_A1, _A2>::type type;
  560. return __libcpp_islessequal((type)__lcpp_x, (type)__lcpp_y);
  561. }
  562. #endif // islessequal
  563. // islessgreater
  564. #ifdef islessgreater
  565. template <class _A1, class _A2>
  566. _LIBCPP_INLINE_VISIBILITY
  567. bool
  568. __libcpp_islessgreater(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  569. {
  570. return islessgreater(__lcpp_x, __lcpp_y);
  571. }
  572. #undef islessgreater
  573. template <class _A1, class _A2>
  574. inline _LIBCPP_INLINE_VISIBILITY
  575. typename std::enable_if
  576. <
  577. std::is_arithmetic<_A1>::value &&
  578. std::is_arithmetic<_A2>::value,
  579. bool
  580. >::type
  581. islessgreater(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  582. {
  583. typedef typename std::__promote<_A1, _A2>::type type;
  584. return __libcpp_islessgreater((type)__lcpp_x, (type)__lcpp_y);
  585. }
  586. #endif // islessgreater
  587. // isunordered
  588. #ifdef isunordered
  589. template <class _A1, class _A2>
  590. _LIBCPP_INLINE_VISIBILITY
  591. bool
  592. __libcpp_isunordered(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  593. {
  594. return isunordered(__lcpp_x, __lcpp_y);
  595. }
  596. #undef isunordered
  597. template <class _A1, class _A2>
  598. inline _LIBCPP_INLINE_VISIBILITY
  599. typename std::enable_if
  600. <
  601. std::is_arithmetic<_A1>::value &&
  602. std::is_arithmetic<_A2>::value,
  603. bool
  604. >::type
  605. isunordered(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  606. {
  607. typedef typename std::__promote<_A1, _A2>::type type;
  608. return __libcpp_isunordered((type)__lcpp_x, (type)__lcpp_y);
  609. }
  610. #endif // isunordered
  611. // abs
  612. //
  613. // handled in stdlib.h
  614. // div
  615. //
  616. // handled in stdlib.h
  617. // acos
  618. # if !defined(__sun__)
  619. inline _LIBCPP_INLINE_VISIBILITY float acos(float __lcpp_x) _NOEXCEPT {return ::acosf(__lcpp_x);}
  620. inline _LIBCPP_INLINE_VISIBILITY long double acos(long double __lcpp_x) _NOEXCEPT {return ::acosl(__lcpp_x);}
  621. # endif
  622. template <class _A1>
  623. inline _LIBCPP_INLINE_VISIBILITY
  624. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  625. acos(_A1 __lcpp_x) _NOEXCEPT {return ::acos((double)__lcpp_x);}
  626. // asin
  627. # if !defined(__sun__)
  628. inline _LIBCPP_INLINE_VISIBILITY float asin(float __lcpp_x) _NOEXCEPT {return ::asinf(__lcpp_x);}
  629. inline _LIBCPP_INLINE_VISIBILITY long double asin(long double __lcpp_x) _NOEXCEPT {return ::asinl(__lcpp_x);}
  630. # endif
  631. template <class _A1>
  632. inline _LIBCPP_INLINE_VISIBILITY
  633. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  634. asin(_A1 __lcpp_x) _NOEXCEPT {return ::asin((double)__lcpp_x);}
  635. // atan
  636. # if !defined(__sun__)
  637. inline _LIBCPP_INLINE_VISIBILITY float atan(float __lcpp_x) _NOEXCEPT {return ::atanf(__lcpp_x);}
  638. inline _LIBCPP_INLINE_VISIBILITY long double atan(long double __lcpp_x) _NOEXCEPT {return ::atanl(__lcpp_x);}
  639. # endif
  640. template <class _A1>
  641. inline _LIBCPP_INLINE_VISIBILITY
  642. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  643. atan(_A1 __lcpp_x) _NOEXCEPT {return ::atan((double)__lcpp_x);}
  644. // atan2
  645. # if !defined(__sun__)
  646. inline _LIBCPP_INLINE_VISIBILITY float atan2(float __lcpp_y, float __lcpp_x) _NOEXCEPT {return ::atan2f(__lcpp_y, __lcpp_x);}
  647. inline _LIBCPP_INLINE_VISIBILITY long double atan2(long double __lcpp_y, long double __lcpp_x) _NOEXCEPT {return ::atan2l(__lcpp_y, __lcpp_x);}
  648. # endif
  649. template <class _A1, class _A2>
  650. inline _LIBCPP_INLINE_VISIBILITY
  651. typename std::__enable_if_t
  652. <
  653. std::is_arithmetic<_A1>::value &&
  654. std::is_arithmetic<_A2>::value,
  655. std::__promote<_A1, _A2>
  656. >::type
  657. atan2(_A1 __lcpp_y, _A2 __lcpp_x) _NOEXCEPT
  658. {
  659. typedef typename std::__promote<_A1, _A2>::type __result_type;
  660. static_assert((!(std::_IsSame<_A1, __result_type>::value &&
  661. std::_IsSame<_A2, __result_type>::value)), "");
  662. return ::atan2((__result_type)__lcpp_y, (__result_type)__lcpp_x);
  663. }
  664. // ceil
  665. # if !defined(__sun__)
  666. inline _LIBCPP_INLINE_VISIBILITY float ceil(float __lcpp_x) _NOEXCEPT {return ::ceilf(__lcpp_x);}
  667. inline _LIBCPP_INLINE_VISIBILITY long double ceil(long double __lcpp_x) _NOEXCEPT {return ::ceill(__lcpp_x);}
  668. # endif
  669. template <class _A1>
  670. inline _LIBCPP_INLINE_VISIBILITY
  671. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  672. ceil(_A1 __lcpp_x) _NOEXCEPT {return ::ceil((double)__lcpp_x);}
  673. // cos
  674. # if !defined(__sun__)
  675. inline _LIBCPP_INLINE_VISIBILITY float cos(float __lcpp_x) _NOEXCEPT {return ::cosf(__lcpp_x);}
  676. inline _LIBCPP_INLINE_VISIBILITY long double cos(long double __lcpp_x) _NOEXCEPT {return ::cosl(__lcpp_x);}
  677. # endif
  678. template <class _A1>
  679. inline _LIBCPP_INLINE_VISIBILITY
  680. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  681. cos(_A1 __lcpp_x) _NOEXCEPT {return ::cos((double)__lcpp_x);}
  682. // cosh
  683. # if !defined(__sun__)
  684. inline _LIBCPP_INLINE_VISIBILITY float cosh(float __lcpp_x) _NOEXCEPT {return ::coshf(__lcpp_x);}
  685. inline _LIBCPP_INLINE_VISIBILITY long double cosh(long double __lcpp_x) _NOEXCEPT {return ::coshl(__lcpp_x);}
  686. # endif
  687. template <class _A1>
  688. inline _LIBCPP_INLINE_VISIBILITY
  689. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  690. cosh(_A1 __lcpp_x) _NOEXCEPT {return ::cosh((double)__lcpp_x);}
  691. // exp
  692. # if !defined(__sun__)
  693. inline _LIBCPP_INLINE_VISIBILITY float exp(float __lcpp_x) _NOEXCEPT {return ::expf(__lcpp_x);}
  694. inline _LIBCPP_INLINE_VISIBILITY long double exp(long double __lcpp_x) _NOEXCEPT {return ::expl(__lcpp_x);}
  695. # endif
  696. template <class _A1>
  697. inline _LIBCPP_INLINE_VISIBILITY
  698. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  699. exp(_A1 __lcpp_x) _NOEXCEPT {return ::exp((double)__lcpp_x);}
  700. // fabs
  701. # if !defined(__sun__)
  702. inline _LIBCPP_INLINE_VISIBILITY float fabs(float __lcpp_x) _NOEXCEPT {return ::fabsf(__lcpp_x);}
  703. inline _LIBCPP_INLINE_VISIBILITY long double fabs(long double __lcpp_x) _NOEXCEPT {return ::fabsl(__lcpp_x);}
  704. # endif
  705. template <class _A1>
  706. inline _LIBCPP_INLINE_VISIBILITY
  707. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  708. fabs(_A1 __lcpp_x) _NOEXCEPT {return ::fabs((double)__lcpp_x);}
  709. // floor
  710. # if !defined(__sun__)
  711. inline _LIBCPP_INLINE_VISIBILITY float floor(float __lcpp_x) _NOEXCEPT {return ::floorf(__lcpp_x);}
  712. inline _LIBCPP_INLINE_VISIBILITY long double floor(long double __lcpp_x) _NOEXCEPT {return ::floorl(__lcpp_x);}
  713. # endif
  714. template <class _A1>
  715. inline _LIBCPP_INLINE_VISIBILITY
  716. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  717. floor(_A1 __lcpp_x) _NOEXCEPT {return ::floor((double)__lcpp_x);}
  718. // fmod
  719. # if !defined(__sun__)
  720. inline _LIBCPP_INLINE_VISIBILITY float fmod(float __lcpp_x, float __lcpp_y) _NOEXCEPT {return ::fmodf(__lcpp_x, __lcpp_y);}
  721. inline _LIBCPP_INLINE_VISIBILITY long double fmod(long double __lcpp_x, long double __lcpp_y) _NOEXCEPT {return ::fmodl(__lcpp_x, __lcpp_y);}
  722. # endif
  723. template <class _A1, class _A2>
  724. inline _LIBCPP_INLINE_VISIBILITY
  725. typename std::__enable_if_t
  726. <
  727. std::is_arithmetic<_A1>::value &&
  728. std::is_arithmetic<_A2>::value,
  729. std::__promote<_A1, _A2>
  730. >::type
  731. fmod(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  732. {
  733. typedef typename std::__promote<_A1, _A2>::type __result_type;
  734. static_assert((!(std::_IsSame<_A1, __result_type>::value &&
  735. std::_IsSame<_A2, __result_type>::value)), "");
  736. return ::fmod((__result_type)__lcpp_x, (__result_type)__lcpp_y);
  737. }
  738. // frexp
  739. # if !defined(__sun__)
  740. inline _LIBCPP_INLINE_VISIBILITY float frexp(float __lcpp_x, int* __lcpp_e) _NOEXCEPT {return ::frexpf(__lcpp_x, __lcpp_e);}
  741. inline _LIBCPP_INLINE_VISIBILITY long double frexp(long double __lcpp_x, int* __lcpp_e) _NOEXCEPT {return ::frexpl(__lcpp_x, __lcpp_e);}
  742. # endif
  743. template <class _A1>
  744. inline _LIBCPP_INLINE_VISIBILITY
  745. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  746. frexp(_A1 __lcpp_x, int* __lcpp_e) _NOEXCEPT {return ::frexp((double)__lcpp_x, __lcpp_e);}
  747. // ldexp
  748. # if !defined(__sun__)
  749. inline _LIBCPP_INLINE_VISIBILITY float ldexp(float __lcpp_x, int __lcpp_e) _NOEXCEPT {return ::ldexpf(__lcpp_x, __lcpp_e);}
  750. inline _LIBCPP_INLINE_VISIBILITY long double ldexp(long double __lcpp_x, int __lcpp_e) _NOEXCEPT {return ::ldexpl(__lcpp_x, __lcpp_e);}
  751. # endif
  752. template <class _A1>
  753. inline _LIBCPP_INLINE_VISIBILITY
  754. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  755. ldexp(_A1 __lcpp_x, int __lcpp_e) _NOEXCEPT {return ::ldexp((double)__lcpp_x, __lcpp_e);}
  756. // log
  757. # if !defined(__sun__)
  758. inline _LIBCPP_INLINE_VISIBILITY float log(float __lcpp_x) _NOEXCEPT {return ::logf(__lcpp_x);}
  759. inline _LIBCPP_INLINE_VISIBILITY long double log(long double __lcpp_x) _NOEXCEPT {return ::logl(__lcpp_x);}
  760. # endif
  761. template <class _A1>
  762. inline _LIBCPP_INLINE_VISIBILITY
  763. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  764. log(_A1 __lcpp_x) _NOEXCEPT {return ::log((double)__lcpp_x);}
  765. // log10
  766. # if !defined(__sun__)
  767. inline _LIBCPP_INLINE_VISIBILITY float log10(float __lcpp_x) _NOEXCEPT {return ::log10f(__lcpp_x);}
  768. inline _LIBCPP_INLINE_VISIBILITY long double log10(long double __lcpp_x) _NOEXCEPT {return ::log10l(__lcpp_x);}
  769. # endif
  770. template <class _A1>
  771. inline _LIBCPP_INLINE_VISIBILITY
  772. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  773. log10(_A1 __lcpp_x) _NOEXCEPT {return ::log10((double)__lcpp_x);}
  774. // modf
  775. # if !defined(__sun__)
  776. inline _LIBCPP_INLINE_VISIBILITY float modf(float __lcpp_x, float* __lcpp_y) _NOEXCEPT {return ::modff(__lcpp_x, __lcpp_y);}
  777. inline _LIBCPP_INLINE_VISIBILITY long double modf(long double __lcpp_x, long double* __lcpp_y) _NOEXCEPT {return ::modfl(__lcpp_x, __lcpp_y);}
  778. # endif
  779. // pow
  780. # if !defined(__sun__)
  781. inline _LIBCPP_INLINE_VISIBILITY float pow(float __lcpp_x, float __lcpp_y) _NOEXCEPT {return ::powf(__lcpp_x, __lcpp_y);}
  782. inline _LIBCPP_INLINE_VISIBILITY long double pow(long double __lcpp_x, long double __lcpp_y) _NOEXCEPT {return ::powl(__lcpp_x, __lcpp_y);}
  783. # endif
  784. template <class _A1, class _A2>
  785. inline _LIBCPP_INLINE_VISIBILITY
  786. typename std::__enable_if_t
  787. <
  788. std::is_arithmetic<_A1>::value &&
  789. std::is_arithmetic<_A2>::value,
  790. std::__promote<_A1, _A2>
  791. >::type
  792. pow(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  793. {
  794. typedef typename std::__promote<_A1, _A2>::type __result_type;
  795. static_assert((!(std::_IsSame<_A1, __result_type>::value &&
  796. std::_IsSame<_A2, __result_type>::value)), "");
  797. return ::pow((__result_type)__lcpp_x, (__result_type)__lcpp_y);
  798. }
  799. // sin
  800. # if !defined(__sun__)
  801. inline _LIBCPP_INLINE_VISIBILITY float sin(float __lcpp_x) _NOEXCEPT {return ::sinf(__lcpp_x);}
  802. inline _LIBCPP_INLINE_VISIBILITY long double sin(long double __lcpp_x) _NOEXCEPT {return ::sinl(__lcpp_x);}
  803. #endif
  804. template <class _A1>
  805. inline _LIBCPP_INLINE_VISIBILITY
  806. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  807. sin(_A1 __lcpp_x) _NOEXCEPT {return ::sin((double)__lcpp_x);}
  808. // sinh
  809. # if !defined(__sun__)
  810. inline _LIBCPP_INLINE_VISIBILITY float sinh(float __lcpp_x) _NOEXCEPT {return ::sinhf(__lcpp_x);}
  811. inline _LIBCPP_INLINE_VISIBILITY long double sinh(long double __lcpp_x) _NOEXCEPT {return ::sinhl(__lcpp_x);}
  812. # endif
  813. template <class _A1>
  814. inline _LIBCPP_INLINE_VISIBILITY
  815. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  816. sinh(_A1 __lcpp_x) _NOEXCEPT {return ::sinh((double)__lcpp_x);}
  817. // sqrt
  818. # if !defined(__sun__)
  819. inline _LIBCPP_INLINE_VISIBILITY float sqrt(float __lcpp_x) _NOEXCEPT {return ::sqrtf(__lcpp_x);}
  820. inline _LIBCPP_INLINE_VISIBILITY long double sqrt(long double __lcpp_x) _NOEXCEPT {return ::sqrtl(__lcpp_x);}
  821. # endif
  822. template <class _A1>
  823. inline _LIBCPP_INLINE_VISIBILITY
  824. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  825. sqrt(_A1 __lcpp_x) _NOEXCEPT {return ::sqrt((double)__lcpp_x);}
  826. // tan
  827. # if !defined(__sun__)
  828. inline _LIBCPP_INLINE_VISIBILITY float tan(float __lcpp_x) _NOEXCEPT {return ::tanf(__lcpp_x);}
  829. inline _LIBCPP_INLINE_VISIBILITY long double tan(long double __lcpp_x) _NOEXCEPT {return ::tanl(__lcpp_x);}
  830. # endif
  831. template <class _A1>
  832. inline _LIBCPP_INLINE_VISIBILITY
  833. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  834. tan(_A1 __lcpp_x) _NOEXCEPT {return ::tan((double)__lcpp_x);}
  835. // tanh
  836. # if !defined(__sun__)
  837. inline _LIBCPP_INLINE_VISIBILITY float tanh(float __lcpp_x) _NOEXCEPT {return ::tanhf(__lcpp_x);}
  838. inline _LIBCPP_INLINE_VISIBILITY long double tanh(long double __lcpp_x) _NOEXCEPT {return ::tanhl(__lcpp_x);}
  839. # endif
  840. template <class _A1>
  841. inline _LIBCPP_INLINE_VISIBILITY
  842. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  843. tanh(_A1 __lcpp_x) _NOEXCEPT {return ::tanh((double)__lcpp_x);}
  844. // acosh
  845. inline _LIBCPP_INLINE_VISIBILITY float acosh(float __lcpp_x) _NOEXCEPT {return ::acoshf(__lcpp_x);}
  846. inline _LIBCPP_INLINE_VISIBILITY long double acosh(long double __lcpp_x) _NOEXCEPT {return ::acoshl(__lcpp_x);}
  847. template <class _A1>
  848. inline _LIBCPP_INLINE_VISIBILITY
  849. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  850. acosh(_A1 __lcpp_x) _NOEXCEPT {return ::acosh((double)__lcpp_x);}
  851. // asinh
  852. inline _LIBCPP_INLINE_VISIBILITY float asinh(float __lcpp_x) _NOEXCEPT {return ::asinhf(__lcpp_x);}
  853. inline _LIBCPP_INLINE_VISIBILITY long double asinh(long double __lcpp_x) _NOEXCEPT {return ::asinhl(__lcpp_x);}
  854. template <class _A1>
  855. inline _LIBCPP_INLINE_VISIBILITY
  856. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  857. asinh(_A1 __lcpp_x) _NOEXCEPT {return ::asinh((double)__lcpp_x);}
  858. // atanh
  859. inline _LIBCPP_INLINE_VISIBILITY float atanh(float __lcpp_x) _NOEXCEPT {return ::atanhf(__lcpp_x);}
  860. inline _LIBCPP_INLINE_VISIBILITY long double atanh(long double __lcpp_x) _NOEXCEPT {return ::atanhl(__lcpp_x);}
  861. template <class _A1>
  862. inline _LIBCPP_INLINE_VISIBILITY
  863. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  864. atanh(_A1 __lcpp_x) _NOEXCEPT {return ::atanh((double)__lcpp_x);}
  865. // cbrt
  866. inline _LIBCPP_INLINE_VISIBILITY float cbrt(float __lcpp_x) _NOEXCEPT {return ::cbrtf(__lcpp_x);}
  867. inline _LIBCPP_INLINE_VISIBILITY long double cbrt(long double __lcpp_x) _NOEXCEPT {return ::cbrtl(__lcpp_x);}
  868. template <class _A1>
  869. inline _LIBCPP_INLINE_VISIBILITY
  870. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  871. cbrt(_A1 __lcpp_x) _NOEXCEPT {return ::cbrt((double)__lcpp_x);}
  872. // copysign
  873. #if __has_builtin(__builtin_copysignf)
  874. _LIBCPP_CONSTEXPR
  875. #endif
  876. inline _LIBCPP_INLINE_VISIBILITY float __libcpp_copysign(float __lcpp_x, float __lcpp_y) _NOEXCEPT {
  877. #if __has_builtin(__builtin_copysignf)
  878. return __builtin_copysignf(__lcpp_x, __lcpp_y);
  879. #else
  880. return ::copysignf(__lcpp_x, __lcpp_y);
  881. #endif
  882. }
  883. #if __has_builtin(__builtin_copysign)
  884. _LIBCPP_CONSTEXPR
  885. #endif
  886. inline _LIBCPP_INLINE_VISIBILITY double __libcpp_copysign(double __lcpp_x, double __lcpp_y) _NOEXCEPT {
  887. #if __has_builtin(__builtin_copysign)
  888. return __builtin_copysign(__lcpp_x, __lcpp_y);
  889. #else
  890. return ::copysign(__lcpp_x, __lcpp_y);
  891. #endif
  892. }
  893. #if __has_builtin(__builtin_copysignl)
  894. _LIBCPP_CONSTEXPR
  895. #endif
  896. inline _LIBCPP_INLINE_VISIBILITY long double __libcpp_copysign(long double __lcpp_x, long double __lcpp_y) _NOEXCEPT {
  897. #if __has_builtin(__builtin_copysignl)
  898. return __builtin_copysignl(__lcpp_x, __lcpp_y);
  899. #else
  900. return ::copysignl(__lcpp_x, __lcpp_y);
  901. #endif
  902. }
  903. template <class _A1, class _A2>
  904. #if __has_builtin(__builtin_copysign)
  905. _LIBCPP_CONSTEXPR
  906. #endif
  907. inline _LIBCPP_INLINE_VISIBILITY
  908. typename std::__enable_if_t
  909. <
  910. std::is_arithmetic<_A1>::value &&
  911. std::is_arithmetic<_A2>::value,
  912. std::__promote<_A1, _A2>
  913. >::type
  914. __libcpp_copysign(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT {
  915. typedef typename std::__promote<_A1, _A2>::type __result_type;
  916. static_assert((!(std::_IsSame<_A1, __result_type>::value &&
  917. std::_IsSame<_A2, __result_type>::value)), "");
  918. #if __has_builtin(__builtin_copysign)
  919. return __builtin_copysign((__result_type)__lcpp_x, (__result_type)__lcpp_y);
  920. #else
  921. return ::copysign((__result_type)__lcpp_x, (__result_type)__lcpp_y);
  922. #endif
  923. }
  924. inline _LIBCPP_INLINE_VISIBILITY float copysign(float __lcpp_x, float __lcpp_y) _NOEXCEPT {
  925. return ::__libcpp_copysign(__lcpp_x, __lcpp_y);
  926. }
  927. inline _LIBCPP_INLINE_VISIBILITY long double copysign(long double __lcpp_x, long double __lcpp_y) _NOEXCEPT {
  928. return ::__libcpp_copysign(__lcpp_x, __lcpp_y);
  929. }
  930. template <class _A1, class _A2>
  931. inline _LIBCPP_INLINE_VISIBILITY
  932. typename std::__enable_if_t
  933. <
  934. std::is_arithmetic<_A1>::value &&
  935. std::is_arithmetic<_A2>::value,
  936. std::__promote<_A1, _A2>
  937. >::type
  938. copysign(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT {
  939. return ::__libcpp_copysign(__lcpp_x, __lcpp_y);
  940. }
  941. // erf
  942. inline _LIBCPP_INLINE_VISIBILITY float erf(float __lcpp_x) _NOEXCEPT {return ::erff(__lcpp_x);}
  943. inline _LIBCPP_INLINE_VISIBILITY long double erf(long double __lcpp_x) _NOEXCEPT {return ::erfl(__lcpp_x);}
  944. template <class _A1>
  945. inline _LIBCPP_INLINE_VISIBILITY
  946. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  947. erf(_A1 __lcpp_x) _NOEXCEPT {return ::erf((double)__lcpp_x);}
  948. // erfc
  949. inline _LIBCPP_INLINE_VISIBILITY float erfc(float __lcpp_x) _NOEXCEPT {return ::erfcf(__lcpp_x);}
  950. inline _LIBCPP_INLINE_VISIBILITY long double erfc(long double __lcpp_x) _NOEXCEPT {return ::erfcl(__lcpp_x);}
  951. template <class _A1>
  952. inline _LIBCPP_INLINE_VISIBILITY
  953. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  954. erfc(_A1 __lcpp_x) _NOEXCEPT {return ::erfc((double)__lcpp_x);}
  955. // exp2
  956. inline _LIBCPP_INLINE_VISIBILITY float exp2(float __lcpp_x) _NOEXCEPT {return ::exp2f(__lcpp_x);}
  957. inline _LIBCPP_INLINE_VISIBILITY long double exp2(long double __lcpp_x) _NOEXCEPT {return ::exp2l(__lcpp_x);}
  958. template <class _A1>
  959. inline _LIBCPP_INLINE_VISIBILITY
  960. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  961. exp2(_A1 __lcpp_x) _NOEXCEPT {return ::exp2((double)__lcpp_x);}
  962. // expm1
  963. inline _LIBCPP_INLINE_VISIBILITY float expm1(float __lcpp_x) _NOEXCEPT {return ::expm1f(__lcpp_x);}
  964. inline _LIBCPP_INLINE_VISIBILITY long double expm1(long double __lcpp_x) _NOEXCEPT {return ::expm1l(__lcpp_x);}
  965. template <class _A1>
  966. inline _LIBCPP_INLINE_VISIBILITY
  967. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  968. expm1(_A1 __lcpp_x) _NOEXCEPT {return ::expm1((double)__lcpp_x);}
  969. // fdim
  970. inline _LIBCPP_INLINE_VISIBILITY float fdim(float __lcpp_x, float __lcpp_y) _NOEXCEPT {return ::fdimf(__lcpp_x, __lcpp_y);}
  971. inline _LIBCPP_INLINE_VISIBILITY long double fdim(long double __lcpp_x, long double __lcpp_y) _NOEXCEPT {return ::fdiml(__lcpp_x, __lcpp_y);}
  972. template <class _A1, class _A2>
  973. inline _LIBCPP_INLINE_VISIBILITY
  974. typename std::__enable_if_t
  975. <
  976. std::is_arithmetic<_A1>::value &&
  977. std::is_arithmetic<_A2>::value,
  978. std::__promote<_A1, _A2>
  979. >::type
  980. fdim(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  981. {
  982. typedef typename std::__promote<_A1, _A2>::type __result_type;
  983. static_assert((!(std::_IsSame<_A1, __result_type>::value &&
  984. std::_IsSame<_A2, __result_type>::value)), "");
  985. return ::fdim((__result_type)__lcpp_x, (__result_type)__lcpp_y);
  986. }
  987. // fma
  988. inline _LIBCPP_INLINE_VISIBILITY float fma(float __lcpp_x, float __lcpp_y, float __lcpp_z) _NOEXCEPT
  989. {
  990. #if __has_builtin(__builtin_fmaf)
  991. return __builtin_fmaf(__lcpp_x, __lcpp_y, __lcpp_z);
  992. #else
  993. return ::fmaf(__lcpp_x, __lcpp_y, __lcpp_z);
  994. #endif
  995. }
  996. inline _LIBCPP_INLINE_VISIBILITY long double fma(long double __lcpp_x, long double __lcpp_y, long double __lcpp_z) _NOEXCEPT
  997. {
  998. #if __has_builtin(__builtin_fmal)
  999. return __builtin_fmal(__lcpp_x, __lcpp_y, __lcpp_z);
  1000. #else
  1001. return ::fmal(__lcpp_x, __lcpp_y, __lcpp_z);
  1002. #endif
  1003. }
  1004. template <class _A1, class _A2, class _A3>
  1005. inline _LIBCPP_INLINE_VISIBILITY
  1006. typename std::__enable_if_t
  1007. <
  1008. std::is_arithmetic<_A1>::value &&
  1009. std::is_arithmetic<_A2>::value &&
  1010. std::is_arithmetic<_A3>::value,
  1011. std::__promote<_A1, _A2, _A3>
  1012. >::type
  1013. fma(_A1 __lcpp_x, _A2 __lcpp_y, _A3 __lcpp_z) _NOEXCEPT
  1014. {
  1015. typedef typename std::__promote<_A1, _A2, _A3>::type __result_type;
  1016. static_assert((!(std::_IsSame<_A1, __result_type>::value &&
  1017. std::_IsSame<_A2, __result_type>::value &&
  1018. std::_IsSame<_A3, __result_type>::value)), "");
  1019. #if __has_builtin(__builtin_fma)
  1020. return __builtin_fma((__result_type)__lcpp_x, (__result_type)__lcpp_y, (__result_type)__lcpp_z);
  1021. #else
  1022. return ::fma((__result_type)__lcpp_x, (__result_type)__lcpp_y, (__result_type)__lcpp_z);
  1023. #endif
  1024. }
  1025. // fmax
  1026. inline _LIBCPP_INLINE_VISIBILITY float fmax(float __lcpp_x, float __lcpp_y) _NOEXCEPT {return ::fmaxf(__lcpp_x, __lcpp_y);}
  1027. inline _LIBCPP_INLINE_VISIBILITY long double fmax(long double __lcpp_x, long double __lcpp_y) _NOEXCEPT {return ::fmaxl(__lcpp_x, __lcpp_y);}
  1028. template <class _A1, class _A2>
  1029. inline _LIBCPP_INLINE_VISIBILITY
  1030. typename std::__enable_if_t
  1031. <
  1032. std::is_arithmetic<_A1>::value &&
  1033. std::is_arithmetic<_A2>::value,
  1034. std::__promote<_A1, _A2>
  1035. >::type
  1036. fmax(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  1037. {
  1038. typedef typename std::__promote<_A1, _A2>::type __result_type;
  1039. static_assert((!(std::_IsSame<_A1, __result_type>::value &&
  1040. std::_IsSame<_A2, __result_type>::value)), "");
  1041. return ::fmax((__result_type)__lcpp_x, (__result_type)__lcpp_y);
  1042. }
  1043. // fmin
  1044. inline _LIBCPP_INLINE_VISIBILITY float fmin(float __lcpp_x, float __lcpp_y) _NOEXCEPT {return ::fminf(__lcpp_x, __lcpp_y);}
  1045. inline _LIBCPP_INLINE_VISIBILITY long double fmin(long double __lcpp_x, long double __lcpp_y) _NOEXCEPT {return ::fminl(__lcpp_x, __lcpp_y);}
  1046. template <class _A1, class _A2>
  1047. inline _LIBCPP_INLINE_VISIBILITY
  1048. typename std::__enable_if_t
  1049. <
  1050. std::is_arithmetic<_A1>::value &&
  1051. std::is_arithmetic<_A2>::value,
  1052. std::__promote<_A1, _A2>
  1053. >::type
  1054. fmin(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  1055. {
  1056. typedef typename std::__promote<_A1, _A2>::type __result_type;
  1057. static_assert((!(std::_IsSame<_A1, __result_type>::value &&
  1058. std::_IsSame<_A2, __result_type>::value)), "");
  1059. return ::fmin((__result_type)__lcpp_x, (__result_type)__lcpp_y);
  1060. }
  1061. // hypot
  1062. inline _LIBCPP_INLINE_VISIBILITY float hypot(float __lcpp_x, float __lcpp_y) _NOEXCEPT {return ::hypotf(__lcpp_x, __lcpp_y);}
  1063. inline _LIBCPP_INLINE_VISIBILITY long double hypot(long double __lcpp_x, long double __lcpp_y) _NOEXCEPT {return ::hypotl(__lcpp_x, __lcpp_y);}
  1064. template <class _A1, class _A2>
  1065. inline _LIBCPP_INLINE_VISIBILITY
  1066. typename std::__enable_if_t
  1067. <
  1068. std::is_arithmetic<_A1>::value &&
  1069. std::is_arithmetic<_A2>::value,
  1070. std::__promote<_A1, _A2>
  1071. >::type
  1072. hypot(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  1073. {
  1074. typedef typename std::__promote<_A1, _A2>::type __result_type;
  1075. static_assert((!(std::_IsSame<_A1, __result_type>::value &&
  1076. std::_IsSame<_A2, __result_type>::value)), "");
  1077. return ::hypot((__result_type)__lcpp_x, (__result_type)__lcpp_y);
  1078. }
  1079. // ilogb
  1080. inline _LIBCPP_INLINE_VISIBILITY int ilogb(float __lcpp_x) _NOEXCEPT {return ::ilogbf(__lcpp_x);}
  1081. inline _LIBCPP_INLINE_VISIBILITY int ilogb(long double __lcpp_x) _NOEXCEPT {return ::ilogbl(__lcpp_x);}
  1082. template <class _A1>
  1083. inline _LIBCPP_INLINE_VISIBILITY
  1084. typename std::enable_if<std::is_integral<_A1>::value, int>::type
  1085. ilogb(_A1 __lcpp_x) _NOEXCEPT {return ::ilogb((double)__lcpp_x);}
  1086. // lgamma
  1087. inline _LIBCPP_INLINE_VISIBILITY float lgamma(float __lcpp_x) _NOEXCEPT {return ::lgammaf(__lcpp_x);}
  1088. inline _LIBCPP_INLINE_VISIBILITY long double lgamma(long double __lcpp_x) _NOEXCEPT {return ::lgammal(__lcpp_x);}
  1089. template <class _A1>
  1090. inline _LIBCPP_INLINE_VISIBILITY
  1091. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  1092. lgamma(_A1 __lcpp_x) _NOEXCEPT {return ::lgamma((double)__lcpp_x);}
  1093. // llrint
  1094. inline _LIBCPP_INLINE_VISIBILITY long long llrint(float __lcpp_x) _NOEXCEPT
  1095. {
  1096. #if __has_builtin(__builtin_llrintf)
  1097. return __builtin_llrintf(__lcpp_x);
  1098. #else
  1099. return ::llrintf(__lcpp_x);
  1100. #endif
  1101. }
  1102. inline _LIBCPP_INLINE_VISIBILITY long long llrint(long double __lcpp_x) _NOEXCEPT
  1103. {
  1104. #if __has_builtin(__builtin_llrintl)
  1105. return __builtin_llrintl(__lcpp_x);
  1106. #else
  1107. return ::llrintl(__lcpp_x);
  1108. #endif
  1109. }
  1110. template <class _A1>
  1111. inline _LIBCPP_INLINE_VISIBILITY
  1112. typename std::enable_if<std::is_integral<_A1>::value, long long>::type
  1113. llrint(_A1 __lcpp_x) _NOEXCEPT
  1114. {
  1115. #if __has_builtin(__builtin_llrint)
  1116. return __builtin_llrint((double)__lcpp_x);
  1117. #else
  1118. return ::llrint((double)__lcpp_x);
  1119. #endif
  1120. }
  1121. // llround
  1122. inline _LIBCPP_INLINE_VISIBILITY long long llround(float __lcpp_x) _NOEXCEPT
  1123. {
  1124. #if __has_builtin(__builtin_llroundf)
  1125. return __builtin_llroundf(__lcpp_x);
  1126. #else
  1127. return ::llroundf(__lcpp_x);
  1128. #endif
  1129. }
  1130. inline _LIBCPP_INLINE_VISIBILITY long long llround(long double __lcpp_x) _NOEXCEPT
  1131. {
  1132. #if __has_builtin(__builtin_llroundl)
  1133. return __builtin_llroundl(__lcpp_x);
  1134. #else
  1135. return ::llroundl(__lcpp_x);
  1136. #endif
  1137. }
  1138. template <class _A1>
  1139. inline _LIBCPP_INLINE_VISIBILITY
  1140. typename std::enable_if<std::is_integral<_A1>::value, long long>::type
  1141. llround(_A1 __lcpp_x) _NOEXCEPT
  1142. {
  1143. #if __has_builtin(__builtin_llround)
  1144. return __builtin_llround((double)__lcpp_x);
  1145. #else
  1146. return ::llround((double)__lcpp_x);
  1147. #endif
  1148. }
  1149. // log1p
  1150. inline _LIBCPP_INLINE_VISIBILITY float log1p(float __lcpp_x) _NOEXCEPT {return ::log1pf(__lcpp_x);}
  1151. inline _LIBCPP_INLINE_VISIBILITY long double log1p(long double __lcpp_x) _NOEXCEPT {return ::log1pl(__lcpp_x);}
  1152. template <class _A1>
  1153. inline _LIBCPP_INLINE_VISIBILITY
  1154. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  1155. log1p(_A1 __lcpp_x) _NOEXCEPT {return ::log1p((double)__lcpp_x);}
  1156. // log2
  1157. inline _LIBCPP_INLINE_VISIBILITY float log2(float __lcpp_x) _NOEXCEPT {return ::log2f(__lcpp_x);}
  1158. inline _LIBCPP_INLINE_VISIBILITY long double log2(long double __lcpp_x) _NOEXCEPT {return ::log2l(__lcpp_x);}
  1159. template <class _A1>
  1160. inline _LIBCPP_INLINE_VISIBILITY
  1161. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  1162. log2(_A1 __lcpp_x) _NOEXCEPT {return ::log2((double)__lcpp_x);}
  1163. // logb
  1164. inline _LIBCPP_INLINE_VISIBILITY float logb(float __lcpp_x) _NOEXCEPT {return ::logbf(__lcpp_x);}
  1165. inline _LIBCPP_INLINE_VISIBILITY long double logb(long double __lcpp_x) _NOEXCEPT {return ::logbl(__lcpp_x);}
  1166. template <class _A1>
  1167. inline _LIBCPP_INLINE_VISIBILITY
  1168. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  1169. logb(_A1 __lcpp_x) _NOEXCEPT {return ::logb((double)__lcpp_x);}
  1170. // lrint
  1171. inline _LIBCPP_INLINE_VISIBILITY long lrint(float __lcpp_x) _NOEXCEPT
  1172. {
  1173. #if __has_builtin(__builtin_lrintf)
  1174. return __builtin_lrintf(__lcpp_x);
  1175. #else
  1176. return ::lrintf(__lcpp_x);
  1177. #endif
  1178. }
  1179. inline _LIBCPP_INLINE_VISIBILITY long lrint(long double __lcpp_x) _NOEXCEPT
  1180. {
  1181. #if __has_builtin(__builtin_lrintl)
  1182. return __builtin_lrintl(__lcpp_x);
  1183. #else
  1184. return ::lrintl(__lcpp_x);
  1185. #endif
  1186. }
  1187. template <class _A1>
  1188. inline _LIBCPP_INLINE_VISIBILITY
  1189. typename std::enable_if<std::is_integral<_A1>::value, long>::type
  1190. lrint(_A1 __lcpp_x) _NOEXCEPT
  1191. {
  1192. #if __has_builtin(__builtin_lrint)
  1193. return __builtin_lrint((double)__lcpp_x);
  1194. #else
  1195. return ::lrint((double)__lcpp_x);
  1196. #endif
  1197. }
  1198. // lround
  1199. inline _LIBCPP_INLINE_VISIBILITY long lround(float __lcpp_x) _NOEXCEPT
  1200. {
  1201. #if __has_builtin(__builtin_lroundf)
  1202. return __builtin_lroundf(__lcpp_x);
  1203. #else
  1204. return ::lroundf(__lcpp_x);
  1205. #endif
  1206. }
  1207. inline _LIBCPP_INLINE_VISIBILITY long lround(long double __lcpp_x) _NOEXCEPT
  1208. {
  1209. #if __has_builtin(__builtin_lroundl)
  1210. return __builtin_lroundl(__lcpp_x);
  1211. #else
  1212. return ::lroundl(__lcpp_x);
  1213. #endif
  1214. }
  1215. template <class _A1>
  1216. inline _LIBCPP_INLINE_VISIBILITY
  1217. typename std::enable_if<std::is_integral<_A1>::value, long>::type
  1218. lround(_A1 __lcpp_x) _NOEXCEPT
  1219. {
  1220. #if __has_builtin(__builtin_lround)
  1221. return __builtin_lround((double)__lcpp_x);
  1222. #else
  1223. return ::lround((double)__lcpp_x);
  1224. #endif
  1225. }
  1226. // nan
  1227. // nearbyint
  1228. inline _LIBCPP_INLINE_VISIBILITY float nearbyint(float __lcpp_x) _NOEXCEPT {return ::nearbyintf(__lcpp_x);}
  1229. inline _LIBCPP_INLINE_VISIBILITY long double nearbyint(long double __lcpp_x) _NOEXCEPT {return ::nearbyintl(__lcpp_x);}
  1230. template <class _A1>
  1231. inline _LIBCPP_INLINE_VISIBILITY
  1232. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  1233. nearbyint(_A1 __lcpp_x) _NOEXCEPT {return ::nearbyint((double)__lcpp_x);}
  1234. // nextafter
  1235. inline _LIBCPP_INLINE_VISIBILITY float nextafter(float __lcpp_x, float __lcpp_y) _NOEXCEPT {return ::nextafterf(__lcpp_x, __lcpp_y);}
  1236. inline _LIBCPP_INLINE_VISIBILITY long double nextafter(long double __lcpp_x, long double __lcpp_y) _NOEXCEPT {return ::nextafterl(__lcpp_x, __lcpp_y);}
  1237. template <class _A1, class _A2>
  1238. inline _LIBCPP_INLINE_VISIBILITY
  1239. typename std::__enable_if_t
  1240. <
  1241. std::is_arithmetic<_A1>::value &&
  1242. std::is_arithmetic<_A2>::value,
  1243. std::__promote<_A1, _A2>
  1244. >::type
  1245. nextafter(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  1246. {
  1247. typedef typename std::__promote<_A1, _A2>::type __result_type;
  1248. static_assert((!(std::_IsSame<_A1, __result_type>::value &&
  1249. std::_IsSame<_A2, __result_type>::value)), "");
  1250. return ::nextafter((__result_type)__lcpp_x, (__result_type)__lcpp_y);
  1251. }
  1252. // nexttoward
  1253. inline _LIBCPP_INLINE_VISIBILITY float nexttoward(float __lcpp_x, long double __lcpp_y) _NOEXCEPT {return ::nexttowardf(__lcpp_x, __lcpp_y);}
  1254. inline _LIBCPP_INLINE_VISIBILITY long double nexttoward(long double __lcpp_x, long double __lcpp_y) _NOEXCEPT {return ::nexttowardl(__lcpp_x, __lcpp_y);}
  1255. template <class _A1>
  1256. inline _LIBCPP_INLINE_VISIBILITY
  1257. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  1258. nexttoward(_A1 __lcpp_x, long double __lcpp_y) _NOEXCEPT {return ::nexttoward((double)__lcpp_x, __lcpp_y);}
  1259. // remainder
  1260. inline _LIBCPP_INLINE_VISIBILITY float remainder(float __lcpp_x, float __lcpp_y) _NOEXCEPT {return ::remainderf(__lcpp_x, __lcpp_y);}
  1261. inline _LIBCPP_INLINE_VISIBILITY long double remainder(long double __lcpp_x, long double __lcpp_y) _NOEXCEPT {return ::remainderl(__lcpp_x, __lcpp_y);}
  1262. template <class _A1, class _A2>
  1263. inline _LIBCPP_INLINE_VISIBILITY
  1264. typename std::__enable_if_t
  1265. <
  1266. std::is_arithmetic<_A1>::value &&
  1267. std::is_arithmetic<_A2>::value,
  1268. std::__promote<_A1, _A2>
  1269. >::type
  1270. remainder(_A1 __lcpp_x, _A2 __lcpp_y) _NOEXCEPT
  1271. {
  1272. typedef typename std::__promote<_A1, _A2>::type __result_type;
  1273. static_assert((!(std::_IsSame<_A1, __result_type>::value &&
  1274. std::_IsSame<_A2, __result_type>::value)), "");
  1275. return ::remainder((__result_type)__lcpp_x, (__result_type)__lcpp_y);
  1276. }
  1277. // remquo
  1278. inline _LIBCPP_INLINE_VISIBILITY float remquo(float __lcpp_x, float __lcpp_y, int* __lcpp_z) _NOEXCEPT {return ::remquof(__lcpp_x, __lcpp_y, __lcpp_z);}
  1279. inline _LIBCPP_INLINE_VISIBILITY long double remquo(long double __lcpp_x, long double __lcpp_y, int* __lcpp_z) _NOEXCEPT {return ::remquol(__lcpp_x, __lcpp_y, __lcpp_z);}
  1280. template <class _A1, class _A2>
  1281. inline _LIBCPP_INLINE_VISIBILITY
  1282. typename std::__enable_if_t
  1283. <
  1284. std::is_arithmetic<_A1>::value &&
  1285. std::is_arithmetic<_A2>::value,
  1286. std::__promote<_A1, _A2>
  1287. >::type
  1288. remquo(_A1 __lcpp_x, _A2 __lcpp_y, int* __lcpp_z) _NOEXCEPT
  1289. {
  1290. typedef typename std::__promote<_A1, _A2>::type __result_type;
  1291. static_assert((!(std::_IsSame<_A1, __result_type>::value &&
  1292. std::_IsSame<_A2, __result_type>::value)), "");
  1293. return ::remquo((__result_type)__lcpp_x, (__result_type)__lcpp_y, __lcpp_z);
  1294. }
  1295. // rint
  1296. inline _LIBCPP_INLINE_VISIBILITY float rint(float __lcpp_x) _NOEXCEPT
  1297. {
  1298. #if __has_builtin(__builtin_rintf)
  1299. return __builtin_rintf(__lcpp_x);
  1300. #else
  1301. return ::rintf(__lcpp_x);
  1302. #endif
  1303. }
  1304. inline _LIBCPP_INLINE_VISIBILITY long double rint(long double __lcpp_x) _NOEXCEPT
  1305. {
  1306. #if __has_builtin(__builtin_rintl)
  1307. return __builtin_rintl(__lcpp_x);
  1308. #else
  1309. return ::rintl(__lcpp_x);
  1310. #endif
  1311. }
  1312. template <class _A1>
  1313. inline _LIBCPP_INLINE_VISIBILITY
  1314. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  1315. rint(_A1 __lcpp_x) _NOEXCEPT
  1316. {
  1317. #if __has_builtin(__builtin_rint)
  1318. return __builtin_rint((double)__lcpp_x);
  1319. #else
  1320. return ::rint((double)__lcpp_x);
  1321. #endif
  1322. }
  1323. // round
  1324. inline _LIBCPP_INLINE_VISIBILITY float round(float __lcpp_x) _NOEXCEPT
  1325. {
  1326. #if __has_builtin(__builtin_roundf)
  1327. return __builtin_roundf(__lcpp_x);
  1328. #else
  1329. return ::roundf(__lcpp_x);
  1330. #endif
  1331. }
  1332. inline _LIBCPP_INLINE_VISIBILITY long double round(long double __lcpp_x) _NOEXCEPT
  1333. {
  1334. #if __has_builtin(__builtin_roundl)
  1335. return __builtin_roundl(__lcpp_x);
  1336. #else
  1337. return ::roundl(__lcpp_x);
  1338. #endif
  1339. }
  1340. template <class _A1>
  1341. inline _LIBCPP_INLINE_VISIBILITY
  1342. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  1343. round(_A1 __lcpp_x) _NOEXCEPT
  1344. {
  1345. #if __has_builtin(__builtin_round)
  1346. return __builtin_round((double)__lcpp_x);
  1347. #else
  1348. return ::round((double)__lcpp_x);
  1349. #endif
  1350. }
  1351. // scalbln
  1352. inline _LIBCPP_INLINE_VISIBILITY float scalbln(float __lcpp_x, long __lcpp_y) _NOEXCEPT {return ::scalblnf(__lcpp_x, __lcpp_y);}
  1353. inline _LIBCPP_INLINE_VISIBILITY long double scalbln(long double __lcpp_x, long __lcpp_y) _NOEXCEPT {return ::scalblnl(__lcpp_x, __lcpp_y);}
  1354. template <class _A1>
  1355. inline _LIBCPP_INLINE_VISIBILITY
  1356. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  1357. scalbln(_A1 __lcpp_x, long __lcpp_y) _NOEXCEPT {return ::scalbln((double)__lcpp_x, __lcpp_y);}
  1358. // scalbn
  1359. inline _LIBCPP_INLINE_VISIBILITY float scalbn(float __lcpp_x, int __lcpp_y) _NOEXCEPT {return ::scalbnf(__lcpp_x, __lcpp_y);}
  1360. inline _LIBCPP_INLINE_VISIBILITY long double scalbn(long double __lcpp_x, int __lcpp_y) _NOEXCEPT {return ::scalbnl(__lcpp_x, __lcpp_y);}
  1361. template <class _A1>
  1362. inline _LIBCPP_INLINE_VISIBILITY
  1363. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  1364. scalbn(_A1 __lcpp_x, int __lcpp_y) _NOEXCEPT {return ::scalbn((double)__lcpp_x, __lcpp_y);}
  1365. // tgamma
  1366. inline _LIBCPP_INLINE_VISIBILITY float tgamma(float __lcpp_x) _NOEXCEPT {return ::tgammaf(__lcpp_x);}
  1367. inline _LIBCPP_INLINE_VISIBILITY long double tgamma(long double __lcpp_x) _NOEXCEPT {return ::tgammal(__lcpp_x);}
  1368. template <class _A1>
  1369. inline _LIBCPP_INLINE_VISIBILITY
  1370. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  1371. tgamma(_A1 __lcpp_x) _NOEXCEPT {return ::tgamma((double)__lcpp_x);}
  1372. // trunc
  1373. inline _LIBCPP_INLINE_VISIBILITY float trunc(float __lcpp_x) _NOEXCEPT
  1374. {
  1375. #if __has_builtin(__builtin_truncf)
  1376. return __builtin_truncf(__lcpp_x);
  1377. #else
  1378. return ::truncf(__lcpp_x);
  1379. #endif
  1380. }
  1381. inline _LIBCPP_INLINE_VISIBILITY long double trunc(long double __lcpp_x) _NOEXCEPT
  1382. {
  1383. #if __has_builtin(__builtin_truncl)
  1384. return __builtin_truncl(__lcpp_x);
  1385. #else
  1386. return ::truncl(__lcpp_x);
  1387. #endif
  1388. }
  1389. template <class _A1>
  1390. inline _LIBCPP_INLINE_VISIBILITY
  1391. typename std::enable_if<std::is_integral<_A1>::value, double>::type
  1392. trunc(_A1 __lcpp_x) _NOEXCEPT
  1393. {
  1394. #if __has_builtin(__builtin_trunc)
  1395. return __builtin_trunc((double)__lcpp_x);
  1396. #else
  1397. return ::trunc((double)__lcpp_x);
  1398. #endif
  1399. }
  1400. } // extern "C++"
  1401. #endif // __cplusplus
  1402. #else // _LIBCPP_MATH_H
  1403. // This include lives outside the header guard in order to support an MSVC
  1404. // extension which allows users to do:
  1405. //
  1406. // #define _USE_MATH_DEFINES
  1407. // #include <math.h>
  1408. //
  1409. // and receive the definitions of mathematical constants, even if <math.h>
  1410. // has previously been included.
  1411. #if defined(_LIBCPP_MSVCRT) && defined(_USE_MATH_DEFINES)
  1412. #include_next <math.h>
  1413. #endif
  1414. #endif // _LIBCPP_MATH_H