| //===-- Unittests for atanbf16 --------------------------------------------===// |
| // |
| // 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 "src/__support/FPUtil/bfloat16.h" |
| #include "src/math/atanbf16.h" |
| #include "test/UnitTest/FEnvSafeTest.h" |
| #include "test/UnitTest/FPMatcher.h" |
| #include "test/UnitTest/Test.h" |
| #include "utils/MPFRWrapper/MPFRUtils.h" |
| |
| namespace mpfr = LIBC_NAMESPACE::testing::mpfr; |
| |
| class LlvmLibcAtanBf16Test : public LIBC_NAMESPACE::testing::FEnvSafeTest { |
| DECLARE_SPECIAL_CONSTANTS(bfloat16) |
| public: |
| void test_special_numbers() { |
| EXPECT_FP_EQ_ALL_ROUNDING(aNaN, LIBC_NAMESPACE::atanbf16(aNaN)); |
| EXPECT_MATH_ERRNO(0); |
| |
| EXPECT_FP_EQ_WITH_EXCEPTION_ALL_ROUNDING( |
| aNaN, LIBC_NAMESPACE::atanbf16(sNaN), FE_INVALID); |
| EXPECT_MATH_ERRNO(0); |
| |
| EXPECT_FP_EQ_ALL_ROUNDING(zero, LIBC_NAMESPACE::atanbf16(zero)); |
| EXPECT_MATH_ERRNO(0); |
| |
| EXPECT_FP_EQ_ALL_ROUNDING(neg_zero, LIBC_NAMESPACE::atanbf16(neg_zero)); |
| EXPECT_MATH_ERRNO(0); |
| |
| bfloat16 VALUES[] = {inf, neg_inf, bfloat16(1.0f), bfloat16(-1.0)}; |
| for (size_t i = 0; i < 4; ++i) { |
| bfloat16 x = VALUES[i]; |
| |
| EXPECT_MPFR_MATCH_ALL_ROUNDING(mpfr::Operation::Atan, x, |
| LIBC_NAMESPACE::atanbf16(x), 0.5); |
| } |
| } |
| }; |
| TEST_F(LlvmLibcAtanBf16Test, SpecialNumbers) { test_special_numbers(); } |