Subversion Repositories gelsvn

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
688 khor 1
/* ----------------------------------------------------------------------- *
2
 * This file is part of GEL, http://www.imm.dtu.dk/GEL
3
 * Copyright (C) the authors and DTU Informatics
4
 * For license and list of authors, see ../../doc/intro.pdf
5
 * ----------------------------------------------------------------------- */
6
 
7
/**
8
 * @file Timer.h
9
 * @brief Wall clock timing.
10
 */
11
 
12
#ifndef __UTIL_OSTIMER_H__
13
#define __UTIL_OSTIMER_H__
14
 
15
// Created by bdl 5. april 2002
16
// The purpose of this file is to make a timer function that is as 
17
// precise as posible on any given platform
18
#if (_MSC_VER >= 1200)
19
#pragma warning (disable: 4244)
20
#endif
21
#ifdef WIN32
22
#include <windows.h>
23
static LARGE_INTEGER	largeInteger;
24
#else
25
#include <sys/time.h>
26
#endif
27
 
28
namespace Util{
29
	class Timer {
30
#ifdef WIN32
31
		double freq;
32
		double start_count;
33
#else
34
		timeval start_time;
35
#endif
36
	public:
37
		void start() {
38
#ifdef WIN32
39
			QueryPerformanceFrequency(&largeInteger);
40
			freq = largeInteger.QuadPart;
41
			QueryPerformanceCounter(&largeInteger);
42
			start_count = largeInteger.QuadPart;
43
#else
44
			gettimeofday(&start_time,0);
45
#endif
46
		}
47
 
48
		float get_secs() {
49
#ifdef WIN32
50
			QueryPerformanceCounter(&largeInteger);
51
			double now_count = largeInteger.QuadPart;
52
			return (float)((now_count-start_count)/freq);
53
#else
54
			timeval now;
55
			gettimeofday(&now,0);
56
			return (now.tv_sec-start_time.tv_sec) + 
57
				(now.tv_usec-start_time.tv_usec)/1.0e6;
58
#endif
59
		}
60
	};
61
}
62
 
63
#endif