forked from aksnzhy/xlearn
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtimer.h
62 lines (53 loc) · 1.7 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
//------------------------------------------------------------------------------
// Copyright (c) 2016 by contributors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//------------------------------------------------------------------------------
/*
Author: Chao Ma ([email protected])
This file define the Timer class.
*/
#ifndef XLEARN_BASE_TIMER_H_
#define XLEARN_BASE_TIMER_H_
#include <chrono>
#include "src/base/common.h"
//------------------------------------------------------------------------------
// We can use the Timer class like this:
//
// Timer timer();
// timer.tic();
//
// .... /* code we want to evaluate */
//
// float time = timer.toc(); // (sec)
//
// This class can be used to evaluate multi-thread code.
//------------------------------------------------------------------------------
class Timer {
public:
Timer();
// Reset start time
void reset();
// Code start
void tic();
// Code end
float toc();
// Get the time duration
float get();
protected:
std::chrono::high_resolution_clock::time_point begin;
std::chrono::milliseconds duration;
private:
DISALLOW_COPY_AND_ASSIGN(Timer);
};
#endif // XLEARN_BASE_TIMER_H_