forked from baidu-research/baidu-allreduce
-
Notifications
You must be signed in to change notification settings - Fork 0
/
timer.h
94 lines (73 loc) · 2.25 KB
/
timer.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
#pragma once
#ifndef TIMER_SMALL_SECOND
#define TIMER_SMALL_SECOND 5e-324
#endif
#ifndef TIMER_LARGE_SECOND
#define TIMER_LARGE_SECOND 5e324
#endif
#include <ctime>
namespace timer
{
class Timer
{
public:
/*! \brief A type for seconds */
typedef double Second;
/*! \brief A type for representing clock ticks */
typedef long long unsigned Cycle;
private:
/*! An integer representing the value of the cycle counter when the
last start() function was called
*/
Cycle beginning;
/*! An integer representing the value of the cycle counter when the
last stop() function was called
*/
Cycle ending;
/*! A floating point number representing the value of the system
clock when the last start() function was called
*/
Second beginningS;
/*! A floating point number representing the value of the system
clock when the last stop() function was called
*/
Second endingS;
/*! Read a cycle counter using either assembly or an OS interface.
\return a 64 bit value representing the current number of
clock cycles since the last reset
*/
static Cycle rdtsc();
/*! \brief Is the Timer running? */
bool running;
public:
/*! \brief The constructor initializes the private variables
and makes sure that the Timer is not running.
*/
Timer();
/*! A function that is used to set beginning to the value of
the hardware Timer
*/
void start();
/*! A function that is used to set ending to the value of
the hardware Timer
*/
void stop();
/*! A function that is used to determine the number of clock cycles
between the last time start was called and the last time that
end was called.
\return the difference between ending and beginning
*/
Cycle cycles() const;
/*! A function that is used to determine the number of seconds
between the last time start was called and the last time that
end was called.
\return the difference between ending and beginning
*/
Second seconds() const;
/*! \brief Get the absolute number of seconds elapsed since system
start
\return That time
*/
Second absolute() const;
};
}