blob: 0c3a98832c84da7d336d567c9a0cfa866e961ec3 [file] [log] [blame] [edit]
//===-- Exhaustive test for cosf - 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/sincosf_float_eval.h"
#include "utils/MPFRWrapper/MPFRUtils.h"
namespace mpfr = LIBC_NAMESPACE::testing::mpfr;
float cosf_fast(float x) {
return LIBC_NAMESPACE::math::sincosf_float_eval::sincosf_eval<
/*IS_SIN*/ false>(x);
}
using LlvmLibcCosfExhaustiveTest =
LlvmLibcUnaryOpExhaustiveMathTest<float, mpfr::Operation::Cos, cosf_fast,
3>;
// Range: [0, Inf];
static constexpr uint32_t POS_START = 0x0000'0000U;
static constexpr uint32_t POS_STOP = 0x7f80'0000U;
TEST_F(LlvmLibcCosfExhaustiveTest, 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(LlvmLibcCosfExhaustiveTest, 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);
}