-
Notifications
You must be signed in to change notification settings - Fork 30
/
time.hpp
70 lines (55 loc) · 1.86 KB
/
time.hpp
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
/*
* Copyright (C) 2019 by AutoSense Organization. All rights reserved.
* Gary Chan <[email protected]>
*/
#ifndef COMMON_INCLUDE_COMMON_TIME_HPP_
#define COMMON_INCLUDE_COMMON_TIME_HPP_
#include <ros/ros.h> // ros::Time::now()
#include <sys/time.h> // gettimeofday
#include <string>
namespace autosense {
namespace common {
//----------------------------------- Timer helper class
class Clock {
public:
Clock() { start(); }
/// \brief Start clock timer.
void start() {
gettimeofday(&real_time_start_, NULL);
cpu_start_ = clock();
}
/// \brief Sample clock timer.
void takeTime() {
struct timeval end;
gettimeofday(&end, NULL);
cpu_time_ms_ = static_cast<double>(clock() - cpu_start_) /
CLOCKS_PER_SEC * kSecondsToMiliseconds;
uint64_t seconds, useconds;
seconds = end.tv_sec - real_time_start_.tv_sec;
useconds = end.tv_usec - real_time_start_.tv_usec;
real_time_ms_ = (seconds * kSecondsToMiliseconds +
useconds * kMicrosecondsToMiliseconds) +
0.5;
}
/// \brief Return elapsed physical time.
double getRealTime() { return real_time_ms_; }
/// \brief Return elapsed CPU time.
double getCPUTime() { return cpu_time_ms_; }
double takeRealTime() {
takeTime();
return getRealTime();
}
private:
struct timeval real_time_start_;
double real_time_ms_, cpu_time_ms_;
clock_t cpu_start_;
static constexpr double kSecondsToMiliseconds = 1000.0;
static constexpr double kMicrosecondsToMiliseconds = 0.001;
};
static std::string getCurrentTimestampString() {
uint64_t current_time = ros::Time::now().toSec() * 100;
return std::to_string(current_time);
}
} // namespace common
} // namespace autosense
#endif // COMMON_INCLUDE_COMMON_TIME_HPP_