| //===-- Exhaustive test for sinf - 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 |
| // |
| //===----------------------------------------------------------------------===// |
| |
| // Test float-only fast math implementation for sinf. |
| #define LIBC_MATH (LIBC_MATH_FAST | LIBC_MATH_INTERMEDIATE_COMP_IN_FLOAT) |
| |
| #include "exhaustive_test.h" |
| #include "src/__support/math/sincosf_float_eval.h" |
| #include "utils/MPFRWrapper/MPFRUtils.h" |
| |
| namespace mpfr = LIBC_NAMESPACE::testing::mpfr; |
| |
| float sinf_fast(float x) { |
| return LIBC_NAMESPACE::math::sincosf_float_eval::sincosf_eval< |
| /*IS_SIN*/ true>(x); |
| } |
| |
| using LlvmLibcSinfExhaustiveTest = |
| LlvmLibcUnaryOpExhaustiveMathTest<float, mpfr::Operation::Sin, sinf_fast, |
| 3>; |
| |
| // Range: [0, Inf]; |
| static constexpr uint32_t POS_START = 0x0000'0000U; |
| static constexpr uint32_t POS_STOP = 0x7f80'0000U; |
| |
| TEST_F(LlvmLibcSinfExhaustiveTest, 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(LlvmLibcSinfExhaustiveTest, 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); |
| } |