Skip to content

Commit 2b592b1

Browse files
authored
[libc][gpu] Add Sinf Benchmarks (#102532)
This PR adds benchmarking for `sinf()` using the same set up as `sin()` but with a smaller range for floats.
1 parent d46c26b commit 2b592b1

File tree

2 files changed

+41
-20
lines changed

2 files changed

+41
-20
lines changed

libc/benchmarks/gpu/src/math/CMakeLists.txt

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -32,6 +32,7 @@ add_benchmark(
3232
sin_benchmark.cpp
3333
DEPENDS
3434
libc.src.math.sin
35+
libc.src.math.sinf
3536
libc.src.stdlib.srand
3637
libc.src.stdlib.rand
3738
libc.src.__support.FPUtil.fp_bits

libc/benchmarks/gpu/src/math/sin_benchmark.cpp

Lines changed: 40 additions & 20 deletions
Original file line numberDiff line numberDiff line change
@@ -5,6 +5,7 @@
55
#include "src/__support/CPP/functional.h"
66
#include "src/__support/FPUtil/FPBits.h"
77
#include "src/math/sin.h"
8+
#include "src/math/sinf.h"
89
#include "src/stdlib/rand.h"
910

1011
#ifdef NVPTX_MATH_FOUND
@@ -19,37 +20,56 @@
1920
// uint64_t representing the latency. Defining each benchmark using macro that
2021
// expands to a lambda to allow us to switch the implementation of `sin()` to
2122
// easily register NVPTX benchmarks.
22-
#define BM_RANDOM_INPUT(Func, MIN_EXP, MAX_EXP, N) \
23+
#define BM_RANDOM_INPUT(T, Func, MIN_EXP, MAX_EXP, N) \
2324
[]() { \
24-
return LIBC_NAMESPACE::benchmarks::MathPerf< \
25-
double>::run_throughput_in_range<N>(Func, MIN_EXP, MAX_EXP); \
25+
return LIBC_NAMESPACE::benchmarks::MathPerf<T>::run_throughput_in_range< \
26+
N>(Func, MIN_EXP, MAX_EXP); \
2627
}
2728

28-
#define BENCH(Name, Func, MIN_EXP, MAX_EXP) \
29+
#define BENCH(T, Name, Func, MIN_EXP, MAX_EXP) \
2930
SINGLE_WAVE_BENCHMARK(LlvmLibcSinGpuBenchmark, Name##_1, \
30-
BM_RANDOM_INPUT(Func, MIN_EXP, MAX_EXP, 1)); \
31+
BM_RANDOM_INPUT(T, Func, MIN_EXP, MAX_EXP, 1)); \
3132
SINGLE_WAVE_BENCHMARK(LlvmLibcSinGpuBenchmark, Name##_128, \
32-
BM_RANDOM_INPUT(Func, MIN_EXP, MAX_EXP, 128)); \
33+
BM_RANDOM_INPUT(T, Func, MIN_EXP, MAX_EXP, 128)); \
3334
SINGLE_WAVE_BENCHMARK(LlvmLibcSinGpuBenchmark, Name##_1024, \
34-
BM_RANDOM_INPUT(Func, MIN_EXP, MAX_EXP, 1024)); \
35+
BM_RANDOM_INPUT(T, Func, MIN_EXP, MAX_EXP, 1024)); \
3536
SINGLE_WAVE_BENCHMARK(LlvmLibcSinGpuBenchmark, Name##_4096, \
36-
BM_RANDOM_INPUT(Func, MIN_EXP, MAX_EXP, 4096))
37+
BM_RANDOM_INPUT(T, Func, MIN_EXP, MAX_EXP, 4096))
3738

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);
39+
BENCH(double, Sin, LIBC_NAMESPACE::sin, -1023, 1023);
40+
BENCH(double, SinTwoPi, LIBC_NAMESPACE::sin, -10, 3);
41+
BENCH(double, SinTwoPow30, LIBC_NAMESPACE::sin, 0, 30);
42+
BENCH(double, SinVeryLarge, LIBC_NAMESPACE::sin, 30, 1000);
4243

4344
#ifdef NVPTX_MATH_FOUND
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);
45+
BENCH(double, NvSin, LIBC_NAMESPACE::__nv_sin, -1023, 1023);
46+
BENCH(double, NvSinTwoPi, LIBC_NAMESPACE::__nv_sin, -10, 3);
47+
BENCH(double, NvSinTwoPow30, LIBC_NAMESPACE::__nv_sin, 0, 30);
48+
BENCH(double, NvSinVeryLarge, LIBC_NAMESPACE::__nv_sin, 30, 1000);
4849
#endif
4950

5051
#ifdef AMDGPU_MATH_FOUND
51-
BENCH(AmdSin, LIBC_NAMESPACE::__ocml_sin_f64, -1023, 1023);
52-
BENCH(AmdSinTwoPi, LIBC_NAMESPACE::__ocml_sin_f64, -10, 3);
53-
BENCH(AmdSinTwoPow30, LIBC_NAMESPACE::__ocml_sin_f64, 0, 30);
54-
BENCH(AmdSinVeryLarge, LIBC_NAMESPACE::__ocml_sin_f64, 30, 1000);
52+
BENCH(double, AmdSin, LIBC_NAMESPACE::__ocml_sin_f64, -1023, 1023);
53+
BENCH(double, AmdSinTwoPi, LIBC_NAMESPACE::__ocml_sin_f64, -10, 3);
54+
BENCH(double, AmdSinTwoPow30, LIBC_NAMESPACE::__ocml_sin_f64, 0, 30);
55+
BENCH(double, AmdSinVeryLarge, LIBC_NAMESPACE::__ocml_sin_f64, 30, 1000);
56+
#endif
57+
58+
BENCH(float, Sinf, LIBC_NAMESPACE::sinf, -127, 128);
59+
BENCH(float, SinfTwoPi, LIBC_NAMESPACE::sinf, -10, 3);
60+
BENCH(float, SinfTwoPow30, LIBC_NAMESPACE::sinf, 0, 30);
61+
BENCH(float, SinfVeryLarge, LIBC_NAMESPACE::sinf, 30, 120);
62+
63+
#ifdef NVPTX_MATH_FOUND
64+
BENCH(float, NvSinf, LIBC_NAMESPACE::__nv_sinf, -127, 128);
65+
BENCH(float, NvSinfTwoPi, LIBC_NAMESPACE::__nv_sinf, -10, 3);
66+
BENCH(float, NvSinfTwoPow30, LIBC_NAMESPACE::__nv_sinf, 0, 30);
67+
BENCH(float, NvSinfVeryLarge, LIBC_NAMESPACE::__nv_sinf, 30, 120);
68+
#endif
69+
70+
#ifdef AMDGPU_MATH_FOUND
71+
BENCH(float, AmdSinf, LIBC_NAMESPACE::__ocml_sin_f32, -127, 128);
72+
BENCH(float, AmdSinfTwoPi, LIBC_NAMESPACE::__ocml_sin_f32, -10, 3);
73+
BENCH(float, AmdSinfTwoPow30, LIBC_NAMESPACE::__ocml_sin_f32, 0, 30);
74+
BENCH(float, AmdSinfVeryLarge, LIBC_NAMESPACE::__ocml_sin_f32, 30, 120);
5575
#endif

0 commit comments

Comments
 (0)