clang 23.0.0git
__clang_spirv_math.h
Go to the documentation of this file.
1/*===---- __clang_spirv_math.h - Device-side SPIRV math support ------------===
2 *
3 * Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 * See https://llvm.org/LICENSE.txt for license information.
5 * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 *
7 *===-----------------------------------------------------------------------===
8 */
9#ifndef __CLANG_SPIRV_MATH_H__
10#define __CLANG_SPIRV_MATH_H__
11
12#if !defined(__SPIRV__) && !defined(__OPENMP_SPIRV__)
13#error "This file is for SPIRV and OpenMP SPIRV device compilation only."
14#endif
15
16// The __CLANG_GPU_DISABLE_MATH_WRAPPERS macro provides a way to let standard
17// libcalls reach the link step instead of being eagerly replaced.
18#ifndef __CLANG_GPU_DISABLE_MATH_WRAPPERS
19
20// __DEVICE__ is a helper macro with common set of attributes for the wrappers
21// we implement in this file. We need static in order to avoid emitting unused
22// functions and __forceinline__ helps inlining these wrappers at -O1.
23#pragma push_macro("__DEVICE__")
24#ifdef __OPENMP_SPIRV__
25#if defined(__cplusplus)
26#define __DEVICE__ static constexpr __attribute__((always_inline, nothrow))
27#else
28#define __DEVICE__ static __attribute__((always_inline, nothrow))
29#endif
30#else
31#define __DEVICE__ static __device__ __forceinline__
32#endif
33
35float __cosf(float __x) { return __spirv_ocl_cos(__x); }
37float __exp10f(float __x) { return __spirv_ocl_exp10(__x); }
39float __expf(float __x) { return __spirv_ocl_exp(__x); }
40
42float __fadd_rd(float __x, float __y) {
43 float sum = __x + __y;
44 float rounded = __spirv_ocl_floor(sum);
45 if (rounded > sum)
46 rounded -= 1.0f;
47 return rounded;
48}
49
51float __fadd_rn(float __x, float __y) { return __spirv_ocl_rint(__x + __y); }
53float __fadd_ru(float __x, float __y) { return __spirv_ocl_ceil(__x + __y); }
55float __fadd_rz(float __x, float __y) { return __spirv_ocl_trunc(__x + __y); }
56
58float __fdiv_rd(float __x, float __y) {
59 float res = __x / __y;
60 float rounded = __spirv_ocl_floor(res);
61 if (rounded > res)
62 rounded -= 1.0f;
63 return rounded;
64}
66float __fdiv_rn(float __x, float __y) { return __spirv_ocl_rint(__x / __y); }
68float __fdiv_ru(float __x, float __y) { return __spirv_ocl_ceil(__x / __y); }
70float __fdiv_rz(float __x, float __y) { return __spirv_ocl_trunc(__x / __y); }
72float __fdividef(float __x, float __y) { return __x / __y; }
73
75float __fmaf_rd(float __x, float __y, float __z) {
76 float res = __x * __y + __z;
77 float rounded = __spirv_ocl_floor(res);
78 if (rounded > res)
79 rounded -= 1.0f;
80 return rounded;
81}
83float __fmaf_rn(float __x, float __y, float __z) {
84 return __spirv_ocl_rint(__x * __y + __z);
85}
87float __fmaf_ru(float __x, float __y, float __z) {
88 return __spirv_ocl_ceil(__x * __y + __z);
89}
91float __fmaf_rz(float __x, float __y, float __z) {
92 return __spirv_ocl_trunc(__x * __y + __z);
93}
94
96float __fmul_rd(float __x, float __y) {
97 float res = __x * __y;
98 float rounded = __spirv_ocl_floor(res);
99 if (rounded > res)
100 rounded -= 1.0f;
101 return rounded;
102}
104float __fmul_rn(float __x, float __y) { return __spirv_ocl_rint(__x * __y); }
106float __fmul_ru(float __x, float __y) { return __spirv_ocl_ceil(__x * __y); }
108float __fmul_rz(float __x, float __y) { return __spirv_ocl_trunc(__x * __y); }
109
111float __frcp_rd(float __x) { return __fdiv_rd(1.0f, __x); }
113float __frcp_rn(float __x) { return __fdiv_rn(1.0f, __x); }
115float __frcp_ru(float __x) { return __fdiv_ru(1.0f, __x); }
117float __frcp_rz(float __x) { return __fdiv_rz(1.0f, __x); }
119
120float __frsqrt_rn(float __x) {
122}
123
125float __fsqrt_rd(float __x) {
126 float res = __spirv_ocl_sqrt(__x);
127 float rounded = __spirv_ocl_floor(res);
128 if (rounded > res)
129 rounded -= 1.0f;
130 return rounded;
131}
133float __fsqrt_rn(float __x) { return __spirv_ocl_rint(__spirv_ocl_sqrt(__x)); }
135float __fsqrt_ru(float __x) { return __spirv_ocl_ceil(__spirv_ocl_sqrt(__x)); }
137float __fsqrt_rz(float __x) { return __spirv_ocl_trunc(__spirv_ocl_sqrt(__x)); }
138
140float __fsub_rd(float __x, float __y) {
141 float res = __x - __y;
142 float rounded = __spirv_ocl_floor(res);
143 if (rounded > res)
144 rounded -= 1.0f;
145 return rounded;
146}
148float __fsub_rn(float __x, float __y) { return __spirv_ocl_rint(__x - __y); }
150float __fsub_ru(float __x, float __y) { return __spirv_ocl_ceil(__x - __y); }
152float __fsub_rz(float __x, float __y) { return __spirv_ocl_trunc(__x - __y); }
154float __log10f(float __x) { return __spirv_ocl_log10(__x); }
156float __log2f(float __x) { return __spirv_ocl_log2(__x); }
158float __logf(float __x) { return __spirv_ocl_log(__x); }
160float __powf(float __x, float __y) { return __spirv_ocl_pow(__x, __y); }
161
163float __saturatef(float __x) { return __spirv_ocl_fclamp(__x, 0.0f, 1.0f); }
164
166void __sincosf(float __x, float *__sinptr, float *__cosptr) {
167 *__sinptr = __spirv_ocl_sincos(__x, __cosptr);
168}
169
171float __sinf(float __x) { return __spirv_ocl_sin(__x); }
172
174float __tanf(float __x) { return __spirv_ocl_tan(__x); }
175
177int __finitef(float __x) { return !__spirv_IsInf(__x) && !__spirv_IsNan(__x); }
179int __isinff(float __x) { return __spirv_IsInf(__x); }
181int __isnanf(float __x) { return __spirv_IsNan(__x); }
183int __signbitf(float __x) { return __builtin_signbitf(__x); }
184
186int __finite(double __x) { return !__spirv_IsInf(__x) && !__spirv_IsNan(__x); }
187
189int __isinf(double __x) { return __spirv_IsInf(__x); }
190
192int __isnan(double __x) { return __spirv_IsNan(__x); }
194int __signbit(double __x) { return __builtin_signbit(__x); }
195
197double __dadd_rd(double __x, double __y) {
198 double sum = __x + __y;
199 double rounded = __spirv_ocl_floor(sum);
200 if (rounded > sum)
201 rounded -= 1.0;
202 return rounded;
203}
205double __dadd_rn(double __x, double __y) { return __spirv_ocl_rint(__x + __y); }
207double __dadd_ru(double __x, double __y) { return __spirv_ocl_ceil(__x + __y); }
209double __dadd_rz(double __x, double __y) {
210 return __spirv_ocl_trunc(__x + __y);
211}
213double __ddiv_rd(double __x, double __y) {
214 double res = __x / __y;
215 double rounded = __spirv_ocl_floor(res);
216 if (rounded > res)
217 rounded -= 1.0;
218 return rounded;
219}
221double __ddiv_rn(double __x, double __y) { return __spirv_ocl_rint(__x / __y); }
223double __ddiv_ru(double __x, double __y) { return __spirv_ocl_ceil(__x / __y); }
225double __ddiv_rz(double __x, double __y) {
226 return __spirv_ocl_trunc(__x / __y);
227}
228
230double __dmul_rd(double __x, double __y) {
231 double res = __x * __y;
232 double rounded = __spirv_ocl_floor(res);
233 if (rounded > res)
234 rounded -= 1.0;
235 return rounded;
236}
238double __dmul_rn(double __x, double __y) { return __spirv_ocl_rint(__x * __y); }
240double __dmul_ru(double __x, double __y) { return __spirv_ocl_ceil(__x * __y); }
242double __dmul_rz(double __x, double __y) {
243 return __spirv_ocl_trunc(__x * __y);
244}
245
247double __drcp_rd(double __x) { return __ddiv_rd(1.0, __x); }
249double __drcp_rn(double __x) { return __ddiv_rn(1.0, __x); }
251double __drcp_ru(double __x) { return __ddiv_ru(1.0, __x); }
253double __drcp_rz(double __x) { return __ddiv_rz(1.0, __x); }
254
256double __dsqrt_rd(double __x) {
257 double res = __spirv_ocl_sqrt(__x);
258 double rounded = __spirv_ocl_floor(res);
259 if (rounded > res)
260 rounded -= 1.0;
261 return rounded;
262}
264double __dsqrt_rn(double __x) {
266}
268double __dsqrt_ru(double __x) {
270}
272double __dsqrt_rz(double __x) {
274}
275
277double __dsub_rd(double __x, double __y) {
278 double res = __x - __y;
279 double rounded = __spirv_ocl_floor(res);
280 if (rounded > res)
281 rounded -= 1.0;
282 return rounded;
283}
285double __dsub_rn(double __x, double __y) { return __spirv_ocl_rint(__x - __y); }
287double __dsub_ru(double __x, double __y) { return __spirv_ocl_ceil(__x - __y); }
289double __dsub_rz(double __x, double __y) {
290 return __spirv_ocl_trunc(__x - __y);
291}
292
294double __fma_rd(double __x, double __y, double __z) {
295 double res = __x * __y + __z;
296 double rounded = __spirv_ocl_floor(res);
297 if (rounded > res)
298 rounded -= 1.0;
299 return rounded;
300}
302double __fma_rn(double __x, double __y, double __z) {
303 return __spirv_ocl_rint(__x * __y + __z);
304}
306double __fma_ru(double __x, double __y, double __z) {
307 return __spirv_ocl_ceil(__x * __y + __z);
308}
310double __fma_rz(double __x, double __y, double __z) {
311 return __spirv_ocl_trunc(__x * __y + __z);
312}
313
315__DEVICE__ double fabs(double __a) { return __spirv_ocl_fabs(__a); }
316__DEVICE__ double acos(double __a) { return __spirv_ocl_acos(__a); }
317__DEVICE__ float acosf(float __a) { return __spirv_ocl_acos(__a); }
318__DEVICE__ double acosh(double __a) { return __spirv_ocl_acosh(__a); }
319__DEVICE__ float acoshf(float __a) { return __spirv_ocl_acosh(__a); }
320__DEVICE__ double asin(double __a) { return __spirv_ocl_asin(__a); }
321__DEVICE__ float asinf(float __a) { return __spirv_ocl_asin(__a); }
322__DEVICE__ double asinh(double __a) { return __spirv_ocl_asinh(__a); }
323__DEVICE__ float asinhf(float __a) { return __spirv_ocl_asinh(__a); }
324__DEVICE__ double atan(double __a) { return __spirv_ocl_atan(__a); }
325__DEVICE__ double atan2(double __a, double __b) {
326 return __spirv_ocl_atan2(__a, __b);
327}
328__DEVICE__ float atan2f(float __a, float __b) {
329 return __spirv_ocl_atan2(__a, __b);
330}
331__DEVICE__ float atanf(float __a) { return __spirv_ocl_atan(__a); }
332__DEVICE__ double atanh(double __a) { return __spirv_ocl_atanh(__a); }
333__DEVICE__ float atanhf(float __a) { return __spirv_ocl_atanh(__a); }
334__DEVICE__ double cbrt(double __a) { return __spirv_ocl_cbrt(__a); }
335__DEVICE__ float cbrtf(float __a) { return __spirv_ocl_cbrt(__a); }
336__DEVICE__ double ceil(double __a) { return __spirv_ocl_ceil(__a); }
337__DEVICE__ float ceilf(float __a) { return __spirv_ocl_ceil(__a); }
338__DEVICE__ double copysign(double __a, double __b) {
340}
341__DEVICE__ float copysignf(float __a, float __b) {
343}
344__DEVICE__ double cos(double __a) { return __spirv_ocl_cos(__a); }
345__DEVICE__ float cosf(float __a) { return __spirv_ocl_cos(__a); }
346__DEVICE__ double cosh(double __a) { return __spirv_ocl_cosh(__a); }
347__DEVICE__ float coshf(float __a) { return __spirv_ocl_cosh(__a); }
348__DEVICE__ double cospi(double __a) { return __spirv_ocl_cospi(__a); }
349__DEVICE__ float cospif(float __a) { return __spirv_ocl_cospi(__a); }
350__DEVICE__ double erf(double __a) { return __spirv_ocl_erf(__a); }
351__DEVICE__ double erfc(double __a) { return __spirv_ocl_erfc(__a); }
352__DEVICE__ float erfcf(float __a) { return __spirv_ocl_erfc(__a); }
353__DEVICE__ double erfcx(double __a) {
355}
356__DEVICE__ float erfcxf(float __a) {
358}
359__DEVICE__ float erff(float __a) { return __spirv_ocl_erf(__a); }
360__DEVICE__ double exp(double __a) { return __spirv_ocl_exp(__a); }
361__DEVICE__ double exp10(double __a) { return __spirv_ocl_exp10(__a); }
362__DEVICE__ float exp10f(float __a) { return __spirv_ocl_exp10(__a); }
363__DEVICE__ double exp2(double __a) { return __spirv_ocl_exp2(__a); }
364__DEVICE__ float exp2f(float __a) { return __spirv_ocl_exp2(__a); }
365__DEVICE__ float expf(float __a) { return __spirv_ocl_exp(__a); }
366__DEVICE__ double expm1(double __a) { return __spirv_ocl_expm1(__a); }
367__DEVICE__ float expm1f(float __a) { return __spirv_ocl_expm1(__a); }
368__DEVICE__ float fabsf(float __a) { return __spirv_ocl_fabs(__a); }
369__DEVICE__ double fdim(double __a, double __b) {
370 return __spirv_ocl_fdim(__a, __b);
371}
372__DEVICE__ float fdimf(float __a, float __b) {
373 return __spirv_ocl_fdim(__a, __b);
374}
375__DEVICE__ double fdivide(double __a, double __b) { return __a / __b; }
376__DEVICE__ float fdividef(float __a, float __b) { return __a / __b; }
377__DEVICE__ double floor(double __f) { return __spirv_ocl_floor(__f); }
378__DEVICE__ float floorf(float __f) { return __spirv_ocl_floor(__f); }
379__DEVICE__ double fma(double __a, double __b, double __c) {
380 return __spirv_ocl_fma(__a, __b, __c);
381}
382__DEVICE__ float fmaf(float __a, float __b, float __c) {
383 return __spirv_ocl_fma(__a, __b, __c);
384}
385__DEVICE__ double fmax(double __a, double __b) {
386 return __spirv_ocl_fmax(__a, __b);
387}
388__DEVICE__ float fmaxf(float __a, float __b) {
389 return __spirv_ocl_fmax(__a, __b);
390}
391__DEVICE__ double fmin(double __a, double __b) {
392 return __spirv_ocl_fmin(__a, __b);
393}
394__DEVICE__ float fminf(float __a, float __b) {
395 return __spirv_ocl_fmin(__a, __b);
396}
397__DEVICE__ double fmod(double __a, double __b) {
398 return __spirv_ocl_fmod(__a, __b);
399}
400__DEVICE__ float fmodf(float __a, float __b) {
401 return __spirv_ocl_fmod(__a, __b);
402}
403__DEVICE__ double frexp(double __a, int *__b) {
404 return __spirv_ocl_frexp(__a, __b);
405}
406__DEVICE__ float frexpf(float __a, int *__b) {
407 return __spirv_ocl_frexp(__a, __b);
408}
409__DEVICE__ double hypot(double __a, double __b) {
410 return __spirv_ocl_hypot(__a, __b);
411}
412__DEVICE__ float hypotf(float __a, float __b) {
413 return __spirv_ocl_hypot(__a, __b);
414}
415__DEVICE__ int ilogb(double __a) { return __spirv_ocl_ilogb(__a); }
417__DEVICE__ long labs(long __a) { return __spirv_ocl_s_abs(__a); };
418__DEVICE__ double ldexp(double __a, int __b) {
419 return __spirv_ocl_ldexp(__a, __b);
420}
421__DEVICE__ float ldexpf(float __a, int __b) {
422 return __spirv_ocl_ldexp(__a, __b);
423}
424__DEVICE__ double lgamma(double __a) { return __spirv_ocl_lgamma(__a); }
425__DEVICE__ float lgammaf(float __a) { return __spirv_ocl_lgamma(__a); }
426__DEVICE__ long long llabs(long long __a) { return __spirv_ocl_s_abs(__a); }
427__DEVICE__ long long llmax(long long __a, long long __b) {
428 return __spirv_ocl_s_max(__a, __b);
429}
430__DEVICE__ long long llmin(long long __a, long long __b) {
431 return __spirv_ocl_s_min(__a, __b);
432}
433__DEVICE__ long long llrint(double __a) { return __builtin_rint(__a); }
434__DEVICE__ long long llrintf(float __a) { return __builtin_rintf(__a); }
435__DEVICE__ long long llround(double __a) { return __builtin_round(__a); }
436__DEVICE__ long long llroundf(float __a) { return __builtin_roundf(__a); }
437__DEVICE__ double round(double __a) { return __spirv_ocl_round(__a); }
438__DEVICE__ float roundf(float __a) { return __spirv_ocl_round(__a); }
439__DEVICE__ double log(double __a) { return __spirv_ocl_log(__a); }
440__DEVICE__ double log10(double __a) { return __spirv_ocl_log10(__a); }
441__DEVICE__ float log10f(float __a) { return __spirv_ocl_log10(__a); }
442__DEVICE__ double log1p(double __a) { return __spirv_ocl_log1p(__a); }
443__DEVICE__ float log1pf(float __a) { return __spirv_ocl_log1p(__a); }
444__DEVICE__ double log2(double __a) { return __spirv_ocl_log2(__a); }
445__DEVICE__ float log2f(float __a) { return __spirv_ocl_log2(__a); }
446__DEVICE__ double logb(double __a) { return __spirv_ocl_logb(__a); }
447__DEVICE__ float logbf(float __a) { return __spirv_ocl_logb(__a); }
448__DEVICE__ float logf(float __a) { return __spirv_ocl_log(__a); }
449__DEVICE__ long lrint(double __a) { return __builtin_rint(__a); }
450__DEVICE__ long lrintf(float __a) { return __builtin_rintf(__a); }
451__DEVICE__ long lround(double __a) { return __builtin_round(__a); }
452__DEVICE__ long lroundf(float __a) { return __builtin_roundf(__a); }
453__DEVICE__ int max(int __a, int __b) { return __spirv_ocl_s_max(__a, __b); }
454__DEVICE__ int min(int __a, int __b) { return __spirv_ocl_s_min(__a, __b); }
455__DEVICE__ double modf(double __a, double *__b) {
456 return __spirv_ocl_modf(__a, __b);
457}
458__DEVICE__ float modff(float __a, float *__b) {
459 return __spirv_ocl_modf(__a, __b);
460}
461__DEVICE__ double nearbyint(double __a) { return __spirv_ocl_rint(__a); }
463__DEVICE__ double nextafter(double __a, double __b) {
465}
466__DEVICE__ float nextafterf(float __a, float __b) {
468}
469
470__DEVICE__ double norm(int __dim, const double *__a) {
471 double __r = 0;
472 while (__dim--) {
473 __r += __a[0] * __a[0];
474 ++__a;
475 }
476
477 return __spirv_ocl_sqrt(__r);
478}
479__DEVICE__ double norm3d(double __a, double __b, double __c) {
480 return __spirv_ocl_sqrt(__a * __a + __b * __b + __c * __c);
481}
482__DEVICE__ float norm3df(float __a, float __b, float __c) {
483 return __spirv_ocl_sqrt(__a * __a + __b * __b + __c * __c);
484}
485__DEVICE__ double norm4d(double __a, double __b, double __c, double __d) {
486 return __spirv_ocl_sqrt(__a * __a + __b * __b + __c * __c + __d * __d);
487}
488__DEVICE__ float norm4df(float __a, float __b, float __c, float __d) {
489 return __spirv_ocl_sqrt(__a * __a + __b * __b + __c * __c + __d * __d);
490}
491__DEVICE__ double normcdf(double __a) {
492 return 0.5 * (1.0 + __spirv_ocl_erf(__a * __spirv_ocl_rsqrt(2.0)));
493}
494__DEVICE__ float normcdff(float __a) {
495 return 0.5f * (1.0f + __spirv_ocl_erf(__a * __spirv_ocl_rsqrt(2.0f)));
496}
497__DEVICE__ float normf(int __dim, const float *__a) {
498 float __r = 0;
499 while (__dim--) {
500 __r += __a[0] * __a[0];
501 ++__a;
502 }
503 return __spirv_ocl_sqrt(__r);
504}
505__DEVICE__ double pow(double __a, double __b) {
506 return __spirv_ocl_pow(__a, __b);
507}
508__DEVICE__ float powf(float __a, float __b) {
509 return __spirv_ocl_pow(__a, __b);
510}
511__DEVICE__ double powi(double __a, int __b) { return pow(__a, (double)__b); }
512__DEVICE__ float powif(float __a, int __b) { return pow(__a, (float)__b); }
513__DEVICE__ double rcbrt(double __a) { return 1.0 / __spirv_ocl_cbrt(__a); }
514__DEVICE__ float rcbrtf(float __a) { return 1.0f / __spirv_ocl_cbrt(__a); }
515__DEVICE__ double remainder(double __a, double __b) {
517}
518__DEVICE__ float remainderf(float __a, float __b) {
520}
521__DEVICE__ double remquo(double __a, double __b, int *__c) {
522 return __spirv_ocl_remquo(__a, __b, __c);
523}
524__DEVICE__ float remquof(float __a, float __b, int *__c) {
525 return __spirv_ocl_remquo(__a, __b, __c);
526}
527__DEVICE__ double rhypot(double __a, double __b) {
528 return __spirv_ocl_hypot(__a, __b);
529}
530__DEVICE__ float rhypotf(float __a, float __b) {
531 return __spirv_ocl_hypot(__a, __b);
532}
533__DEVICE__ double rint(double __a) { return __spirv_ocl_rint(__a); }
534__DEVICE__ float rintf(float __a) { return __spirv_ocl_rint(__a); }
535__DEVICE__ double rnorm(int __dim, const double *__a) {
536 double __r = 0;
537 while (__dim--) {
538 __r += __a[0] * __a[0];
539 ++__a;
540 }
541
542 return __spirv_ocl_rsqrt(__r);
543}
544__DEVICE__ double rnorm3d(double __a, double __b, double __c) {
545 return __spirv_ocl_rsqrt(__a * __a + __b * __b + __c * __c);
546}
547__DEVICE__ float rnorm3df(float __a, float __b, float __c) {
548 return __spirv_ocl_rsqrt(__a * __a + __b * __b + __c * __c);
549}
550__DEVICE__ double rnorm4d(double __a, double __b, double __c, double __d) {
551 return __spirv_ocl_rsqrt(__a * __a + __b * __b + __c * __c + __d * __d);
552}
553__DEVICE__ float rnorm4df(float __a, float __b, float __c, float __d) {
554 return __spirv_ocl_rsqrt(__a * __a + __b * __b + __c * __c + __d * __d);
555}
556__DEVICE__ float rnormf(int __dim, const float *__a) {
557 float __r = 0;
558 while (__dim--) {
559 __r += __a[0] * __a[0];
560 ++__a;
561 }
562
563 return __spirv_ocl_rsqrt(__r);
564}
565__DEVICE__ double rsqrt(double __a) { return __spirv_ocl_rsqrt(__a); }
566__DEVICE__ float rsqrtf(float __a) { return __spirv_ocl_rsqrt(__a); }
567__DEVICE__ double scalbn(double __a, int __b) {
568 return __spirv_ocl_ldexp(__a, __b);
569}
570__DEVICE__ float scalbnf(float __a, int __b) {
571 return __spirv_ocl_ldexp(__a, __b);
572}
573__DEVICE__ double scalbln(double __a, long __b) {
574 if (__b > INT_MAX)
575 return __a > 0 ? HUGE_VAL : -HUGE_VAL;
576 if (__b < INT_MIN)
577 return __a > 0 ? 0.0 : -0.0;
578 return scalbn(__a, (int)__b);
579}
580__DEVICE__ float scalblnf(float __a, long __b) {
581 if (__b > INT_MAX)
582 return __a > 0 ? HUGE_VALF : -HUGE_VALF;
583 if (__b < INT_MIN)
584 return __a > 0 ? 0.f : -0.f;
585 return scalbnf(__a, (int)__b);
586}
587__DEVICE__ double sin(double __a) { return __spirv_ocl_sin(__a); }
588__DEVICE__ void sincos(double __a, double *__s, double *__c) {
589 *__s = __spirv_ocl_sincos(__a, __c);
590}
591__DEVICE__ void sincosf(float __a, float *__s, float *__c) {
592 *__s = __spirv_ocl_sincos(__a, __c);
593}
594__DEVICE__ void sincospi(double __a, double *__s, double *__c) {
595 *__s = __spirv_ocl_sinpi(__a);
597}
598__DEVICE__ void sincospif(float __a, float *__s, float *__c) {
599 *__s = __spirv_ocl_sinpi(__a);
601}
602__DEVICE__ float sinf(float __a) { return __spirv_ocl_sin(__a); }
603__DEVICE__ double sinh(double __a) { return __spirv_ocl_sinh(__a); }
604__DEVICE__ float sinhf(float __a) { return __spirv_ocl_sinh(__a); }
605__DEVICE__ double sinpi(double __a) { return __spirv_ocl_sinpi(__a); }
606__DEVICE__ float sinpif(float __a) { return __spirv_ocl_sinpi(__a); }
607__DEVICE__ double sqrt(double __a) { return __spirv_ocl_sqrt(__a); }
608__DEVICE__ float sqrtf(float __a) { return __spirv_ocl_sqrt(__a); }
609__DEVICE__ double tan(double __a) { return __spirv_ocl_tan(__a); }
610__DEVICE__ float tanf(float __a) { return __spirv_ocl_tan(__a); }
611__DEVICE__ double tanh(double __a) { return __spirv_ocl_tanh(__a); }
612__DEVICE__ float tanhf(float __a) { return __spirv_ocl_tanh(__a); }
613__DEVICE__ double tgamma(double __a) { return __spirv_ocl_tgamma(__a); }
614__DEVICE__ float tgammaf(float __a) { return __spirv_ocl_tgamma(__a); }
615__DEVICE__ double trunc(double __a) { return __spirv_ocl_trunc(__a); }
616__DEVICE__ float truncf(float __a) { return __spirv_ocl_trunc(__a); }
617__DEVICE__ unsigned long long ullmax(unsigned long long __a,
618 unsigned long long __b) {
619 return __spirv_ocl_u_max(__a, __b);
620}
621__DEVICE__ unsigned long long ullmin(unsigned long long __a,
622 unsigned long long __b) {
623 return __spirv_ocl_u_min(__a, __b);
624}
625__DEVICE__ unsigned int umax(unsigned int __a, unsigned int __b) {
626 return __spirv_ocl_u_max(__a, __b);
627}
628__DEVICE__ unsigned int umin(unsigned int __a, unsigned int __b) {
629 return __spirv_ocl_u_min(__a, __b);
630}
631
632#if !defined(__cplusplus) && __STDC_VERSION__ >= 201112L
633#define isfinite(__x) _Generic((__x), float: __finitef, double: __finite)(__x)
634#define isinf(__x) _Generic((__x), float: __isinff, double: __isinf)(__x)
635#define isnan(__x) _Generic((__x), float: __isnanf, double: __isnan)(__x)
636#define signbit(__x) _Generic((__x), float: __signbitf, double: __signbit)(__x)
637#endif // !defined(__cplusplus) && __STDC_VERSION__ >= 201112L
638
640unsigned long __make_mantissa_base8(const char *__tagp) {
641 unsigned long __r = 0;
642 while (*__tagp != '\0') {
643 char __tmp = *__tagp;
644
645 if (__tmp >= '0' && __tmp <= '7')
646 __r = (__r * 8u) + __tmp - '0';
647 else
648 return 0;
649
650 ++__tagp;
651 }
652
653 return __r;
654}
655
657unsigned long __make_mantissa_base10(const char *__tagp) {
658 unsigned long __r = 0;
659 while (*__tagp != '\0') {
660 char __tmp = *__tagp;
661
662 if (__tmp >= '0' && __tmp <= '9')
663 __r = (__r * 10u) + __tmp - '0';
664 else
665 return 0;
666
667 ++__tagp;
668 }
669
670 return __r;
671}
672
674unsigned long __make_mantissa_base16(const char *__tagp) {
675 unsigned long __r = 0;
676 while (*__tagp != '\0') {
677 char __tmp = *__tagp;
678
679 if (__tmp >= '0' && __tmp <= '9')
680 __r = (__r * 16u) + __tmp - '0';
681 else if (__tmp >= 'a' && __tmp <= 'f')
682 __r = (__r * 16u) + __tmp - 'a' + 10;
683 else if (__tmp >= 'A' && __tmp <= 'F')
684 __r = (__r * 16u) + __tmp - 'A' + 10;
685 else
686 return 0;
687
688 ++__tagp;
689 }
690
691 return __r;
692}
693
695unsigned long __make_mantissa(const char *__tagp) {
696 if (!__tagp)
697 return 0;
698 if (*__tagp == '0') {
699 ++__tagp;
700
701 if (*__tagp == 'x' || *__tagp == 'X')
702 return __make_mantissa_base16(++__tagp);
703 else
704 return __make_mantissa_base8(__tagp);
705 }
706
707 return __make_mantissa_base10(__tagp);
708}
709
710float nanf(const char *__tagp) {
711 return __spirv_ocl_nan((unsigned int)__make_mantissa(__tagp));
712}
713double nan(const char *__tagp) {
714 return __spirv_ocl_nan(__make_mantissa(__tagp));
715}
716
717#pragma pop_macro("__DEVICE__")
718#endif // __CLANG_GPU_DISABLE_MATH_WRAPPERS
719#endif // __CLANG_SPIRV_MATH_H__
#define __DEVICE__
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_ldexp(float, int)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_modf(float, float *)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_fmax(float, float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_ceil(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_fclamp(float, float, float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_cbrt(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_remainder(float, float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_pow(float, float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_fabs(float)
_CLC_OVERLOAD _CLC_CONSTFN unsigned int __spirv_ocl_u_max(unsigned int, unsigned int)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_sqrt(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_atanh(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_remquo(float, float, int *)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_tgamma(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_sin(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_cos(float)
_CLC_OVERLOAD _CLC_CONSTFN bool __spirv_IsNan(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_expm1(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_log1p(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_fma(float, float, float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_log2(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_atan(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_copysign(float, float)
_CLC_OVERLOAD _CLC_CONSTFN unsigned int __spirv_ocl_u_min(unsigned int, unsigned int)
_CLC_OVERLOAD _CLC_CONSTFN int __spirv_ocl_s_max(int, int)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_sincos(float, float *)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_frexp(float, int *)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_nan(int)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_lgamma(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_acos(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_rsqrt(float)
_CLC_OVERLOAD _CLC_CONSTFN int __spirv_ocl_ilogb(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_acosh(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_round(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_fdim(float, float)
_CLC_OVERLOAD _CLC_CONSTFN unsigned int __spirv_ocl_s_abs(int)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_log10(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_sinh(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_erf(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_hypot(float, float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_nextafter(float, float)
_CLC_OVERLOAD _CLC_CONSTFN int __spirv_ocl_s_min(int, int)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_log(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_logb(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_cospi(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_trunc(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_cosh(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_exp10(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_fmin(float, float)
_CLC_OVERLOAD _CLC_CONSTFN bool __spirv_IsInf(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_floor(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_fmod(float, float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_asinh(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_exp2(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_tanh(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_exp(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_erfc(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_tan(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_atan2(float, float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_sinpi(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_asin(float)
_CLC_OVERLOAD _CLC_CONSTFN float __spirv_ocl_rint(float)
__DEVICE__ unsigned long __make_mantissa_base10(const char *__tagp)
__DEVICE__ double __dsub_rn(double __x, double __y)
__DEVICE__ double powi(double __a, int __b)
__DEVICE__ float fabsf(float __a)
__DEVICE__ double rhypot(double __a, double __b)
__DEVICE__ float fmodf(float __a, float __b)
__DEVICE__ float remainderf(float __a, float __b)
__DEVICE__ float exp2f(float __a)
__DEVICE__ float __fsqrt_rd(float __x)
__DEVICE__ float rsqrtf(float __a)
__DEVICE__ float acosf(float __a)
__DEVICE__ double __fma_ru(double __x, double __y, double __z)
__DEVICE__ float fmaf(float __a, float __b, float __c)
__DEVICE__ double __ddiv_rz(double __x, double __y)
__DEVICE__ float __fmaf_rz(float __x, float __y, float __z)
__DEVICE__ float cbrtf(float __a)
__DEVICE__ float __fdiv_rn(float __x, float __y)
__DEVICE__ float remquof(float __a, float __b, int *__c)
__DEVICE__ void sincospi(double __a, double *__s, double *__c)
__DEVICE__ double __drcp_rd(double __x)
__DEVICE__ float tanf(float __a)
__DEVICE__ long labs(long __a)
__DEVICE__ float nextafterf(float __a, float __b)
__DEVICE__ void sincos(double __a, double *__s, double *__c)
__DEVICE__ float fmaxf(float __a, float __b)
__DEVICE__ double __ddiv_ru(double __x, double __y)
__DEVICE__ double __dsqrt_rn(double __x)
__DEVICE__ float __sinf(float __x)
__DEVICE__ float __fmaf_rd(float __x, float __y, float __z)
__DEVICE__ long long llabs(long long __a)
__DEVICE__ float __fadd_ru(float __x, float __y)
__DEVICE__ float fminf(float __a, float __b)
__DEVICE__ float log2f(float __a)
__DEVICE__ double normcdf(double __a)
__DEVICE__ double __dsub_rd(double __x, double __y)
__DEVICE__ float norm3df(float __a, float __b, float __c)
__DEVICE__ float __fadd_rz(float __x, float __y)
__DEVICE__ float copysignf(float __a, float __b)
__DEVICE__ float truncf(float __a)
__DEVICE__ float fdimf(float __a, float __b)
__DEVICE__ float rcbrtf(float __a)
__DEVICE__ long lrintf(float __a)
__DEVICE__ long long llrintf(float __a)
__DEVICE__ float cosf(float __a)
__DEVICE__ float rnormf(int __dim, const float *__a)
__DEVICE__ double fdivide(double __a, double __b)
__DEVICE__ float __fsub_rz(float __x, float __y)
__DEVICE__ float __cosf(float __x)
__DEVICE__ float __fdiv_ru(float __x, float __y)
__DEVICE__ float sinf(float __a)
__DEVICE__ float sinpif(float __a)
__DEVICE__ double norm(int __dim, const double *__a)
__DEVICE__ double __dmul_rz(double __x, double __y)
__DEVICE__ double __fma_rz(double __x, double __y, double __z)
__DEVICE__ float logf(float __a)
__DEVICE__ int min(int __a, int __b)
__DEVICE__ float __fmul_ru(float __x, float __y)
__DEVICE__ float erff(float __a)
__DEVICE__ float floorf(float __f)
__DEVICE__ float __fdividef(float __x, float __y)
__DEVICE__ float __frsqrt_rn(float __x)
__DEVICE__ float __log2f(float __x)
__DEVICE__ float ceilf(float __a)
__DEVICE__ float nearbyintf(float __a)
__DEVICE__ float atanf(float __a)
__DEVICE__ float __fdiv_rd(float __x, float __y)
__DEVICE__ float rnorm4df(float __a, float __b, float __c, float __d)
__DEVICE__ float atanhf(float __a)
__DEVICE__ long long llmin(long long __a, long long __b)
__DEVICE__ float tanhf(float __a)
__DEVICE__ float __exp10f(float __x)
__DEVICE__ double rnorm4d(double __a, double __b, double __c, double __d)
__DEVICE__ double __dsqrt_rz(double __x)
__DEVICE__ float __frcp_rn(float __x)
__DEVICE__ long long llmax(long long __a, long long __b)
__DEVICE__ float rhypotf(float __a, float __b)
__DEVICE__ float exp10f(float __a)
__DEVICE__ float __fsub_rn(float __x, float __y)
__DEVICE__ double __dmul_ru(double __x, double __y)
__DEVICE__ double rcbrt(double __a)
__DEVICE__ float rintf(float __a)
__DEVICE__ float atan2f(float __a, float __b)
__DEVICE__ double __dadd_rn(double __x, double __y)
__DEVICE__ float sinhf(float __a)
__DEVICE__ unsigned long long ullmin(unsigned long long __a, unsigned long long __b)
__DEVICE__ float __fsub_rd(float __x, float __y)
__DEVICE__ double __dadd_rz(double __x, double __y)
__DEVICE__ float acoshf(float __a)
__DEVICE__ float __fadd_rd(float __x, float __y)
__DEVICE__ float __tanf(float __x)
__DEVICE__ unsigned long long ullmax(unsigned long long __a, unsigned long long __b)
__DEVICE__ double __fma_rd(double __x, double __y, double __z)
__DEVICE__ float __fsqrt_rn(float __x)
__DEVICE__ float __fsqrt_ru(float __x)
__DEVICE__ float log10f(float __a)
__DEVICE__ float __fmaf_rn(float __x, float __y, float __z)
float nanf(const char *__tagp)
__DEVICE__ int abs(int __a)
__DEVICE__ float ldexpf(float __a, int __b)
__DEVICE__ double __drcp_ru(double __x)
__DEVICE__ int __finitef(float __x)
__DEVICE__ int __isnan(double __x)
__DEVICE__ double __dmul_rd(double __x, double __y)
__DEVICE__ double __dsub_ru(double __x, double __y)
__DEVICE__ double __dsqrt_rd(double __x)
__DEVICE__ float __fadd_rn(float __x, float __y)
__DEVICE__ float normcdff(float __a)
__DEVICE__ float __fdiv_rz(float __x, float __y)
__DEVICE__ double cospi(double __a)
__DEVICE__ int __isnanf(float __x)
__DEVICE__ float __frcp_rd(float __x)
__DEVICE__ double __dadd_ru(double __x, double __y)
__DEVICE__ void sincosf(float __a, float *__s, float *__c)
__DEVICE__ double sinpi(double __a)
__DEVICE__ float modff(float __a, float *__b)
__DEVICE__ float erfcxf(float __a)
__DEVICE__ float __fmul_rz(float __x, float __y)
__DEVICE__ float logbf(float __a)
__DEVICE__ float __expf(float __x)
__DEVICE__ float __fmaf_ru(float __x, float __y, float __z)
__DEVICE__ float __logf(float __x)
__DEVICE__ double __fma_rn(double __x, double __y, double __z)
__DEVICE__ double rnorm(int __dim, const double *__a)
__DEVICE__ int __isinff(float __x)
__DEVICE__ float powif(float __a, int __b)
__DEVICE__ float coshf(float __a)
__DEVICE__ float asinhf(float __a)
__DEVICE__ float roundf(float __a)
__DEVICE__ double __dadd_rd(double __x, double __y)
__DEVICE__ float __frcp_rz(float __x)
__DEVICE__ long lroundf(float __a)
__DEVICE__ int __finite(double __x)
__DEVICE__ float norm4df(float __a, float __b, float __c, float __d)
__DEVICE__ float scalbnf(float __a, int __b)
__DEVICE__ void __sincosf(float __x, float *__sinptr, float *__cosptr)
__DEVICE__ float erfcf(float __a)
__DEVICE__ double modf(double __a, double *__b)
__DEVICE__ double __ddiv_rn(double __x, double __y)
__DEVICE__ double __ddiv_rd(double __x, double __y)
__DEVICE__ int ilogbf(float __a)
__DEVICE__ double norm3d(double __a, double __b, double __c)
__DEVICE__ float __fmul_rd(float __x, float __y)
__DEVICE__ float powf(float __a, float __b)
__DEVICE__ void sincospif(float __a, float *__s, float *__c)
__DEVICE__ double norm4d(double __a, double __b, double __c, double __d)
__DEVICE__ unsigned long __make_mantissa(const char *__tagp)
__DEVICE__ int __signbitf(float __x)
__DEVICE__ double __dmul_rn(double __x, double __y)
__DEVICE__ float normf(int __dim, const float *__a)
__DEVICE__ unsigned int umin(unsigned int __a, unsigned int __b)
__DEVICE__ float rnorm3df(float __a, float __b, float __c)
__DEVICE__ float cospif(float __a)
__DEVICE__ float frexpf(float __a, int *__b)
__DEVICE__ double erfcx(double __a)
__DEVICE__ float sqrtf(float __a)
__DEVICE__ unsigned int umax(unsigned int __a, unsigned int __b)
__DEVICE__ double __dsub_rz(double __x, double __y)
__DEVICE__ unsigned long __make_mantissa_base8(const char *__tagp)
__DEVICE__ double __drcp_rn(double __x)
__DEVICE__ double exp10(double __a)
__DEVICE__ unsigned long __make_mantissa_base16(const char *__tagp)
__DEVICE__ float fdividef(float __a, float __b)
__DEVICE__ float expf(float __a)
__DEVICE__ float __frcp_ru(float __x)
__DEVICE__ int __signbit(double __x)
__DEVICE__ float expm1f(float __a)
__DEVICE__ float __fsub_ru(float __x, float __y)
__DEVICE__ float scalblnf(float __a, long __b)
__DEVICE__ int max(int __a, int __b)
__DEVICE__ float tgammaf(float __a)
__DEVICE__ double rsqrt(double __a)
__DEVICE__ double __dsqrt_ru(double __x)
__DEVICE__ float log1pf(float __a)
__DEVICE__ double __drcp_rz(double __x)
__DEVICE__ float __log10f(float __x)
__DEVICE__ float lgammaf(float __a)
__DEVICE__ float __fsqrt_rz(float __x)
__DEVICE__ float __fmul_rn(float __x, float __y)
double nan(const char *__tagp)
__DEVICE__ long long llroundf(float __a)
__DEVICE__ int __isinf(double __x)
__DEVICE__ double rnorm3d(double __a, double __b, double __c)
__DEVICE__ float hypotf(float __a, float __b)
__DEVICE__ float __saturatef(float __x)
__DEVICE__ float __powf(float __x, float __y)
__DEVICE__ float asinf(float __a)
static __inline__ vector float vector float vector float __c
Definition altivec.h:4800
static __inline__ vector float vector float __b
Definition altivec.h:578
static __inline__ uint32_t uint32_t __y
Definition arm_acle.h:132
static __inline__ void int __a
Definition emmintrin.h:4077
#define INT_MIN
Definition limits.h:55
#define INT_MAX
Definition limits.h:50
#define HUGE_VALF
A positive float constant expression.
#define HUGE_VAL
A positive double constant expression.
#define sinh(__x)
Definition tgmath.h:373
#define asin(__x)
Definition tgmath.h:112
#define scalbln(__x, __y)
Definition tgmath.h:1182
#define sqrt(__x)
Definition tgmath.h:520
#define acos(__x)
Definition tgmath.h:83
#define fmin(__x, __y)
Definition tgmath.h:780
#define exp(__x)
Definition tgmath.h:431
#define ilogb(__x)
Definition tgmath.h:851
#define copysign(__x, __y)
Definition tgmath.h:618
#define erf(__x)
Definition tgmath.h:636
#define atanh(__x)
Definition tgmath.h:228
#define remquo(__x, __y, __z)
Definition tgmath.h:1111
#define nextafter(__x, __y)
Definition tgmath.h:1055
#define frexp(__x, __y)
Definition tgmath.h:816
#define asinh(__x)
Definition tgmath.h:199
#define erfc(__x)
Definition tgmath.h:653
#define atan2(__x, __y)
Definition tgmath.h:566
#define hypot(__x, __y)
Definition tgmath.h:833
#define exp2(__x)
Definition tgmath.h:670
#define sin(__x)
Definition tgmath.h:286
#define cbrt(__x)
Definition tgmath.h:584
#define log2(__x)
Definition tgmath.h:970
#define llround(__x)
Definition tgmath.h:919
#define cosh(__x)
Definition tgmath.h:344
#define trunc(__x)
Definition tgmath.h:1216
#define fmax(__x, __y)
Definition tgmath.h:762
#define ldexp(__x, __y)
Definition tgmath.h:868
#define acosh(__x)
Definition tgmath.h:170
#define tgamma(__x)
Definition tgmath.h:1199
#define scalbn(__x, __y)
Definition tgmath.h:1165
#define round(__x)
Definition tgmath.h:1148
#define fmod(__x, __y)
Definition tgmath.h:798
#define llrint(__x)
Definition tgmath.h:902
#define tan(__x)
Definition tgmath.h:315
#define cos(__x)
Definition tgmath.h:257
#define log10(__x)
Definition tgmath.h:936
#define fabs(__x)
Definition tgmath.h:549
#define pow(__x, __y)
Definition tgmath.h:490
#define log1p(__x)
Definition tgmath.h:953
#define rint(__x)
Definition tgmath.h:1131
#define expm1(__x)
Definition tgmath.h:687
#define remainder(__x, __y)
Definition tgmath.h:1090
#define fdim(__x, __y)
Definition tgmath.h:704
#define lgamma(__x)
Definition tgmath.h:885
#define tanh(__x)
Definition tgmath.h:402
#define lrint(__x)
Definition tgmath.h:1004
#define atan(__x)
Definition tgmath.h:141
#define floor(__x)
Definition tgmath.h:722
#define ceil(__x)
Definition tgmath.h:601
#define log(__x)
Definition tgmath.h:460
#define logb(__x)
Definition tgmath.h:987
#define nearbyint(__x)
Definition tgmath.h:1038
#define lround(__x)
Definition tgmath.h:1021
#define fma(__x, __y, __z)
Definition tgmath.h:742