|
15 | 15 | #include "src/math/amdgpu/declarations.h"
|
16 | 16 | #endif
|
17 | 17 |
|
18 |
| -constexpr double M_PI = 3.14159265358979323846; |
19 |
| -uint64_t get_bits(double x) { |
20 |
| - return LIBC_NAMESPACE::cpp::bit_cast<uint64_t>(x); |
21 |
| -} |
22 |
| - |
23 | 18 | // BENCHMARK() expects a function that with no parameters that returns a
|
24 | 19 | // uint64_t representing the latency. Defining each benchmark using macro that
|
25 | 20 | // expands to a lambda to allow us to switch the implementation of `sin()` to
|
26 | 21 | // easily register NVPTX benchmarks.
|
27 |
| -#define BM_RANDOM_INPUT(Func) \ |
28 |
| - []() { \ |
29 |
| - double x = LIBC_NAMESPACE::benchmarks::get_rand_input<double>(); \ |
30 |
| - return LIBC_NAMESPACE::latency(Func, x); \ |
31 |
| - } |
32 |
| -BENCHMARK(LlvmLibcSinGpuBenchmark, Sin, BM_RANDOM_INPUT(LIBC_NAMESPACE::sin)); |
33 |
| - |
34 |
| -#define BM_TWO_PI(Func) \ |
| 22 | +#define BM_RANDOM_INPUT(Func, MIN_EXP, MAX_EXP, N) \ |
35 | 23 | []() { \
|
36 |
| - return LIBC_NAMESPACE::benchmarks::MathPerf<double>::run_perf_in_range( \ |
37 |
| - Func, 0, get_bits(2 * M_PI), get_bits(M_PI / 64)); \ |
| 24 | + return LIBC_NAMESPACE::benchmarks::MathPerf<double>::run_perf_in_range<N>( \ |
| 25 | + Func, MIN_EXP, MAX_EXP); \ |
38 | 26 | }
|
39 |
| -BENCHMARK(LlvmLibcSinGpuBenchmark, SinTwoPi, BM_TWO_PI(LIBC_NAMESPACE::sin)); |
40 | 27 |
|
41 |
| -#define BM_LARGE_INT(Func) \ |
42 |
| - []() { \ |
43 |
| - return LIBC_NAMESPACE::benchmarks::MathPerf<double>::run_perf_in_range( \ |
44 |
| - Func, 0, get_bits(1 << 30), get_bits(1 << 4)); \ |
45 |
| - } |
46 |
| -BENCHMARK(LlvmLibcSinGpuBenchmark, SinLargeInt, |
47 |
| - BM_LARGE_INT(LIBC_NAMESPACE::sin)); |
| 28 | +#define BENCH(Name, Func, MIN_EXP, MAX_EXP) \ |
| 29 | + BENCHMARK(LlvmLibcSinGpuBenchmark, Name##_1, \ |
| 30 | + BM_RANDOM_INPUT(Func, MIN_EXP, MAX_EXP, 1)); \ |
| 31 | + BENCHMARK(LlvmLibcSinGpuBenchmark, Name##_128, \ |
| 32 | + BM_RANDOM_INPUT(Func, MIN_EXP, MAX_EXP, 128)); \ |
| 33 | + BENCHMARK(LlvmLibcSinGpuBenchmark, Name##_1024, \ |
| 34 | + BM_RANDOM_INPUT(Func, MIN_EXP, MAX_EXP, 1024)); \ |
| 35 | + BENCHMARK(LlvmLibcSinGpuBenchmark, Name##_4096, \ |
| 36 | + BM_RANDOM_INPUT(Func, MIN_EXP, MAX_EXP, 4096)) |
| 37 | + |
| 38 | +BENCH(Sin, LIBC_NAMESPACE::sin, -1023, 1023); |
| 39 | +BENCH(SinTwoPi, LIBC_NAMESPACE::sin, -10, 3); |
| 40 | +BENCH(SinTwoPow30, LIBC_NAMESPACE::sin, 0, 30); |
| 41 | +BENCH(SinVeryLarge, LIBC_NAMESPACE::sin, 30, 1000); |
48 | 42 |
|
49 | 43 | #ifdef NVPTX_MATH_FOUND
|
50 |
| -BENCHMARK(LlvmLibcSinGpuBenchmark, NvSin, |
51 |
| - BM_RANDOM_INPUT(LIBC_NAMESPACE::__nv_sin)); |
52 |
| -BENCHMARK(LlvmLibcSinGpuBenchmark, NvSinTwoPi, |
53 |
| - BM_TWO_PI(LIBC_NAMESPACE::__nv_sin)); |
54 |
| -BENCHMARK(LlvmLibcSinGpuBenchmark, NvSinLargeInt, |
55 |
| - BM_LARGE_INT(LIBC_NAMESPACE::__nv_sin)); |
| 44 | +BENCH(NvSin, LIBC_NAMESPACE::__nv_sin, -1023, 1023); |
| 45 | +BENCH(NvSinTwoPi, LIBC_NAMESPACE::__nv_sin, -10, 3); |
| 46 | +BENCH(NvSinTwoPow30, LIBC_NAMESPACE::__nv_sin, 0, 30); |
| 47 | +BENCH(NvSinVeryLarge, LIBC_NAMESPACE::__nv_sin, 30, 1000); |
56 | 48 | #endif
|
57 | 49 |
|
58 | 50 | #ifdef AMDGPU_MATH_FOUND
|
59 |
| -BENCHMARK(LlvmLibcSinGpuBenchmark, AmdgpuSin, |
60 |
| - BM_RANDOM_INPUT(LIBC_NAMESPACE::__ocml_sin_f64)); |
61 |
| -BENCHMARK(LlvmLibcSinGpuBenchmark, AmdgpuSinTwoPi, |
62 |
| - BM_TWO_PI(LIBC_NAMESPACE::__ocml_sin_f64)); |
63 |
| -BENCHMARK(LlvmLibcSinGpuBenchmark, AmdgpuSinLargeInt, |
64 |
| - BM_LARGE_INT(LIBC_NAMESPACE::__ocml_sin_f64)); |
| 51 | +BENCH(AmdgpuSin, LIBC_NAMESPACE::__ocml_sin_f64, -1023, 1023); |
| 52 | +BENCH(AmdgpuSinTwoPi, LIBC_NAMESPACE::__ocml_sin_f64, -10, 3); |
| 53 | +BENCH(AmdgpuSinTwoPow30, LIBC_NAMESPACE::__ocml_sin_f64, 0, 30); |
| 54 | +BENCH(AmdgpuSinVeryLarge, LIBC_NAMESPACE::__ocml_sin_f64, 30, 1000); |
65 | 55 | #endif
|
0 commit comments