mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-09 10:50:08 +00:00
5c22fd25c1
The CORE-MATH implementation is correctly rounded (for any rounding mode) and shows better performance compared to the generic exp2m1f. The code was adapted to glibc style and to use the definition of math_config.h (to handle errno, overflow, and underflow). The only change is to handle FLT_MAX_EXP for FE_DOWNWARD or FE_TOWARDZERO. The benchmark inputs are based on exp2f ones. Benchtest on x64_64 (Ryzen 9 5900X, gcc 14.2.1), aarch64 (Neoverse-N1, gcc 13.3.1), and powerpc (POWER10, gcc 13.2.1): Latency master patched improvement x86_64 40.6042 48.7104 -19.96% x86_64v2 40.7506 35.9032 11.90% x86_64v3 35.2301 31.7956 9.75% i686 102.094 94.6657 7.28% aarch64 18.2704 15.1387 17.14% power10 11.9444 8.2402 31.01% reciprocal-throughput master patched improvement x86_64 20.8683 16.1428 22.64% x86_64v2 19.5076 10.4474 46.44% x86_64v3 19.2106 10.4014 45.86% i686 56.4054 59.3004 -5.13% aarch64 12.0781 7.3953 38.77% power10 6.5306 5.9388 9.06% The generic implementation calls __ieee754_exp2f and x86_64 provides an optimized ifunc version (built with -mfma -mavx2, not correctly rounded). This explains the performance difference for x86_64. Same for i686, where the ABI provides an optimized __ieee754_exp2f version built with '-msse2 -mfpmath=sse'. When built wth same flags, the new algorithm shows a better performance: master patched improvement latency 102.094 91.2823 10.59% reciprocal-throughput 56.4054 52.7984 6.39% Signed-off-by: Alexei Sibidanov <sibid@uvic.ca> Signed-off-by: Paul Zimmermann <Paul.Zimmermann@inria.fr> Signed-off-by: Adhemerval Zanella <adhemerval.zanella@linaro.org> Reviewed-by: DJ Delorie <dj@redhat.com>
2349 lines
28 KiB
Plaintext
2349 lines
28 KiB
Plaintext
# Begin of automatic generation
|
|
|
|
# Maximal error of functions:
|
|
Function: "acos":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 2
|
|
|
|
Function: "acos_downward":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 2
|
|
|
|
Function: "acos_towardzero":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 2
|
|
|
|
Function: "acos_upward":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 2
|
|
|
|
Function: "acos_vlen16":
|
|
float: 1
|
|
|
|
Function: "acos_vlen2":
|
|
double: 1
|
|
|
|
Function: "acos_vlen4":
|
|
double: 1
|
|
float: 2
|
|
|
|
Function: "acos_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "acos_vlen8":
|
|
double: 1
|
|
float: 2
|
|
|
|
Function: "acos_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "acosh":
|
|
double: 2
|
|
float: 2
|
|
float128: 4
|
|
ldouble: 3
|
|
|
|
Function: "acosh_downward":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: "acosh_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 4
|
|
|
|
Function: "acosh_upward":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: "acosh_vlen16":
|
|
float: 1
|
|
|
|
Function: "acosh_vlen2":
|
|
double: 2
|
|
|
|
Function: "acosh_vlen4":
|
|
double: 2
|
|
float: 2
|
|
|
|
Function: "acosh_vlen4_avx2":
|
|
double: 2
|
|
|
|
Function: "acosh_vlen8":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "acosh_vlen8_avx2":
|
|
float: 2
|
|
|
|
Function: "asin":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "asin_downward":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: "asin_towardzero":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "asin_upward":
|
|
double: 2
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "asin_vlen16":
|
|
float: 1
|
|
|
|
Function: "asin_vlen2":
|
|
double: 1
|
|
|
|
Function: "asin_vlen4":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "asin_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "asin_vlen8":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "asin_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "asinh":
|
|
double: 2
|
|
float: 2
|
|
float128: 4
|
|
ldouble: 3
|
|
|
|
Function: "asinh_downward":
|
|
double: 3
|
|
float: 3
|
|
float128: 4
|
|
ldouble: 5
|
|
|
|
Function: "asinh_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 4
|
|
|
|
Function: "asinh_upward":
|
|
double: 3
|
|
float: 3
|
|
float128: 4
|
|
ldouble: 5
|
|
|
|
Function: "asinh_vlen2":
|
|
double: 2
|
|
|
|
Function: "asinh_vlen4":
|
|
double: 1
|
|
float: 2
|
|
|
|
Function: "asinh_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "asinh_vlen8":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "asinh_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "atan":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "atan2":
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "atan2_downward":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "atan2_towardzero":
|
|
double: 1
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 1
|
|
|
|
Function: "atan2_upward":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "atan2_vlen16":
|
|
float: 2
|
|
|
|
Function: "atan2_vlen2":
|
|
double: 2
|
|
|
|
Function: "atan2_vlen4":
|
|
double: 2
|
|
float: 2
|
|
|
|
Function: "atan2_vlen4_avx2":
|
|
double: 3
|
|
|
|
Function: "atan2_vlen8":
|
|
double: 3
|
|
float: 2
|
|
|
|
Function: "atan2_vlen8_avx2":
|
|
float: 2
|
|
|
|
Function: "atan_downward":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "atan_towardzero":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "atan_upward":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "atan_vlen16":
|
|
float: 1
|
|
|
|
Function: "atan_vlen2":
|
|
double: 1
|
|
|
|
Function: "atan_vlen4":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "atan_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "atan_vlen8":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "atan_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "atanh":
|
|
double: 2
|
|
float: 2
|
|
float128: 4
|
|
ldouble: 3
|
|
|
|
Function: "atanh_downward":
|
|
double: 3
|
|
float: 3
|
|
float128: 4
|
|
ldouble: 5
|
|
|
|
Function: "atanh_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 4
|
|
|
|
Function: "atanh_upward":
|
|
double: 3
|
|
float: 3
|
|
float128: 4
|
|
ldouble: 5
|
|
|
|
Function: "atanh_vlen16":
|
|
float: 1
|
|
|
|
Function: "atanh_vlen2":
|
|
double: 2
|
|
|
|
Function: "atanh_vlen4":
|
|
double: 1
|
|
float: 2
|
|
|
|
Function: "atanh_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "atanh_vlen8":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "atanh_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "cabs":
|
|
double: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "cabs_downward":
|
|
double: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "cabs_towardzero":
|
|
double: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "cabs_upward":
|
|
double: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: Real part of "cacos":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: Imaginary part of "cacos":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: Real part of "cacos_downward":
|
|
double: 3
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: Imaginary part of "cacos_downward":
|
|
double: 5
|
|
float: 3
|
|
float128: 6
|
|
ldouble: 6
|
|
|
|
Function: Real part of "cacos_towardzero":
|
|
double: 3
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: Imaginary part of "cacos_towardzero":
|
|
double: 5
|
|
float: 3
|
|
float128: 5
|
|
ldouble: 5
|
|
|
|
Function: Real part of "cacos_upward":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: Imaginary part of "cacos_upward":
|
|
double: 5
|
|
float: 7
|
|
float128: 7
|
|
ldouble: 7
|
|
|
|
Function: Real part of "cacosh":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: Imaginary part of "cacosh":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: Real part of "cacosh_downward":
|
|
double: 5
|
|
float: 3
|
|
float128: 5
|
|
ldouble: 5
|
|
|
|
Function: Imaginary part of "cacosh_downward":
|
|
double: 3
|
|
float: 3
|
|
float128: 4
|
|
ldouble: 3
|
|
|
|
Function: Real part of "cacosh_towardzero":
|
|
double: 5
|
|
float: 3
|
|
float128: 5
|
|
ldouble: 5
|
|
|
|
Function: Imaginary part of "cacosh_towardzero":
|
|
double: 3
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: Real part of "cacosh_upward":
|
|
double: 4
|
|
float: 4
|
|
float128: 6
|
|
ldouble: 5
|
|
|
|
Function: Imaginary part of "cacosh_upward":
|
|
double: 3
|
|
float: 2
|
|
float128: 4
|
|
ldouble: 3
|
|
|
|
Function: "carg":
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "carg_downward":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "carg_towardzero":
|
|
double: 1
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 1
|
|
|
|
Function: "carg_upward":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: Real part of "casin":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: Imaginary part of "casin":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: Real part of "casin_downward":
|
|
double: 3
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "casin_downward":
|
|
double: 5
|
|
float: 3
|
|
float128: 6
|
|
ldouble: 6
|
|
|
|
Function: Real part of "casin_towardzero":
|
|
double: 3
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "casin_towardzero":
|
|
double: 5
|
|
float: 3
|
|
float128: 5
|
|
ldouble: 5
|
|
|
|
Function: Real part of "casin_upward":
|
|
double: 3
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: Imaginary part of "casin_upward":
|
|
double: 5
|
|
float: 7
|
|
float128: 7
|
|
ldouble: 7
|
|
|
|
Function: Real part of "casinh":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: Imaginary part of "casinh":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: Real part of "casinh_downward":
|
|
double: 5
|
|
float: 3
|
|
float128: 6
|
|
ldouble: 6
|
|
|
|
Function: Imaginary part of "casinh_downward":
|
|
double: 3
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: Real part of "casinh_towardzero":
|
|
double: 5
|
|
float: 3
|
|
float128: 5
|
|
ldouble: 5
|
|
|
|
Function: Imaginary part of "casinh_towardzero":
|
|
double: 3
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: Real part of "casinh_upward":
|
|
double: 5
|
|
float: 7
|
|
float128: 7
|
|
ldouble: 7
|
|
|
|
Function: Imaginary part of "casinh_upward":
|
|
double: 3
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: Real part of "catan":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: Imaginary part of "catan":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: Real part of "catan_downward":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: Imaginary part of "catan_downward":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 4
|
|
|
|
Function: Real part of "catan_towardzero":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: Imaginary part of "catan_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 4
|
|
|
|
Function: Real part of "catan_upward":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: Imaginary part of "catan_upward":
|
|
double: 3
|
|
float: 3
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: Real part of "catanh":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: Imaginary part of "catanh":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: Real part of "catanh_downward":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 4
|
|
|
|
Function: Imaginary part of "catanh_downward":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: Real part of "catanh_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 4
|
|
|
|
Function: Imaginary part of "catanh_towardzero":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: Real part of "catanh_upward":
|
|
double: 4
|
|
float: 4
|
|
float128: 4
|
|
ldouble: 4
|
|
|
|
Function: Imaginary part of "catanh_upward":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "cbrt":
|
|
double: 4
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "cbrt_downward":
|
|
double: 4
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "cbrt_towardzero":
|
|
double: 3
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "cbrt_upward":
|
|
double: 5
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "cbrt_vlen16":
|
|
float: 1
|
|
|
|
Function: "cbrt_vlen2":
|
|
double: 4
|
|
|
|
Function: "cbrt_vlen4":
|
|
double: 1
|
|
float: 2
|
|
|
|
Function: "cbrt_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "cbrt_vlen8":
|
|
double: 1
|
|
float: 2
|
|
|
|
Function: "cbrt_vlen8_avx2":
|
|
float: 2
|
|
|
|
Function: Real part of "ccos":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: Imaginary part of "ccos":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: Real part of "ccos_downward":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "ccos_downward":
|
|
double: 3
|
|
float: 3
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Real part of "ccos_towardzero":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "ccos_towardzero":
|
|
double: 3
|
|
float: 3
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Real part of "ccos_upward":
|
|
double: 1
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: Imaginary part of "ccos_upward":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: Real part of "ccosh":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: Imaginary part of "ccosh":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: Real part of "ccosh_downward":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "ccosh_downward":
|
|
double: 3
|
|
float: 3
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Real part of "ccosh_towardzero":
|
|
double: 2
|
|
float: 3
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "ccosh_towardzero":
|
|
double: 3
|
|
float: 3
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Real part of "ccosh_upward":
|
|
double: 1
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: Imaginary part of "ccosh_upward":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: Real part of "cexp":
|
|
double: 2
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: Imaginary part of "cexp":
|
|
double: 1
|
|
float: 2
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: Real part of "cexp_downward":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "cexp_downward":
|
|
double: 3
|
|
float: 3
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Real part of "cexp_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "cexp_towardzero":
|
|
double: 3
|
|
float: 3
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Real part of "cexp_upward":
|
|
double: 1
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: Imaginary part of "cexp_upward":
|
|
double: 3
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: Real part of "clog":
|
|
double: 3
|
|
float: 3
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "clog":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: Real part of "clog10":
|
|
double: 3
|
|
float: 4
|
|
float128: 2
|
|
ldouble: 4
|
|
|
|
Function: Imaginary part of "clog10":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: Real part of "clog10_downward":
|
|
double: 5
|
|
float: 5
|
|
float128: 3
|
|
ldouble: 8
|
|
|
|
Function: Imaginary part of "clog10_downward":
|
|
double: 2
|
|
float: 4
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: Real part of "clog10_towardzero":
|
|
double: 5
|
|
float: 6
|
|
float128: 4
|
|
ldouble: 8
|
|
|
|
Function: Imaginary part of "clog10_towardzero":
|
|
double: 2
|
|
float: 4
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: Real part of "clog10_upward":
|
|
double: 6
|
|
float: 5
|
|
float128: 4
|
|
ldouble: 8
|
|
|
|
Function: Imaginary part of "clog10_upward":
|
|
double: 2
|
|
float: 4
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: Real part of "clog_downward":
|
|
double: 4
|
|
float: 3
|
|
float128: 3
|
|
ldouble: 5
|
|
|
|
Function: Imaginary part of "clog_downward":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: Real part of "clog_towardzero":
|
|
double: 4
|
|
float: 4
|
|
float128: 3
|
|
ldouble: 5
|
|
|
|
Function: Imaginary part of "clog_towardzero":
|
|
double: 1
|
|
float: 3
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: Real part of "clog_upward":
|
|
double: 4
|
|
float: 3
|
|
float128: 4
|
|
ldouble: 4
|
|
|
|
Function: Imaginary part of "clog_upward":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "cos":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "cos_downward":
|
|
double: 1
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: "cos_towardzero":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 2
|
|
|
|
Function: "cos_upward":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: "cos_vlen16":
|
|
float: 1
|
|
|
|
Function: "cos_vlen2":
|
|
double: 2
|
|
|
|
Function: "cos_vlen4":
|
|
double: 2
|
|
float: 1
|
|
|
|
Function: "cos_vlen4_avx2":
|
|
double: 2
|
|
|
|
Function: "cos_vlen8":
|
|
double: 2
|
|
float: 1
|
|
|
|
Function: "cos_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "cosh":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: "cosh_downward":
|
|
double: 3
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: "cosh_towardzero":
|
|
double: 3
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: "cosh_upward":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: "cosh_vlen16":
|
|
float: 2
|
|
|
|
Function: "cosh_vlen2":
|
|
double: 2
|
|
|
|
Function: "cosh_vlen4":
|
|
double: 2
|
|
float: 2
|
|
|
|
Function: "cosh_vlen4_avx2":
|
|
double: 2
|
|
|
|
Function: "cosh_vlen8":
|
|
double: 2
|
|
float: 2
|
|
|
|
Function: "cosh_vlen8_avx2":
|
|
float: 2
|
|
|
|
Function: Real part of "cpow":
|
|
double: 2
|
|
float: 5
|
|
float128: 4
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "cpow":
|
|
float: 2
|
|
float128: 1
|
|
ldouble: 4
|
|
|
|
Function: Real part of "cpow_downward":
|
|
double: 5
|
|
float: 8
|
|
float128: 6
|
|
ldouble: 7
|
|
|
|
Function: Imaginary part of "cpow_downward":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: Real part of "cpow_towardzero":
|
|
double: 5
|
|
float: 8
|
|
float128: 6
|
|
ldouble: 7
|
|
|
|
Function: Imaginary part of "cpow_towardzero":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: Real part of "cpow_upward":
|
|
double: 4
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: Imaginary part of "cpow_upward":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: Real part of "csin":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: Imaginary part of "csin":
|
|
float128: 1
|
|
|
|
Function: Real part of "csin_downward":
|
|
double: 3
|
|
float: 3
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "csin_downward":
|
|
double: 1
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Real part of "csin_towardzero":
|
|
double: 3
|
|
float: 3
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "csin_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Real part of "csin_upward":
|
|
double: 2
|
|
float: 3
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "csin_upward":
|
|
double: 1
|
|
float: 3
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: Real part of "csinh":
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: Imaginary part of "csinh":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: Real part of "csinh_downward":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "csinh_downward":
|
|
double: 3
|
|
float: 3
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Real part of "csinh_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "csinh_towardzero":
|
|
double: 3
|
|
float: 3
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Real part of "csinh_upward":
|
|
double: 1
|
|
float: 3
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "csinh_upward":
|
|
double: 2
|
|
float: 3
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: Real part of "csqrt":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: Imaginary part of "csqrt":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: Real part of "csqrt_downward":
|
|
double: 5
|
|
float: 4
|
|
float128: 4
|
|
ldouble: 5
|
|
|
|
Function: Imaginary part of "csqrt_downward":
|
|
double: 4
|
|
float: 3
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: Real part of "csqrt_towardzero":
|
|
double: 4
|
|
float: 3
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: Imaginary part of "csqrt_towardzero":
|
|
double: 4
|
|
float: 3
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: Real part of "csqrt_upward":
|
|
double: 5
|
|
float: 4
|
|
float128: 4
|
|
ldouble: 5
|
|
|
|
Function: Imaginary part of "csqrt_upward":
|
|
double: 3
|
|
float: 3
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: Real part of "ctan":
|
|
double: 1
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: Imaginary part of "ctan":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 1
|
|
|
|
Function: Real part of "ctan_downward":
|
|
double: 6
|
|
float: 5
|
|
float128: 4
|
|
ldouble: 5
|
|
|
|
Function: Imaginary part of "ctan_downward":
|
|
double: 2
|
|
float: 2
|
|
float128: 5
|
|
ldouble: 4
|
|
|
|
Function: Real part of "ctan_towardzero":
|
|
double: 5
|
|
float: 3
|
|
float128: 4
|
|
ldouble: 5
|
|
|
|
Function: Imaginary part of "ctan_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 5
|
|
ldouble: 4
|
|
|
|
Function: Real part of "ctan_upward":
|
|
double: 2
|
|
float: 4
|
|
float128: 5
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "ctan_upward":
|
|
double: 2
|
|
float: 2
|
|
float128: 5
|
|
ldouble: 3
|
|
|
|
Function: Real part of "ctanh":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 1
|
|
|
|
Function: Imaginary part of "ctanh":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: Real part of "ctanh_downward":
|
|
double: 4
|
|
float: 2
|
|
float128: 5
|
|
ldouble: 4
|
|
|
|
Function: Imaginary part of "ctanh_downward":
|
|
double: 6
|
|
float: 5
|
|
float128: 4
|
|
ldouble: 4
|
|
|
|
Function: Real part of "ctanh_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 5
|
|
ldouble: 4
|
|
|
|
Function: Imaginary part of "ctanh_towardzero":
|
|
double: 5
|
|
float: 3
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: Real part of "ctanh_upward":
|
|
double: 2
|
|
float: 2
|
|
float128: 5
|
|
ldouble: 3
|
|
|
|
Function: Imaginary part of "ctanh_upward":
|
|
double: 2
|
|
float: 3
|
|
float128: 5
|
|
ldouble: 3
|
|
|
|
Function: "erf":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "erf_downward":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "erf_towardzero":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "erf_upward":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "erf_vlen16":
|
|
float: 1
|
|
|
|
Function: "erf_vlen2":
|
|
double: 1
|
|
|
|
Function: "erf_vlen4":
|
|
double: 1
|
|
float: 2
|
|
|
|
Function: "erf_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "erf_vlen8":
|
|
double: 1
|
|
float: 2
|
|
|
|
Function: "erf_vlen8_avx2":
|
|
float: 2
|
|
|
|
Function: "erfc":
|
|
double: 5
|
|
float: 3
|
|
float128: 4
|
|
ldouble: 5
|
|
|
|
Function: "erfc_downward":
|
|
double: 5
|
|
float: 6
|
|
float128: 5
|
|
ldouble: 4
|
|
|
|
Function: "erfc_towardzero":
|
|
double: 3
|
|
float: 4
|
|
float128: 4
|
|
ldouble: 4
|
|
|
|
Function: "erfc_upward":
|
|
double: 5
|
|
float: 6
|
|
float128: 5
|
|
ldouble: 5
|
|
|
|
Function: "erfc_vlen16":
|
|
float: 1
|
|
|
|
Function: "erfc_vlen2":
|
|
double: 5
|
|
|
|
Function: "erfc_vlen4":
|
|
double: 1
|
|
float: 3
|
|
|
|
Function: "erfc_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "erfc_vlen8":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "erfc_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "exp":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "exp10":
|
|
double: 2
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "exp10_downward":
|
|
double: 3
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: "exp10_towardzero":
|
|
double: 3
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: "exp10_upward":
|
|
double: 2
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: "exp10_vlen16":
|
|
float: 3
|
|
|
|
Function: "exp10_vlen2":
|
|
double: 2
|
|
|
|
Function: "exp10_vlen4":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "exp10_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "exp10_vlen8":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "exp10_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "exp10m1":
|
|
double: 4
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: "exp10m1_downward":
|
|
double: 3
|
|
float128: 6
|
|
ldouble: 6
|
|
|
|
Function: "exp10m1_towardzero":
|
|
double: 2
|
|
float128: 6
|
|
ldouble: 5
|
|
|
|
Function: "exp10m1_upward":
|
|
double: 5
|
|
float128: 6
|
|
ldouble: 6
|
|
|
|
Function: "exp2":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "exp2_downward":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "exp2_towardzero":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "exp2_upward":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "exp2_vlen16":
|
|
float: 1
|
|
|
|
Function: "exp2_vlen2":
|
|
double: 1
|
|
|
|
Function: "exp2_vlen4":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "exp2_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "exp2_vlen8":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "exp2_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "exp2m1":
|
|
double: 2
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: "exp2m1_downward":
|
|
double: 3
|
|
float128: 3
|
|
ldouble: 6
|
|
|
|
Function: "exp2m1_towardzero":
|
|
double: 3
|
|
float128: 4
|
|
ldouble: 5
|
|
|
|
Function: "exp2m1_upward":
|
|
double: 3
|
|
float128: 5
|
|
ldouble: 6
|
|
|
|
Function: "exp_downward":
|
|
double: 1
|
|
float: 1
|
|
ldouble: 1
|
|
|
|
Function: "exp_towardzero":
|
|
double: 1
|
|
float: 1
|
|
ldouble: 2
|
|
|
|
Function: "exp_upward":
|
|
double: 1
|
|
float: 1
|
|
ldouble: 1
|
|
|
|
Function: "exp_vlen16":
|
|
float: 1
|
|
|
|
Function: "exp_vlen2":
|
|
double: 1
|
|
|
|
Function: "exp_vlen4":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "exp_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "exp_vlen8":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "exp_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "expm1":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: "expm1_downward":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 4
|
|
|
|
Function: "expm1_towardzero":
|
|
double: 1
|
|
float: 2
|
|
float128: 4
|
|
ldouble: 4
|
|
|
|
Function: "expm1_upward":
|
|
double: 1
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: "expm1_vlen16":
|
|
float: 1
|
|
|
|
Function: "expm1_vlen2":
|
|
double: 1
|
|
|
|
Function: "expm1_vlen4":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "expm1_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "expm1_vlen8":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "expm1_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "gamma":
|
|
double: 4
|
|
float: 7
|
|
ldouble: 4
|
|
|
|
Function: "gamma_downward":
|
|
double: 5
|
|
float: 7
|
|
ldouble: 7
|
|
|
|
Function: "gamma_towardzero":
|
|
double: 5
|
|
float: 6
|
|
ldouble: 7
|
|
|
|
Function: "gamma_upward":
|
|
double: 5
|
|
float: 6
|
|
ldouble: 6
|
|
|
|
Function: "hypot":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "hypot_downward":
|
|
double: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "hypot_towardzero":
|
|
double: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "hypot_upward":
|
|
double: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "hypot_vlen16":
|
|
float: 1
|
|
|
|
Function: "hypot_vlen2":
|
|
double: 1
|
|
|
|
Function: "hypot_vlen4":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "hypot_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "hypot_vlen8":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "hypot_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "j0":
|
|
double: 3
|
|
float: 9
|
|
float128: 2
|
|
ldouble: 8
|
|
|
|
Function: "j0_downward":
|
|
double: 6
|
|
float: 9
|
|
float128: 9
|
|
ldouble: 6
|
|
|
|
Function: "j0_towardzero":
|
|
double: 7
|
|
float: 9
|
|
float128: 9
|
|
ldouble: 6
|
|
|
|
Function: "j0_upward":
|
|
double: 9
|
|
float: 9
|
|
float128: 7
|
|
ldouble: 6
|
|
|
|
Function: "j1":
|
|
double: 4
|
|
float: 9
|
|
float128: 4
|
|
ldouble: 9
|
|
|
|
Function: "j1_downward":
|
|
double: 6
|
|
float: 8
|
|
float128: 6
|
|
ldouble: 8
|
|
|
|
Function: "j1_towardzero":
|
|
double: 4
|
|
float: 9
|
|
float128: 9
|
|
ldouble: 4
|
|
|
|
Function: "j1_upward":
|
|
double: 9
|
|
float: 9
|
|
float128: 9
|
|
ldouble: 3
|
|
|
|
Function: "jn":
|
|
double: 4
|
|
float: 4
|
|
float128: 7
|
|
ldouble: 4
|
|
|
|
Function: "jn_downward":
|
|
double: 5
|
|
float: 5
|
|
float128: 8
|
|
ldouble: 4
|
|
|
|
Function: "jn_towardzero":
|
|
double: 5
|
|
float: 5
|
|
float128: 8
|
|
ldouble: 5
|
|
|
|
Function: "jn_upward":
|
|
double: 5
|
|
float: 5
|
|
float128: 7
|
|
ldouble: 5
|
|
|
|
Function: "lgamma":
|
|
double: 4
|
|
float: 7
|
|
float128: 5
|
|
ldouble: 4
|
|
|
|
Function: "lgamma_downward":
|
|
double: 5
|
|
float: 7
|
|
float128: 8
|
|
ldouble: 7
|
|
|
|
Function: "lgamma_towardzero":
|
|
double: 5
|
|
float: 6
|
|
float128: 5
|
|
ldouble: 7
|
|
|
|
Function: "lgamma_upward":
|
|
double: 5
|
|
float: 6
|
|
float128: 8
|
|
ldouble: 6
|
|
|
|
Function: "log":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "log10":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "log10_downward":
|
|
double: 2
|
|
float: 3
|
|
float128: 1
|
|
ldouble: 2
|
|
|
|
Function: "log10_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 1
|
|
ldouble: 2
|
|
|
|
Function: "log10_upward":
|
|
double: 2
|
|
float: 2
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "log10_vlen16":
|
|
float: 1
|
|
|
|
Function: "log10_vlen2":
|
|
double: 2
|
|
|
|
Function: "log10_vlen4":
|
|
double: 1
|
|
float: 2
|
|
|
|
Function: "log10_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "log10_vlen8":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "log10_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "log10p1":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: "log10p1_downward":
|
|
double: 2
|
|
float: 3
|
|
float128: 4
|
|
ldouble: 8
|
|
|
|
Function: "log10p1_towardzero":
|
|
double: 3
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 8
|
|
|
|
Function: "log10p1_upward":
|
|
double: 2
|
|
float: 3
|
|
float128: 4
|
|
ldouble: 6
|
|
|
|
Function: "log1p":
|
|
double: 1
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: "log1p_downward":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: "log1p_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: "log1p_upward":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: "log1p_vlen16":
|
|
float: 2
|
|
|
|
Function: "log1p_vlen2":
|
|
double: 1
|
|
|
|
Function: "log1p_vlen4":
|
|
double: 1
|
|
float: 2
|
|
|
|
Function: "log1p_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "log1p_vlen8":
|
|
double: 1
|
|
float: 2
|
|
|
|
Function: "log1p_vlen8_avx2":
|
|
float: 2
|
|
|
|
Function: "log2":
|
|
double: 2
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 1
|
|
|
|
Function: "log2_downward":
|
|
double: 3
|
|
float: 3
|
|
float128: 3
|
|
ldouble: 1
|
|
|
|
Function: "log2_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "log2_upward":
|
|
double: 3
|
|
float: 3
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "log2_vlen16":
|
|
float: 1
|
|
|
|
Function: "log2_vlen2":
|
|
double: 1
|
|
|
|
Function: "log2_vlen4":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "log2_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "log2_vlen8":
|
|
double: 1
|
|
float: 1
|
|
|
|
Function: "log2_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "log2p1":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: "log2p1_downward":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: "log2p1_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 4
|
|
|
|
Function: "log2p1_upward":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 5
|
|
|
|
Function: "log_downward":
|
|
float: 2
|
|
float128: 1
|
|
ldouble: 2
|
|
|
|
Function: "log_towardzero":
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: "log_upward":
|
|
double: 1
|
|
float: 2
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "log_vlen16":
|
|
float: 3
|
|
|
|
Function: "log_vlen2":
|
|
double: 1
|
|
|
|
Function: "log_vlen4":
|
|
double: 1
|
|
float: 3
|
|
|
|
Function: "log_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "log_vlen8":
|
|
double: 1
|
|
float: 3
|
|
|
|
Function: "log_vlen8_avx2":
|
|
float: 3
|
|
|
|
Function: "logp1":
|
|
double: 1
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: "logp1_downward":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: "logp1_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: "logp1_upward":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: "pow":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 1
|
|
|
|
Function: "pow_downward":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 4
|
|
|
|
Function: "pow_towardzero":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 4
|
|
|
|
Function: "pow_upward":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 4
|
|
|
|
Function: "pow_vlen16":
|
|
float: 3
|
|
|
|
Function: "pow_vlen2":
|
|
double: 1
|
|
|
|
Function: "pow_vlen4":
|
|
double: 1
|
|
float: 3
|
|
|
|
Function: "pow_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "pow_vlen8":
|
|
double: 1
|
|
float: 3
|
|
|
|
Function: "pow_vlen8_avx2":
|
|
float: 3
|
|
|
|
Function: "sin":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: "sin_downward":
|
|
double: 1
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: "sin_towardzero":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: "sin_upward":
|
|
double: 1
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: "sin_vlen16":
|
|
float: 1
|
|
|
|
Function: "sin_vlen2":
|
|
double: 2
|
|
|
|
Function: "sin_vlen4":
|
|
double: 2
|
|
float: 1
|
|
|
|
Function: "sin_vlen4_avx2":
|
|
double: 2
|
|
|
|
Function: "sin_vlen8":
|
|
double: 2
|
|
float: 1
|
|
|
|
Function: "sin_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "sincos":
|
|
double: 1
|
|
float128: 1
|
|
ldouble: 1
|
|
|
|
Function: "sincos_downward":
|
|
double: 1
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: "sincos_towardzero":
|
|
double: 1
|
|
float: 1
|
|
float128: 2
|
|
ldouble: 2
|
|
|
|
Function: "sincos_upward":
|
|
double: 1
|
|
float: 1
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: "sincos_vlen16":
|
|
float: 1
|
|
|
|
Function: "sincos_vlen2":
|
|
double: 2
|
|
|
|
Function: "sincos_vlen4":
|
|
double: 2
|
|
float: 1
|
|
|
|
Function: "sincos_vlen4_avx2":
|
|
double: 2
|
|
|
|
Function: "sincos_vlen8":
|
|
double: 2
|
|
float: 1
|
|
|
|
Function: "sincos_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "sinh":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: "sinh_downward":
|
|
double: 3
|
|
float: 3
|
|
float128: 3
|
|
ldouble: 5
|
|
|
|
Function: "sinh_towardzero":
|
|
double: 3
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: "sinh_upward":
|
|
double: 3
|
|
float: 3
|
|
float128: 4
|
|
ldouble: 5
|
|
|
|
Function: "sinh_vlen16":
|
|
float: 1
|
|
|
|
Function: "sinh_vlen2":
|
|
double: 2
|
|
|
|
Function: "sinh_vlen4":
|
|
double: 2
|
|
float: 2
|
|
|
|
Function: "sinh_vlen4_avx2":
|
|
double: 2
|
|
|
|
Function: "sinh_vlen8":
|
|
double: 2
|
|
float: 1
|
|
|
|
Function: "sinh_vlen8_avx2":
|
|
float: 1
|
|
|
|
Function: "tan":
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 2
|
|
|
|
Function: "tan_downward":
|
|
double: 1
|
|
float: 2
|
|
float128: 1
|
|
ldouble: 3
|
|
|
|
Function: "tan_towardzero":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 3
|
|
|
|
Function: "tan_upward":
|
|
double: 1
|
|
float: 1
|
|
float128: 1
|
|
ldouble: 2
|
|
|
|
Function: "tan_vlen16":
|
|
float: 1
|
|
|
|
Function: "tan_vlen2":
|
|
double: 2
|
|
|
|
Function: "tan_vlen4":
|
|
double: 2
|
|
float: 2
|
|
|
|
Function: "tan_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "tan_vlen8":
|
|
double: 2
|
|
float: 2
|
|
|
|
Function: "tan_vlen8_avx2":
|
|
float: 2
|
|
|
|
Function: "tanh":
|
|
double: 2
|
|
float: 2
|
|
float128: 2
|
|
ldouble: 3
|
|
|
|
Function: "tanh_downward":
|
|
double: 3
|
|
float: 3
|
|
float128: 4
|
|
ldouble: 4
|
|
|
|
Function: "tanh_towardzero":
|
|
double: 2
|
|
float: 2
|
|
float128: 3
|
|
ldouble: 3
|
|
|
|
Function: "tanh_upward":
|
|
double: 3
|
|
float: 3
|
|
float128: 3
|
|
ldouble: 4
|
|
|
|
Function: "tanh_vlen16":
|
|
float: 1
|
|
|
|
Function: "tanh_vlen2":
|
|
double: 2
|
|
|
|
Function: "tanh_vlen4":
|
|
double: 1
|
|
float: 2
|
|
|
|
Function: "tanh_vlen4_avx2":
|
|
double: 1
|
|
|
|
Function: "tanh_vlen8":
|
|
double: 1
|
|
|
|
Function: "tgamma":
|
|
double: 9
|
|
float128: 4
|
|
ldouble: 5
|
|
|
|
Function: "tgamma_downward":
|
|
double: 9
|
|
float128: 5
|
|
ldouble: 6
|
|
|
|
Function: "tgamma_towardzero":
|
|
double: 9
|
|
float128: 5
|
|
ldouble: 6
|
|
|
|
Function: "tgamma_upward":
|
|
double: 9
|
|
float128: 4
|
|
ldouble: 5
|
|
|
|
Function: "y0":
|
|
double: 3
|
|
float: 9
|
|
float128: 3
|
|
ldouble: 2
|
|
|
|
Function: "y0_downward":
|
|
double: 4
|
|
float: 9
|
|
float128: 7
|
|
ldouble: 7
|
|
|
|
Function: "y0_towardzero":
|
|
double: 4
|
|
float: 9
|
|
float128: 3
|
|
ldouble: 8
|
|
|
|
Function: "y0_upward":
|
|
double: 3
|
|
float: 9
|
|
float128: 4
|
|
ldouble: 7
|
|
|
|
Function: "y1":
|
|
double: 6
|
|
float: 9
|
|
float128: 5
|
|
ldouble: 3
|
|
|
|
Function: "y1_downward":
|
|
double: 6
|
|
float: 9
|
|
float128: 5
|
|
ldouble: 7
|
|
|
|
Function: "y1_towardzero":
|
|
double: 4
|
|
float: 9
|
|
float128: 6
|
|
ldouble: 5
|
|
|
|
Function: "y1_upward":
|
|
double: 7
|
|
float: 9
|
|
float128: 6
|
|
ldouble: 9
|
|
|
|
Function: "yn":
|
|
double: 3
|
|
float: 3
|
|
float128: 5
|
|
ldouble: 4
|
|
|
|
Function: "yn_downward":
|
|
double: 3
|
|
float: 4
|
|
float128: 5
|
|
ldouble: 5
|
|
|
|
Function: "yn_towardzero":
|
|
double: 3
|
|
float: 3
|
|
float128: 5
|
|
ldouble: 5
|
|
|
|
Function: "yn_upward":
|
|
double: 4
|
|
float: 5
|
|
float128: 5
|
|
ldouble: 4
|
|
|
|
# end of automatic generation
|