|  | //===-- Unittests for sin -------------------------------------------------===// | 
|  | // | 
|  | // 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/FPBits.h" | 
|  | #include "src/math/sin.h" | 
|  | #include "test/UnitTest/FPMatcher.h" | 
|  | #include "test/UnitTest/Test.h" | 
|  | #include "utils/MPFRWrapper/MPFRUtils.h" | 
|  |  | 
|  | #include "hdr/math_macros.h" | 
|  |  | 
|  | using LlvmLibcSinTest = LIBC_NAMESPACE::testing::FPTest<double>; | 
|  |  | 
|  | namespace mpfr = LIBC_NAMESPACE::testing::mpfr; | 
|  |  | 
|  | TEST_F(LlvmLibcSinTest, Range) { | 
|  | static constexpr double _2pi = 6.283185307179586; | 
|  | constexpr StorageType COUNT = 100'000; | 
|  | constexpr StorageType STEP = STORAGE_MAX / COUNT; | 
|  | for (StorageType i = 0, v = 0; i <= COUNT; ++i, v += STEP) { | 
|  | double x = FPBits(v).get_val(); | 
|  | // TODO: Expand the range of testing after range reduction is implemented. | 
|  | if (isnan(x) || isinf(x) || x > _2pi || x < -_2pi) | 
|  | continue; | 
|  |  | 
|  | ASSERT_MPFR_MATCH(mpfr::Operation::Sin, x, LIBC_NAMESPACE::sin(x), 1.0); | 
|  | } | 
|  | } |