glibc/sysdeps/arm/libm-test-ulps

1675 lines
20 KiB
Plaintext
Raw Normal View History

# Begin of automatic generation
# Maximal error of functions:
Function: "acos":
float: 1
ifloat: 1
2012-05-30 21:16:52 +00:00
Function: "acos_downward":
double: 1
2012-05-30 21:16:52 +00:00
float: 1
idouble: 1
2012-05-30 21:16:52 +00:00
ifloat: 1
2012-05-30 21:16:52 +00:00
Function: "acos_towardzero":
double: 1
float: 1
idouble: 1
ifloat: 1
2014-01-01 16:46:17 +00:00
Function: "acos_upward":
double: 1
float: 1
2014-01-01 16:46:17 +00:00
idouble: 1
ifloat: 1
2014-01-01 16:46:17 +00:00
Function: "acosh":
double: 2
float: 2
idouble: 2
ifloat: 2
2014-01-01 16:46:17 +00:00
Function: "acosh_downward":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: "acosh_towardzero":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: "acosh_upward":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: "asin":
float: 1
ifloat: 1
2012-05-30 21:16:52 +00:00
Function: "asin_downward":
double: 1
float: 1
idouble: 1
ifloat: 1
2012-05-30 21:16:52 +00:00
Function: "asin_towardzero":
double: 1
float: 1
idouble: 1
ifloat: 1
2012-05-30 21:16:52 +00:00
Function: "asin_upward":
2014-01-01 16:46:17 +00:00
double: 1
float: 1
idouble: 1
ifloat: 1
Function: "asinh":
double: 1
2012-05-30 21:16:52 +00:00
float: 1
idouble: 1
2012-05-30 21:16:52 +00:00
ifloat: 1
Function: "asinh_downward":
double: 3
float: 3
idouble: 3
ifloat: 3
Function: "asinh_towardzero":
double: 2
float: 2
idouble: 2
ifloat: 2
2012-05-30 21:16:52 +00:00
Function: "asinh_upward":
double: 3
float: 3
idouble: 3
ifloat: 3
Function: "atan":
2012-05-30 21:16:52 +00:00
float: 1
ifloat: 1
Function: "atan2":
float: 1
ifloat: 1
Function: "atan2_downward":
2013-07-02 20:34:19 +00:00
double: 1
float: 2
idouble: 1
ifloat: 2
Function: "atan2_towardzero":
double: 1
2013-07-02 20:34:19 +00:00
float: 2
idouble: 1
2013-07-02 20:34:19 +00:00
ifloat: 2
Function: "atan2_upward":
double: 1
Fix ulps regeneration for *-finite tests. On running tests after from-scratch ulps regeneration, I found that some libm tests failed with ulps in excess of those recorded in the from-scratch regeneration, which should never happen unless those ulps exceed the limit on ulps that can go in libm-test-ulps files. Failure: Test: atan2_upward (inf, -inf) Result: is: 2.35619498e+00 0x1.2d97ccp+1 should be: 2.35619450e+00 0x1.2d97c8p+1 difference: 4.76837159e-07 0x1.000000p-21 ulp : 2.0000 max.ulp : 1.0000 Maximal error of `atan2_upward' is : 2 ulp accepted: 1 ulp Failure: Test: carg_upward (-inf + inf i) Result: is: 2.35619498e+00 0x1.2d97ccp+1 should be: 2.35619450e+00 0x1.2d97c8p+1 difference: 4.76837159e-07 0x1.000000p-21 ulp : 2.0000 max.ulp : 1.0000 Maximal error of `carg_upward' is : 2 ulp accepted: 1 ulp The problem comes from the addition of tests for the finite-math-only versions of libm functions. Those tests share ulps with the default function variants. make regen-ulps runs the default tests before the finite-math-only tests, concatenating the resulting ulps before feeding them to gen-libm-test.pl to generate a new libm-test-ulps file. But gen-libm-test.pl always takes the last ulps value given for any (function, type) pair. So, if the largest ulps for a function come from non-finite inputs, a from-scratch regeneration loses those ulps. This patch fixes gen-libm-test.pl, in the case where there are multiple ulps values for a (function, type) pair - which can only happen as part of a regeneration - to take the largest ulps value rather than the last one. Tested for ARM / MIPS / powerpc-nofpu. * math/gen-libm-test.pl (parse_ulps): Do not reduce already-recorded ulps. * sysdeps/arm/libm-test-ulps: Regenerated. * sysdeps/mips/mips32/libm-test-ulps: Likewise. * sysdeps/mips/mips64/libm-test-ulps: Likewise. * sysdeps/powerpc/nofpu/libm-test-ulps: Likewise.
2016-01-19 21:42:58 +00:00
float: 2
idouble: 1
2013-07-02 20:34:19 +00:00
ifloat: 2
Function: "atan_downward":
2012-05-30 21:16:52 +00:00
double: 1
float: 2
2012-05-30 21:16:52 +00:00
idouble: 1
ifloat: 2
Function: "atan_towardzero":
2013-07-02 20:34:19 +00:00
double: 1
float: 1
2013-07-02 20:34:19 +00:00
idouble: 1
ifloat: 1
Function: "atan_upward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: "atanh":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: "atanh_downward":
double: 3
float: 3
idouble: 3
ifloat: 3
2013-07-02 20:34:19 +00:00
Function: "atanh_towardzero":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: "atanh_upward":
double: 3
float: 3
idouble: 3
ifloat: 3
Function: "cabs":
double: 1
idouble: 1
Function: "cabs_downward":
double: 1
idouble: 1
Function: "cabs_towardzero":
double: 1
idouble: 1
Function: "cabs_upward":
double: 1
idouble: 1
Function: Real part of "cacos":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Imaginary part of "cacos":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: Real part of "cacos_downward":
double: 3
float: 2
idouble: 3
ifloat: 2
Function: Imaginary part of "cacos_downward":
double: 5
float: 3
idouble: 5
ifloat: 3
Function: Real part of "cacos_towardzero":
double: 3
float: 2
idouble: 3
ifloat: 2
Function: Imaginary part of "cacos_towardzero":
double: 5
float: 3
idouble: 5
ifloat: 3
Function: Real part of "cacos_upward":
2012-05-30 21:16:52 +00:00
double: 2
float: 2
2012-05-30 21:16:52 +00:00
idouble: 2
ifloat: 2
Function: Imaginary part of "cacos_upward":
double: 5
float: 7
idouble: 5
ifloat: 7
Function: Real part of "cacosh":
double: 2
2012-05-30 21:16:52 +00:00
float: 2
idouble: 2
2012-05-30 21:16:52 +00:00
ifloat: 2
Function: Imaginary part of "cacosh":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Real part of "cacosh_downward":
double: 5
float: 3
idouble: 5
ifloat: 3
Function: Imaginary part of "cacosh_downward":
double: 3
float: 3
idouble: 3
ifloat: 3
Function: Real part of "cacosh_towardzero":
double: 5
float: 3
idouble: 5
ifloat: 3
Function: Imaginary part of "cacosh_towardzero":
double: 3
float: 2
idouble: 3
ifloat: 2
Function: Real part of "cacosh_upward":
double: 4
float: 4
idouble: 4
ifloat: 4
Function: Imaginary part of "cacosh_upward":
double: 3
2012-11-30 20:41:26 +00:00
float: 2
idouble: 3
2012-11-30 20:41:26 +00:00
ifloat: 2
Function: "carg":
float: 1
ifloat: 1
Function: "carg_downward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: "carg_towardzero":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: "carg_upward":
2014-01-01 16:46:17 +00:00
double: 1
Fix ulps regeneration for *-finite tests. On running tests after from-scratch ulps regeneration, I found that some libm tests failed with ulps in excess of those recorded in the from-scratch regeneration, which should never happen unless those ulps exceed the limit on ulps that can go in libm-test-ulps files. Failure: Test: atan2_upward (inf, -inf) Result: is: 2.35619498e+00 0x1.2d97ccp+1 should be: 2.35619450e+00 0x1.2d97c8p+1 difference: 4.76837159e-07 0x1.000000p-21 ulp : 2.0000 max.ulp : 1.0000 Maximal error of `atan2_upward' is : 2 ulp accepted: 1 ulp Failure: Test: carg_upward (-inf + inf i) Result: is: 2.35619498e+00 0x1.2d97ccp+1 should be: 2.35619450e+00 0x1.2d97c8p+1 difference: 4.76837159e-07 0x1.000000p-21 ulp : 2.0000 max.ulp : 1.0000 Maximal error of `carg_upward' is : 2 ulp accepted: 1 ulp The problem comes from the addition of tests for the finite-math-only versions of libm functions. Those tests share ulps with the default function variants. make regen-ulps runs the default tests before the finite-math-only tests, concatenating the resulting ulps before feeding them to gen-libm-test.pl to generate a new libm-test-ulps file. But gen-libm-test.pl always takes the last ulps value given for any (function, type) pair. So, if the largest ulps for a function come from non-finite inputs, a from-scratch regeneration loses those ulps. This patch fixes gen-libm-test.pl, in the case where there are multiple ulps values for a (function, type) pair - which can only happen as part of a regeneration - to take the largest ulps value rather than the last one. Tested for ARM / MIPS / powerpc-nofpu. * math/gen-libm-test.pl (parse_ulps): Do not reduce already-recorded ulps. * sysdeps/arm/libm-test-ulps: Regenerated. * sysdeps/mips/mips32/libm-test-ulps: Likewise. * sysdeps/mips/mips64/libm-test-ulps: Likewise. * sysdeps/powerpc/nofpu/libm-test-ulps: Likewise.
2016-01-19 21:42:58 +00:00
float: 2
2014-01-01 16:46:17 +00:00
idouble: 1
ifloat: 2
2012-05-30 21:16:52 +00:00
Function: Real part of "casin":
2014-01-01 16:46:17 +00:00
double: 1
2012-05-30 21:16:52 +00:00
float: 1
2014-01-01 16:46:17 +00:00
idouble: 1
2012-05-30 21:16:52 +00:00
ifloat: 1
Function: Imaginary part of "casin":
double: 2
2012-05-30 21:16:52 +00:00
float: 2
idouble: 2
2012-05-30 21:16:52 +00:00
ifloat: 2
Function: Real part of "casin_downward":
double: 3
float: 2
idouble: 3
ifloat: 2
2014-01-01 16:46:17 +00:00
Function: Imaginary part of "casin_downward":
double: 5
float: 3
idouble: 5
ifloat: 3
2014-01-01 16:46:17 +00:00
Function: Real part of "casin_towardzero":
double: 3
2012-05-30 21:16:52 +00:00
float: 1
idouble: 3
2012-05-30 21:16:52 +00:00
ifloat: 1
Function: Imaginary part of "casin_towardzero":
double: 5
float: 3
idouble: 5
ifloat: 3
Function: Real part of "casin_upward":
double: 3
float: 2
idouble: 3
ifloat: 2
2012-05-30 21:16:52 +00:00
Function: Imaginary part of "casin_upward":
double: 5
float: 7
idouble: 5
ifloat: 7
Function: Real part of "casinh":
double: 2
2014-01-01 16:46:17 +00:00
float: 2
idouble: 2
2014-01-01 16:46:17 +00:00
ifloat: 2
Function: Imaginary part of "casinh":
2012-05-30 21:16:52 +00:00
double: 1
float: 1
2012-05-30 21:16:52 +00:00
idouble: 1
ifloat: 1
Function: Real part of "casinh_downward":
double: 5
float: 3
idouble: 5
ifloat: 3
Function: Imaginary part of "casinh_downward":
double: 3
float: 2
idouble: 3
ifloat: 2
Function: Real part of "casinh_towardzero":
double: 5
float: 3
idouble: 5
ifloat: 3
Function: Imaginary part of "casinh_towardzero":
double: 3
float: 1
idouble: 3
ifloat: 1
Function: Real part of "casinh_upward":
double: 5
float: 7
idouble: 5
ifloat: 7
Function: Imaginary part of "casinh_upward":
double: 3
float: 2
idouble: 3
ifloat: 2
Function: Real part of "catan":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: Imaginary part of "catan":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: Real part of "catan_downward":
2012-05-30 21:16:52 +00:00
double: 1
float: 2
2012-05-30 21:16:52 +00:00
idouble: 1
ifloat: 2
Function: Imaginary part of "catan_downward":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: Real part of "catan_towardzero":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Imaginary part of "catan_towardzero":
2012-11-30 20:41:26 +00:00
double: 2
float: 2
2012-11-30 20:41:26 +00:00
idouble: 2
ifloat: 2
2012-11-30 20:41:26 +00:00
Function: Real part of "catan_upward":
double: 1
2012-11-30 20:41:26 +00:00
float: 1
idouble: 1
2012-11-30 20:41:26 +00:00
ifloat: 1
Function: Imaginary part of "catan_upward":
double: 3
float: 3
idouble: 3
ifloat: 3
Function: Real part of "catanh":
2014-01-01 16:46:17 +00:00
double: 1
2012-11-30 20:41:26 +00:00
float: 1
2014-01-01 16:46:17 +00:00
idouble: 1
2012-11-30 20:41:26 +00:00
ifloat: 1
Function: Imaginary part of "catanh":
double: 1
2012-11-30 20:41:26 +00:00
float: 1
idouble: 1
2012-11-30 20:41:26 +00:00
ifloat: 1
Function: Real part of "catanh_downward":
2014-01-01 16:46:17 +00:00
double: 2
float: 2
idouble: 2
ifloat: 2
2012-11-30 20:41:26 +00:00
Function: Imaginary part of "catanh_downward":
double: 1
float: 2
idouble: 1
ifloat: 2
2012-11-30 20:41:26 +00:00
Function: Real part of "catanh_towardzero":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: Imaginary part of "catanh_towardzero":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Real part of "catanh_upward":
double: 4
float: 4
idouble: 4
ifloat: 4
Function: Imaginary part of "catanh_upward":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: "cbrt":
double: 3
float: 1
idouble: 3
ifloat: 1
Function: "cbrt_downward":
double: 4
float: 1
idouble: 4
ifloat: 1
Function: "cbrt_towardzero":
double: 3
float: 1
idouble: 3
ifloat: 1
Function: "cbrt_upward":
double: 5
float: 1
idouble: 5
ifloat: 1
Function: Real part of "ccos":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: Imaginary part of "ccos":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: Real part of "ccos_downward":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: Imaginary part of "ccos_downward":
2014-01-01 16:46:17 +00:00
double: 2
float: 3
idouble: 2
ifloat: 3
2012-11-30 20:41:26 +00:00
Function: Real part of "ccos_towardzero":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Imaginary part of "ccos_towardzero":
double: 2
float: 3
idouble: 2
ifloat: 3
Function: Real part of "ccos_upward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Imaginary part of "ccos_upward":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: Real part of "ccosh":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: Imaginary part of "ccosh":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: Real part of "ccosh_downward":
double: 1
float: 3
idouble: 1
ifloat: 3
Function: Imaginary part of "ccosh_downward":
double: 2
float: 3
idouble: 2
ifloat: 3
Function: Real part of "ccosh_towardzero":
double: 1
float: 3
idouble: 1
ifloat: 3
Function: Imaginary part of "ccosh_towardzero":
double: 2
float: 3
idouble: 2
ifloat: 3
Function: Real part of "ccosh_upward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Imaginary part of "ccosh_upward":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: Real part of "cexp":
double: 2
float: 1
idouble: 2
ifloat: 1
Function: Imaginary part of "cexp":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Real part of "cexp_downward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Imaginary part of "cexp_downward":
double: 1
float: 3
idouble: 1
ifloat: 3
Function: Real part of "cexp_towardzero":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Imaginary part of "cexp_towardzero":
double: 1
float: 3
idouble: 1
ifloat: 3
Function: Real part of "cexp_upward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Imaginary part of "cexp_upward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Real part of "clog":
double: 3
float: 3
idouble: 3
ifloat: 3
Function: Imaginary part of "clog":
float: 1
ifloat: 1
Function: Real part of "clog10":
double: 3
float: 4
idouble: 3
ifloat: 4
Function: Imaginary part of "clog10":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: Real part of "clog10_downward":
double: 5
float: 5
idouble: 5
ifloat: 5
Function: Imaginary part of "clog10_downward":
double: 2
float: 4
idouble: 2
ifloat: 4
Function: Real part of "clog10_towardzero":
double: 5
float: 5
idouble: 5
ifloat: 5
Function: Imaginary part of "clog10_towardzero":
double: 2
float: 4
idouble: 2
ifloat: 4
Function: Real part of "clog10_upward":
double: 6
float: 5
idouble: 6
ifloat: 5
Function: Imaginary part of "clog10_upward":
double: 2
float: 4
idouble: 2
ifloat: 4
Function: Real part of "clog_downward":
double: 4
float: 3
idouble: 4
ifloat: 3
Function: Imaginary part of "clog_downward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Real part of "clog_towardzero":
double: 4
float: 4
idouble: 4
ifloat: 4
Function: Imaginary part of "clog_towardzero":
double: 1
float: 3
idouble: 1
ifloat: 3
Function: Real part of "clog_upward":
double: 4
float: 3
idouble: 4
ifloat: 3
Function: Imaginary part of "clog_upward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: "cos":
float: 1
ifloat: 1
Function: "cos_downward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: "cos_towardzero":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: "cos_upward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: "cosh":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: "cosh_downward":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: "cosh_towardzero":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: "cosh_upward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Real part of "cpow":
double: 2
float: 5
idouble: 2
ifloat: 5
Function: Imaginary part of "cpow":
float: 2
ifloat: 2
Function: Real part of "cpow_downward":
double: 4
float: 8
idouble: 4
ifloat: 8
Function: Imaginary part of "cpow_downward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Real part of "cpow_towardzero":
double: 4
float: 8
idouble: 4
ifloat: 8
Function: Imaginary part of "cpow_towardzero":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Real part of "cpow_upward":
double: 4
float: 1
idouble: 4
ifloat: 1
Function: Imaginary part of "cpow_upward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Real part of "csin":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: Real part of "csin_downward":
double: 2
float: 3
idouble: 2
ifloat: 3
Function: Imaginary part of "csin_downward":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: Real part of "csin_towardzero":
double: 2
float: 3
idouble: 2
ifloat: 3
Function: Imaginary part of "csin_towardzero":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: Real part of "csin_upward":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: Imaginary part of "csin_upward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Real part of "csinh":
float: 1
ifloat: 1
Function: Imaginary part of "csinh":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: Real part of "csinh_downward":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: Imaginary part of "csinh_downward":
double: 2
float: 3
idouble: 2
ifloat: 3
Function: Real part of "csinh_towardzero":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: Imaginary part of "csinh_towardzero":
double: 2
float: 3
idouble: 2
ifloat: 3
Function: Real part of "csinh_upward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: Imaginary part of "csinh_upward":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: Real part of "csqrt":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: Imaginary part of "csqrt":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: Real part of "csqrt_downward":
double: 5
float: 4
idouble: 5
ifloat: 4
Function: Imaginary part of "csqrt_downward":
double: 4
float: 3
idouble: 4
ifloat: 3
Function: Real part of "csqrt_towardzero":
double: 4
float: 3
idouble: 4
ifloat: 3
Function: Imaginary part of "csqrt_towardzero":
double: 4
float: 3
idouble: 4
ifloat: 3
Function: Real part of "csqrt_upward":
double: 5
float: 4
idouble: 5
ifloat: 4
Function: Imaginary part of "csqrt_upward":
double: 3
float: 3
idouble: 3
ifloat: 3
Function: Real part of "ctan":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: Imaginary part of "ctan":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: Real part of "ctan_downward":
double: 6
float: 5
idouble: 6
ifloat: 5
Function: Imaginary part of "ctan_downward":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: Real part of "ctan_towardzero":
double: 5
float: 3
idouble: 5
ifloat: 3
Function: Imaginary part of "ctan_towardzero":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: Real part of "ctan_upward":
double: 2
float: 4
idouble: 2
ifloat: 4
Function: Imaginary part of "ctan_upward":
double: 2
float: 3
idouble: 2
ifloat: 3
Function: Real part of "ctanh":
double: 2
float: 2
idouble: 2
ifloat: 2
2012-05-30 21:16:52 +00:00
Function: Imaginary part of "ctanh":
2014-01-01 16:46:17 +00:00
double: 2
float: 2
2014-01-01 16:46:17 +00:00
idouble: 2
ifloat: 2
2012-11-30 20:41:26 +00:00
Function: Real part of "ctanh_downward":
2014-01-01 16:46:17 +00:00
double: 4
float: 2
2014-01-01 16:46:17 +00:00
idouble: 4
ifloat: 2
2012-11-30 20:41:26 +00:00
Function: Imaginary part of "ctanh_downward":
2014-01-01 16:46:17 +00:00
double: 6
float: 5
idouble: 6
ifloat: 5
2012-11-30 20:41:26 +00:00
Function: Real part of "ctanh_towardzero":
2014-01-01 16:46:17 +00:00
double: 2
float: 2
idouble: 2
ifloat: 2
2012-11-30 20:41:26 +00:00
Function: Imaginary part of "ctanh_towardzero":
2014-01-01 16:46:17 +00:00
double: 5
float: 3
idouble: 5
ifloat: 3
2012-11-30 20:41:26 +00:00
Function: Real part of "ctanh_upward":
2014-01-01 16:46:17 +00:00
double: 2
float: 3
idouble: 2
ifloat: 3
2012-11-30 20:41:26 +00:00
Function: Imaginary part of "ctanh_upward":
double: 2
2014-01-01 16:46:17 +00:00
float: 3
2012-11-30 20:41:26 +00:00
idouble: 2
2014-01-01 16:46:17 +00:00
ifloat: 3
2012-11-30 20:41:26 +00:00
Function: "erf":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: "erf_downward":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: "erf_towardzero":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: "erf_upward":
2012-05-30 21:16:52 +00:00
double: 1
float: 1
idouble: 1
ifloat: 1
Function: "erfc":
double: 3
float: 2
idouble: 3
ifloat: 2
Function: "erfc_downward":
double: 5
float: 6
idouble: 5
ifloat: 6
2012-05-30 21:16:52 +00:00
Function: "erfc_towardzero":
double: 3
float: 4
idouble: 3
ifloat: 4
Function: "erfc_upward":
double: 5
float: 6
idouble: 5
ifloat: 6
Function: "exp":
float: 1
ifloat: 1
Function: "exp10":
double: 2
idouble: 2
Function: "exp10_downward":
double: 2
float: 1
idouble: 2
ifloat: 1
Function: "exp10_towardzero":
double: 2
float: 1
idouble: 2
ifloat: 1
Function: "exp10_upward":
double: 2
float: 1
idouble: 2
ifloat: 1
Function: "exp2":
2014-01-01 16:46:17 +00:00
double: 1
float: 1
2014-01-01 16:46:17 +00:00
idouble: 1
ifloat: 1
2014-01-01 16:46:17 +00:00
Function: "exp2_downward":
2014-01-01 16:46:17 +00:00
double: 1
float: 1
2014-01-01 16:46:17 +00:00
idouble: 1
ifloat: 1
2014-01-01 16:46:17 +00:00
Function: "exp2_towardzero":
2014-01-01 16:46:17 +00:00
double: 1
float: 1
2014-01-01 16:46:17 +00:00
idouble: 1
ifloat: 1
2014-01-01 16:46:17 +00:00
Function: "exp2_upward":
2014-01-01 16:46:17 +00:00
double: 1
2012-05-30 21:16:52 +00:00
float: 1
2014-01-01 16:46:17 +00:00
idouble: 1
ifloat: 1
2014-01-01 16:46:17 +00:00
Function: "exp_downward":
double: 1
float: 1
2014-01-01 16:46:17 +00:00
idouble: 1
ifloat: 1
2014-01-01 16:46:17 +00:00
2012-05-30 21:16:52 +00:00
Function: "exp_towardzero":
2014-01-01 16:46:17 +00:00
double: 1
float: 1
2014-01-01 16:46:17 +00:00
idouble: 1
ifloat: 1
2014-01-01 16:46:17 +00:00
Function: "exp_upward":
double: 1
float: 1
2014-01-01 16:46:17 +00:00
idouble: 1
ifloat: 1
2014-01-01 16:46:17 +00:00
Function: "expm1":
double: 1
float: 1
2014-01-01 16:46:17 +00:00
idouble: 1
ifloat: 1
2014-01-01 16:46:17 +00:00
Function: "expm1_downward":
double: 1
2012-05-30 21:16:52 +00:00
float: 1
2014-01-01 16:46:17 +00:00
idouble: 1
2012-05-30 21:16:52 +00:00
ifloat: 1
Function: "expm1_towardzero":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: "expm1_upward":
2013-07-02 20:34:19 +00:00
double: 1
2014-01-01 16:46:17 +00:00
float: 1
2013-07-02 20:34:19 +00:00
idouble: 1
2014-01-01 16:46:17 +00:00
ifloat: 1
2013-07-02 20:34:19 +00:00
Function: "gamma":
double: 4
float: 4
idouble: 4
ifloat: 4
Function: "gamma_downward":
double: 5
float: 4
idouble: 5
ifloat: 4
Function: "gamma_towardzero":
double: 5
float: 4
idouble: 5
ifloat: 4
2012-05-30 21:16:52 +00:00
Function: "gamma_upward":
double: 5
float: 5
idouble: 5
ifloat: 5
2014-01-01 16:46:17 +00:00
Function: "hypot":
double: 1
idouble: 1
Function: "hypot_downward":
double: 1
idouble: 1
Function: "hypot_towardzero":
double: 1
idouble: 1
Function: "hypot_upward":
double: 1
idouble: 1
Function: "j0":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: "j0_downward":
double: 2
float: 4
idouble: 2
ifloat: 4
Function: "j0_towardzero":
double: 3
float: 2
idouble: 3
ifloat: 2
Function: "j0_upward":
double: 3
float: 2
idouble: 3
ifloat: 2
Function: "j1":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: "j1_downward":
double: 3
float: 3
idouble: 3
ifloat: 3
Function: "j1_towardzero":
double: 3
float: 2
idouble: 3
ifloat: 2
Function: "j1_upward":
double: 3
float: 5
idouble: 3
ifloat: 5
Function: "jn":
2012-05-30 21:16:52 +00:00
double: 4
2014-01-01 16:46:17 +00:00
float: 4
2012-05-30 21:16:52 +00:00
idouble: 4
2014-01-01 16:46:17 +00:00
ifloat: 4
Function: "jn_downward":
double: 5
float: 5
idouble: 5
ifloat: 5
2014-01-01 16:46:17 +00:00
Function: "jn_towardzero":
double: 5
float: 5
idouble: 5
ifloat: 5
Function: "jn_upward":
double: 5
float: 5
idouble: 5
ifloat: 5
Function: "lgamma":
double: 4
float: 4
idouble: 4
ifloat: 4
Function: "lgamma_downward":
double: 5
float: 4
idouble: 5
ifloat: 4
Function: "lgamma_towardzero":
double: 5
float: 4
idouble: 5
ifloat: 4
Function: "lgamma_upward":
double: 5
float: 5
idouble: 5
ifloat: 5
2014-01-01 16:46:17 +00:00
Function: "log":
float: 1
ifloat: 1
Function: "log10":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: "log10_downward":
double: 2
float: 3
idouble: 2
ifloat: 3
Function: "log10_towardzero":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: "log10_upward":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: "log1p":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: "log1p_downward":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: "log1p_towardzero":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: "log1p_upward":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: "log2":
double: 2
float: 1
idouble: 2
ifloat: 1
Function: "log2_downward":
double: 3
float: 3
idouble: 3
ifloat: 3
Function: "log2_towardzero":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: "log2_upward":
double: 3
float: 3
idouble: 3
ifloat: 3
Function: "log_downward":
float: 2
ifloat: 2
Function: "log_towardzero":
float: 2
ifloat: 2
Function: "log_upward":
double: 1
float: 2
idouble: 1
ifloat: 2
2012-05-30 21:16:52 +00:00
Function: "pow":
float: 1
ifloat: 1
2012-05-30 21:16:52 +00:00
Function: "pow_downward":
double: 1
float: 1
idouble: 1
ifloat: 1
2014-01-01 16:46:17 +00:00
2012-05-30 21:16:52 +00:00
Function: "pow_towardzero":
double: 1
float: 1
idouble: 1
ifloat: 1
2012-05-30 21:16:52 +00:00
Function: "pow_upward":
double: 1
float: 1
idouble: 1
ifloat: 1
2012-05-30 21:16:52 +00:00
2014-01-01 16:46:17 +00:00
Function: "sin":
float: 1
ifloat: 1
2014-01-01 16:46:17 +00:00
Function: "sin_downward":
double: 1
float: 2
idouble: 1
ifloat: 2
2012-05-30 21:16:52 +00:00
Function: "sin_towardzero":
2014-01-01 16:46:17 +00:00
double: 1
2012-05-30 21:16:52 +00:00
float: 1
2014-01-01 16:46:17 +00:00
idouble: 1
2012-05-30 21:16:52 +00:00
ifloat: 1
Function: "sin_upward":
2014-01-01 16:46:17 +00:00
double: 1
2012-05-30 21:16:52 +00:00
float: 2
2014-01-01 16:46:17 +00:00
idouble: 1
2012-05-30 21:16:52 +00:00
ifloat: 2
Function: "sincos":
float: 1
ifloat: 1
Function: "sincos_downward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: "sincos_towardzero":
double: 1
float: 1
idouble: 1
ifloat: 1
Function: "sincos_upward":
double: 1
float: 2
idouble: 1
ifloat: 2
Function: "sinh":
double: 2
float: 2
idouble: 2
ifloat: 2
2012-05-30 21:16:52 +00:00
Function: "sinh_downward":
double: 3
float: 3
idouble: 3
ifloat: 3
2012-05-30 21:16:52 +00:00
Function: "sinh_towardzero":
double: 2
float: 2
idouble: 2
ifloat: 2
2012-05-30 21:16:52 +00:00
2014-01-01 16:46:17 +00:00
Function: "sinh_upward":
double: 3
float: 3
idouble: 3
ifloat: 3
Function: "tan":
2012-05-30 21:16:52 +00:00
float: 1
ifloat: 1
2014-01-01 16:46:17 +00:00
Function: "tan_downward":
double: 1
float: 2
idouble: 1
ifloat: 2
2012-05-30 21:16:52 +00:00
Function: "tan_towardzero":
2014-01-01 16:46:17 +00:00
double: 1
2012-05-30 21:16:52 +00:00
float: 1
2014-01-01 16:46:17 +00:00
idouble: 1
2012-05-30 21:16:52 +00:00
ifloat: 1
Function: "tan_upward":
2014-01-01 16:46:17 +00:00
double: 1
2012-05-30 21:16:52 +00:00
float: 1
2014-01-01 16:46:17 +00:00
idouble: 1
ifloat: 1
Function: "tanh":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: "tanh_downward":
double: 3
float: 3
idouble: 3
ifloat: 3
Function: "tanh_towardzero":
double: 2
float: 2
idouble: 2
ifloat: 2
Function: "tanh_upward":
double: 3
2013-07-02 20:34:19 +00:00
float: 3
idouble: 3
2013-07-02 20:34:19 +00:00
ifloat: 3
Function: "tgamma":
double: 5
float: 4
idouble: 5
ifloat: 4
Function: "tgamma_downward":
double: 5
float: 5
idouble: 5
ifloat: 5
Function: "tgamma_towardzero":
double: 5
float: 4
idouble: 5
ifloat: 4
Function: "tgamma_upward":
double: 4
float: 4
idouble: 4
ifloat: 4
Function: "y0":
double: 2
float: 1
idouble: 2
ifloat: 1
Function: "y0_downward":
double: 3
float: 4
idouble: 3
ifloat: 4
Function: "y0_towardzero":
double: 3
float: 3
idouble: 3
ifloat: 3
Function: "y0_upward":
double: 3
float: 5
idouble: 3
ifloat: 5
Function: "y1":
double: 3
float: 2
idouble: 3
ifloat: 2
Function: "y1_downward":
double: 3
float: 2
idouble: 3
ifloat: 2
Function: "y1_towardzero":
double: 3
float: 2
idouble: 3
ifloat: 2
Function: "y1_upward":
double: 7
float: 2
idouble: 7
ifloat: 2
Function: "yn":
double: 3
float: 3
idouble: 3
ifloat: 3
Function: "yn_downward":
double: 3
float: 4
idouble: 3
ifloat: 4
Function: "yn_towardzero":
double: 3
float: 3
idouble: 3
ifloat: 3
Function: "yn_upward":
double: 4
float: 5
idouble: 4
ifloat: 5
# end of automatic generation