llvm-project/libc/utils
Kirill Okhotnikov b8e8012aa2 [libc][math] fmod/fmodf implementation.
This is a implementation of find remainder fmod function from standard libm.
The underline algorithm is developed by myself, but probably it was first
invented before.
Some features of the implementation:
1. The code is written on more-or-less modern C++.
2. One general implementation for both float and double precision numbers.
3. Spitted platform/architecture dependent and independent code and tests.
4. Tests covers 100% of the code for both float and double numbers. Tests cases with NaN/Inf etc is copied from glibc.
5. The new implementation in general 2-4 times faster for “regular” x,y values. It can be 20 times faster for x/y huge value, but can also be 2 times slower for double denormalized range (according to perf tests provided).
6. Two different implementation of division loop are provided. In some platforms division can be very time consuming operation. Depend on platform it can be 3-10 times slower than multiplication.

Performance tests:

The test is based on core-math project (https://gitlab.inria.fr/core-math/core-math). By Tue Ly suggestion I took hypot function and use it as template for fmod. Preserving all test cases.

`./check.sh <--special|--worst> fmodf` passed.
`CORE_MATH_PERF_MODE=rdtsc ./perf.sh fmodf` results are

```
GNU libc version: 2.35
GNU libc release: stable
21.166 <-- FPU
51.031 <-- current glibc
37.659 <-- this fmod version.
```
2022-06-24 23:09:14 +02:00
..
HdrGen [libc] Add global stdout and stderr objects. 2022-05-27 05:43:49 +00:00
IntegrationTest [libc][NFC] Convert threads unittests in to integration tests. 2022-06-23 20:32:33 +00:00
LibcTableGenUtil [libc] Add global stdout and stderr objects. 2022-05-27 05:43:49 +00:00
MPFRWrapper [libc][math] fmod/fmodf implementation. 2022-06-24 23:09:14 +02:00
UnitTest [libc] Add Uint128 type as a fallback when __uint128_t is not available. 2022-06-24 16:03:35 +00:00
buildbot [libc] Add python3 to libc buildbot depedencies. 2020-12-17 08:59:13 -08:00
mathtools [libc][NFC] Add supporting class for atof implementation 2021-10-04 21:08:02 +00:00
testutils Fix [libc] Minor test signedness fixes 2022-04-26 17:14:52 -07:00
tools [libc][cmake] Make `add_tablegen` calls match others 2022-01-24 18:36:37 +00:00
CMakeLists.txt [libc] Add a new rule add_integration_test. 2022-03-23 20:57:29 +00:00