| //===-- Exhaustive test for atanf - float-only ----------------------------===// |
| // |
| // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| // See https://llvm.org/LICENSE.txt for license information. |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #include "exhaustive_test.h" |
| #include "src/__support/math/atanf_float.h" |
| #include "utils/MPFRWrapper/MPFRUtils.h" |
| |
| namespace mpfr = LIBC_NAMESPACE::testing::mpfr; |
| |
| float atanf_fast(float x) { return LIBC_NAMESPACE::math::atanf(x); } |
| |
| using LlvmLibcAtanfFloatExhaustiveTest = |
| LlvmLibcUnaryOpExhaustiveMathTest<float, mpfr::Operation::Atan, atanf_fast, |
| 4>; |
| |
| // Range: [0, Inf]; |
| static constexpr uint32_t POS_START = 0x0000'0000U; |
| static constexpr uint32_t POS_STOP = 0x7f80'0000U; |
| |
| TEST_F(LlvmLibcAtanfFloatExhaustiveTest, PostiveRange) { |
| std::cout << "-- Testing for FE_TONEAREST in range [0x" << std::hex |
| << POS_START << ", 0x" << POS_STOP << ") --" << std::dec |
| << std::endl; |
| test_full_range(mpfr::RoundingMode::Nearest, POS_START, POS_STOP); |
| } |
| |
| // Range: [-Inf, 0]; |
| static constexpr uint32_t NEG_START = 0x8000'0000U; |
| static constexpr uint32_t NEG_STOP = 0xff80'0000U; |
| |
| TEST_F(LlvmLibcAtanfFloatExhaustiveTest, NegativeRange) { |
| std::cout << "-- Testing for FE_TONEAREST in range [0x" << std::hex |
| << NEG_START << ", 0x" << NEG_STOP << ") --" << std::dec |
| << std::endl; |
| test_full_range(mpfr::RoundingMode::Nearest, NEG_START, NEG_STOP); |
| } |