-
Notifications
You must be signed in to change notification settings - Fork 19
/
timer.h
54 lines (42 loc) · 1.24 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
//
// Copyright (c) 1994, 1995, 2006 by Mike Romberg ( [email protected] )
//
// This file may be distributed under terms of the GPL
//
#ifndef _TIMER_H_
#define _TIMER_H_
//
// General purpose interval timer class
//
// Implemented using BSD derived function gettimeofday for greater resolution
//
// Author : Mike Romberg
#include "timeval.h"
#include <sys/time.h>
#include <iostream>
class Timer {
public:
Timer( int start = 0 ) { if ( start ) Timer::start(); }
~Timer( void ){}
void start( void ) { gettimeofday( &starttime_, NULL ); }
void stop( void ) { gettimeofday( &stoptime_, NULL ); }
// This one uses doubles as the return value, to avoid
// overflow/sign problems.
double report_usecs(void) const {
return (stoptime_.tv_sec - starttime_.tv_sec) * 1000000.0
+ stoptime_.tv_usec - starttime_.tv_usec;
}
std::ostream &printOn(std::ostream &os) const {
return os <<"Timer : ["
<<"starttime_ = " <<TimeVal(starttime_)
<<", stoptime_ = " <<TimeVal(stoptime_)
<<", duration = " <<report_usecs() <<" usecs]";
}
protected:
struct timeval starttime_, stoptime_;
private:
};
inline std::ostream &operator<<(std::ostream &os, const Timer &t){
return t.printOn(os);
}
#endif