forked from bkaradzic/bx
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmath_bench.cpp
109 lines (83 loc) · 2.44 KB
/
math_bench.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/*
* Copyright 2010-2023 Branimir Karadzic. All rights reserved.
* License: https://github.com/bkaradzic/bx/blob/master/LICENSE
*/
#include <bx/math.h>
#include <bx/timer.h>
#include <bx/file.h>
#include <math.h>
typedef float (*MathFn)(float);
template<MathFn mfn>
float mathTest(const char* _name)
{
bx::WriterI* writer = bx::getStdOut();
int64_t elapsed = -bx::getHPCounter();
float result = 0.0f;
const float max = 1389.0f;
for (float xx = 0.0f; xx < max; xx += 0.1f)
{
result += mfn(xx);
}
bx::Error err;
elapsed += bx::getHPCounter();
bx::write(writer, &err, "%-20s: %15f\n", _name, double(elapsed) );
return result;
}
float rsqrt(float _a)
{
return 1.0f/::sqrtf(_a);
}
void math_bench()
{
bx::WriterI* writer = bx::getStdOut();
bx::Error err;
bx::write(writer, &err, "Math bench\n\n");
mathTest< ::sqrtf >(" ::sqrtf");
mathTest<bx::sqrtRef >("bx::sqrtRef");
mathTest<bx::sqrtSimd >("bx::sqrtSimd");
mathTest<bx::sqrt >("bx::sqrt");
bx::write(writer, &err, "\n");
mathTest< ::rsqrt >(" ::rsqrtf");
mathTest<bx::rsqrtRef >("bx::rsqrtRef");
mathTest<bx::rsqrtSimd>("bx::rsqrtSimd");
mathTest<bx::rsqrt >("bx::rsqrt");
bx::write(writer, &err, "\n");
mathTest< ::sinf >(" ::sinf");
mathTest<bx::sin >("bx::sin");
bx::write(writer, &err, "\n");
mathTest< ::sinhf>(" ::sinhf");
mathTest<bx::sinh >("bx::sinh");
bx::write(writer, &err, "\n");
mathTest< ::asinf>(" ::asinf");
mathTest<bx::asin >("bx::asin");
bx::write(writer, &err, "\n");
mathTest< ::cosf >(" ::cosf");
mathTest<bx::cos >("bx::cos");
bx::write(writer, &err, "\n");
mathTest< ::coshf>(" ::coshf");
mathTest<bx::cosh >("bx::cosh");
bx::write(writer, &err, "\n");
mathTest< ::acosf>(" ::acosf");
mathTest<bx::acos >("bx::acos");
bx::write(writer, &err, "\n");
mathTest< ::tanf >(" ::tanf");
mathTest<bx::tan >("bx::tan");
bx::write(writer, &err, "\n");
mathTest< ::tanhf>(" ::tanhf");
mathTest<bx::tanh >("bx::tanh");
bx::write(writer, &err, "\n");
mathTest< ::atanf>(" ::atanf");
mathTest<bx::atan >("bx::atan");
bx::write(writer, &err, "\n");
mathTest< ::expf>(" ::expf");
mathTest<bx::exp >("bx::exp");
bx::write(writer, &err, "\n");
mathTest< ::exp2f>(" ::exp2f");
mathTest<bx::exp2 >("bx::exp2");
bx::write(writer, &err, "\n");
mathTest< ::logf >(" ::logf");
mathTest<bx::log >("bx::log");
bx::write(writer, &err, "\n");
mathTest< ::log2f>(" ::log2f");
mathTest<bx::log2 >("bx::log2");
}