glibc/sysdeps
Paul Zimmermann 392b3f0971 replace tgammaf by the CORE-MATH implementation
The CORE-MATH implementation is correctly rounded (for any rounding mode).
This can be checked by exhaustive tests in a few minutes since there are
less than 2^32 values to check against for example GNU MPFR.
This patch also adds some bench values for tgammaf.

Tested on x86_64 and x86 (cfarm26).

With the initial GNU libc code it gave on an Intel(R) Core(TM) i7-8700:

      "tgammaf": {
       "": {
        "duration": 3.50188e+09,
        "iterations": 2e+07,
        "max": 602.891,
        "min": 65.1415,
        "mean": 175.094
       }
      }

With the new code:

      "tgammaf": {
       "": {
        "duration": 3.30825e+09,
        "iterations": 5e+07,
        "max": 211.592,
        "min": 32.0325,
        "mean": 66.1649
       }
      }

With the initial GNU libc code it gave on cfarm26 (i686):

  "tgammaf": {
   "": {
    "duration": 3.70505e+09,
    "iterations": 6e+06,
    "max": 2420.23,
    "min": 243.154,
    "mean": 617.509
   }
  }

With the new code:

  "tgammaf": {
   "": {
    "duration": 3.24497e+09,
    "iterations": 1.8e+07,
    "max": 1238.15,
    "min": 101.155,
    "mean": 180.276
   }
  }

Signed-off-by: Alexei Sibidanov <sibid@uvic.ca>
Signed-off-by: Paul Zimmermann <Paul.Zimmermann@inria.fr>

Changes in v2:
    - include <math.h> (fix the linknamespace failures)
    - restored original benchtests/strcoll-inputs/filelist#en_US.UTF-8 file
    - restored original wrapper code (math/w_tgammaf_compat.c),
      except for the dealing with the sign
    - removed the tgammaf/float entries in all libm-test-ulps files
    - address other comments from Joseph Myers
      (https://sourceware.org/pipermail/libc-alpha/2024-July/158736.html)

Changes in v3:
    - pass NULL argument for signgam from w_tgammaf_compat.c
    - use of math_narrow_eval
    - added more comments

Changes in v4:
    - initialize local_signgam to 0 in math/w_tgamma_template.c
    - replace sysdeps/ieee754/dbl-64/gamma_productf.c by dummy file

Changes in v5:
    - do not mention local_signgam any more in math/w_tgammaf_compat.c
    - initialize local_signgam to 1 instead of 0 in w_tgamma_template.c
      and added comment

Changes in v6:
    - pass NULL as 2nd argument of __ieee754_gammaf_r in
      w_tgammaf_compat.c, and check for NULL in e_gammaf_r.c

Changes in v7:
    - added Signed-off-by line for Alexei Sibidanov (author of the code)

Changes in v8:
    - added Signed-off-by line for Paul Zimmermann (submitted of the patch)

Changes in v9:
    - address comments from review by Adhemerval Zanella
Reviewed-by: Adhemerval Zanella  <adhemerval.zanella@linaro.org>
2024-10-11 11:12:32 +02:00
..
aarch64 replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
alpha replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
arc replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
arm replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
csky replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
generic stdlib: Make abort/_Exit AS-safe (BZ 26275) 2024-10-08 14:40:12 -03:00
gnu sysdeps: Re-flow and sort multiline gnu/Makefile definitions 2024-08-07 11:02:03 -03:00
hppa replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
htl stdlib: Make abort/_Exit AS-safe (BZ 26275) 2024-10-08 14:40:12 -03:00
hurd hurd: Move internal functions to internal header 2024-03-23 22:43:07 +01:00
i386 replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
ieee754 replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
loongarch replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
m68k replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
mach Fix header guard in sysdeps/mach/hurd/x86_64/vm_param.h 2024-10-09 19:16:53 +02:00
microblaze replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
mips replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
nios2 replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
nptl stdlib: Make abort/_Exit AS-safe (BZ 26275) 2024-10-08 14:40:12 -03:00
or1k replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
posix stdlib: Make abort/_Exit AS-safe (BZ 26275) 2024-10-08 14:40:12 -03:00
powerpc replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
pthread nptl: Fix Race conditions in pthread cancellation [BZ#12683] 2024-08-23 14:27:43 -03:00
riscv replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
s390 replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
sh replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
sparc replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00
unix misc: Add support for Linux uio.h RWF_ATOMIC flag 2024-10-10 10:28:01 -03:00
wordsize-32 Update copyright dates with scripts/update-copyrights 2024-01-01 10:53:40 -08:00
wordsize-64 Update copyright dates with scripts/update-copyrights 2024-01-01 10:53:40 -08:00
x86 x86: Enable non-temporal memset for Hygon processors 2024-08-26 10:01:58 -07:00
x86_64 replace tgammaf by the CORE-MATH implementation 2024-10-11 11:12:32 +02:00