1 //===-- Unittests for supfuncf --------------------------------------------===//
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
7 //===----------------------------------------------------------------------===//
9 #include "in_float_range_test_helper.h"
10 #include "src/__support/FPUtil/FPBits.h"
11 #include "src/math/generic/explogxf.h"
12 #include "test/UnitTest/FPMatcher.h"
13 #include "test/UnitTest/Test.h"
14 #include "utils/MPFRWrapper/MPFRUtils.h"
17 namespace mpfr
= __llvm_libc::testing::mpfr
;
19 DECLARE_SPECIAL_CONSTANTS(float)
21 constexpr int def_count
= 100003;
22 constexpr float def_prec
= 0.500001f
;
24 auto f_normal
= [](float x
) -> bool {
25 return !(isnan(x
) || isinf(x
) || fabs(x
) < 2E-38);
28 TEST(LlvmLibcExpxfTest
, InFloatRange
) {
29 auto fx
= [](float x
) -> float {
30 auto result
= __llvm_libc::exp_b_range_reduc
<__llvm_libc::ExpBase
>(x
);
31 double r
= __llvm_libc::ExpBase::powb_lo(result
.lo
);
32 return static_cast<float>(result
.mh
* r
);
34 auto f_check
= [](float x
) -> bool {
36 (isnan(x
) || isinf(x
) || x
< -70 || x
> 70 || fabsf(x
) < 0x1.0p
-10));
38 CHECK_DATA(0.0f
, neg_inf
, mpfr::Operation::Exp
, fx
, f_check
, def_count
,
42 TEST(LlvmLibcLog2xfTest
, InFloatRange
) {
43 CHECK_DATA(0.0f
, inf
, mpfr::Operation::Log2
, __llvm_libc::log2_eval
, f_normal
,
47 TEST(LlvmLibcLogxfTest
, InFloatRange
) {
48 CHECK_DATA(0.0f
, inf
, mpfr::Operation::Log
, __llvm_libc::log_eval
, f_normal
,