/usr/include/stxxl/bits/common/timer.h is in libstxxl-dev 1.3.1-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 | /***************************************************************************
* include/stxxl/bits/common/timer.h
*
* Part of the STXXL. See http://stxxl.sourceforge.net
*
* Copyright (C) 2002, 2005 Roman Dementiev <dementiev@mpi-sb.mpg.de>
* Copyright (C) 2007-2009 Andreas Beckmann <beckmann@cs.uni-frankfurt.de>
* Copyright (C) 2008 Johannes Singler <singler@ira.uka.de>
*
* Distributed under the Boost Software License, Version 1.0.
* (See accompanying file LICENSE_1_0.txt or copy at
* http://www.boost.org/LICENSE_1_0.txt)
**************************************************************************/
#ifndef STXXL_TIMER_HEADER
#define STXXL_TIMER_HEADER
#ifdef STXXL_BOOST_TIMESTAMP
#include <boost/date_time/posix_time/posix_time.hpp>
#include <cmath>
#else
#include <ctime>
#include <sys/time.h>
#endif
#include <stxxl/bits/namespace.h>
__STXXL_BEGIN_NAMESPACE
//! \brief Returns number of seconds since the epoch, high resolution.
inline double
timestamp()
{
#ifdef STXXL_BOOST_TIMESTAMP
boost::posix_time::ptime MyTime = boost::posix_time::microsec_clock::local_time();
boost::posix_time::time_duration Duration =
MyTime - boost::posix_time::time_from_string("1970-01-01 00:00:00.000");
double sec = double(Duration.hours()) * 3600. +
double(Duration.minutes()) * 60. +
double(Duration.seconds()) +
double(Duration.fractional_seconds()) / (pow(10., Duration.num_fractional_digits()));
return sec;
#else
struct timeval tp;
gettimeofday(&tp, NULL);
return double(tp.tv_sec) + tp.tv_usec / 1000000.;
#endif
}
class timer
{
bool running;
double accumulated;
double last_clock;
inline double timestamp();
public:
inline timer(bool start_immediately = false);
inline void start();
inline void stop();
inline void reset();
inline double seconds();
inline double mseconds();
inline double useconds();
};
timer::timer(bool start_immediately) : running(false), accumulated(0.)
{
if (start_immediately)
start();
}
double timer::timestamp()
{
return stxxl::timestamp();
}
void timer::start()
{
running = true;
last_clock = timestamp();
}
void timer::stop()
{
running = false;
accumulated += timestamp() - last_clock;
}
void timer::reset()
{
accumulated = 0.;
last_clock = timestamp();
}
double timer::mseconds()
{
if (running)
return (accumulated + timestamp() - last_clock) * 1000.;
return (accumulated * 1000.);
}
double timer::useconds()
{
if (running)
return (accumulated + timestamp() - last_clock) * 1000000.;
return (accumulated * 1000000.);
}
double timer::seconds()
{
if (running)
return (accumulated + timestamp() - last_clock);
return (accumulated);
}
__STXXL_END_NAMESPACE
#endif // !STXXL_TIMER_HEADER
// vim: et:ts=4:sw=4
|