-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbench.h
118 lines (102 loc) · 3.09 KB
/
bench.h
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
110
111
112
113
114
115
116
117
118
#include <string.h>
#ifndef BENCH_H
#define BENCH_H
/*============================================================================*/
/* Macro definitions */
/*============================================================================*/
/**
* Number of times each benchmark is ran.
*/
#define BENCH 100
/**
* Runs a new benchmark once.
*
* @param[in] LABEL - the label for this benchmark.
* @param[in] FUNCTION - the function to benchmark.
*/
#define BENCH_ONCE(LABEL, FUNCTION) \
bench_reset(); \
printf("BENCH: " LABEL "%*c = ", (int)(32 - strlen(LABEL)), ' '); \
bench_before(); \
FUNCTION; \
bench_after(); \
bench_compute(1); \
bench_print(); \
/**
* Runs a new benchmark a small number of times.
*
* @param[in] LABEL - the label for this benchmark.
* @param[in] FUNCTION - the function to benchmark.
*/
#define BENCH_SMALL(LABEL, FUNCTION) \
bench_reset(); \
printf("BENCH: " LABEL "%*c = ", (int)(32 - strlen(LABEL)), ' '); \
bench_before(); \
for (int i = 0; i < BENCH; i++) { \
FUNCTION; \
} \
bench_after(); \
bench_compute(BENCH); \
bench_print(); \
/**
* Runs a new benchmark.
*
* @param[in] LABEL - the label for this benchmark.
*/
#define BENCH_BEGIN(LABEL) \
bench_reset(); \
printf("BENCH: " LABEL "%*c = ", (int)(32 - strlen(LABEL)), ' '); \
for (int i = 0; i < BENCH; i++) { \
/**
* Prints the mean timing of each execution in nanoseconds.
*/
#define BENCH_END \
} \
bench_compute(BENCH * BENCH); \
bench_print() \
/**
* Measures the time of one execution and adds it to the benchmark total.
*
* @param[in] FUNCTION - the function executed.
*/
#define BENCH_ADD(FUNCTION) \
FUNCTION; \
bench_before(); \
for (int j = 0; j < BENCH; j++) { \
FUNCTION; \
} \
bench_after(); \
/*============================================================================*/
/* Function prototypes */
/*============================================================================*/
/**
* Resets the benchmark data.
*
* @param[in] label - the benchmark label.
*/
void bench_reset(void);
/**
* Measures the time before a benchmark is executed.
*/
void bench_before(void);
/**
* Measures the time after a benchmark was started and adds it to the total.
*/
void bench_after(void);
/**
* Computes the mean elapsed time between the start and the end of a benchmark.
*
* @param benches - the number of executed benchmarks.
*/
void bench_compute(int benches);
/**
* Prints the last benchmark.
*/
void bench_print(void);
/**
* Returns the result of the last benchmark.
*
* @return the last benchmark.
*/
unsigned long long bench_total(void);
#endif /* !BENCH_H */