
This patch adds a new set of randomized conformance tests for single-precision bivariate math functions. The functions included in this set were selected based on the following criteria: - An implementation exists in `libc/src/math/generic` (i.e., it is not just a wrapper around a compiler built-in). - The corresponding LLVM CPU libm implementation is correctly rounded. - The function is listed in Table 65 of the OpenCL C Specification v3.0.19.
59 lines
1.9 KiB
C++
59 lines
1.9 KiB
C++
//===----------------------------------------------------------------------===//
|
||
//
|
||
// 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
|
||
//
|
||
//===----------------------------------------------------------------------===//
|
||
///
|
||
/// \file
|
||
/// This file contains the conformance test of the hypotf function.
|
||
///
|
||
//===----------------------------------------------------------------------===//
|
||
|
||
#include "mathtest/CommandLineExtras.hpp"
|
||
#include "mathtest/IndexedRange.hpp"
|
||
#include "mathtest/RandomGenerator.hpp"
|
||
#include "mathtest/RandomState.hpp"
|
||
#include "mathtest/TestConfig.hpp"
|
||
#include "mathtest/TestRunner.hpp"
|
||
|
||
#include "llvm/ADT/StringRef.h"
|
||
|
||
#include <cstdlib>
|
||
#include <math.h>
|
||
|
||
namespace mathtest {
|
||
|
||
template <> struct FunctionConfig<hypotf> {
|
||
static constexpr llvm::StringRef Name = "hypotf";
|
||
static constexpr llvm::StringRef KernelName = "hypotfKernel";
|
||
|
||
// Source: The Khronos Group, The OpenCL C Specification v3.0.19, Sec. 7.4,
|
||
// Table 65, Khronos Registry [July 10, 2025].
|
||
static constexpr uint64_t UlpTolerance = 4;
|
||
};
|
||
} // namespace mathtest
|
||
|
||
int main(int argc, const char **argv) {
|
||
llvm::cl::ParseCommandLineOptions(argc, argv,
|
||
"Conformance test of the hypotf function");
|
||
|
||
using namespace mathtest;
|
||
|
||
uint64_t Seed = 42;
|
||
uint64_t Size = 1ULL << 32;
|
||
IndexedRange<float> RangeX;
|
||
IndexedRange<float> RangeY;
|
||
RandomGenerator<float, float> Generator(SeedTy{Seed}, Size, RangeX, RangeY);
|
||
|
||
const auto Configs = cl::getTestConfigs();
|
||
const llvm::StringRef DeviceBinaryDir = DEVICE_BINARY_DIR;
|
||
const bool IsVerbose = cl::IsVerbose;
|
||
|
||
bool Passed =
|
||
runTests<hypotf>(Generator, Configs, DeviceBinaryDir, IsVerbose);
|
||
|
||
return Passed ? EXIT_SUCCESS : EXIT_FAILURE;
|
||
}
|