/usr/include/CGAL/Timer_impl.h is in libcgal-dev 4.9-1+b2.
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 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 | // Copyright (c) 1997
// Utrecht University (The Netherlands),
// ETH Zurich (Switzerland),
// INRIA Sophia-Antipolis (France),
// Max-Planck-Institute Saarbruecken (Germany),
// and Tel-Aviv University (Israel). All rights reserved.
//
// This file is part of CGAL (www.cgal.org); you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public License as
// published by the Free Software Foundation; either version 3 of the License,
// or (at your option) any later version.
//
// Licensees holding a valid commercial license may use this file in
// accordance with the commercial license agreement provided with the software.
//
// This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
// WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
//
// $URL$
// $Id$
//
//
// Author(s) : Lutz Kettner <kettner@inf.ethz.ch>
// Matthias Baesken <baesken@informatik.uni-halle.de>
#ifdef CGAL_HEADER_ONLY
#define CGAL_INLINE_FUNCTION inline
#else
#define CGAL_INLINE_FUNCTION
#endif
// Determine if the POSIX function getrusage is available, otherwise
// use the previous solution based on std::clock().
// First, detect POSIX. We cannot reliably use "unistd.h",
// but limits.h is part of the C standard.
#include <climits>
#ifdef _POSIX_ARG_MAX // now that should be POSIX
#include <unistd.h>
#ifdef _POSIX_VERSION
#ifdef _XOPEN_UNIX // XSI: X/Open System Interfaces Extension
#define CGAL__GETRUSAGE 1
#endif
#endif
#endif
#ifdef CGAL__GETRUSAGE
// types, function prototype and constants for the POSIX function
// int getrusage (int who, struct rusage *usage);
#include <sys/resource.h>
// For the numerical limits
#else // CGAL__GETRUSAGE //
// used for clock()
#include <ctime>
#endif // CGAL__GETRUSAGE //
// For the numerical limits
#include <cfloat>
namespace CGAL {
// Member functions for Timer
// =====================================
CGAL_INLINE_FUNCTION
double Timer::user_process_time() const {
// Depends on the operating system.
// Returns a (weakly ;-) monotone increasing time in seconds (with
// possible wrap-around in case of overflow, see max()), or 0.0
// if the system call for the time failed. If the system call
// failed the static flag 'm_failed' is set and can be used
// by the caller.
#ifdef CGAL__GETRUSAGE
struct rusage usage;
int ret = getrusage( RUSAGE_SELF, &usage);
CGAL_warning_msg( ret == 0, "Call to getrusage() in class CGAL::Timer "
"failed - timings will be 0.");
if ( ret == 0) {
return double( usage.ru_utime.tv_sec) // seconds
+ double( usage.ru_utime.tv_usec) / 1000000.0; // microseconds
}
#else // CGAL__GETRUSAGE //
std::clock_t clk = std::clock();
CGAL_warning_msg( clk != (std::clock_t)-1,
"Call to clock() in class CGAL::Timer failed - timings will be 0.");
if ( clk != (std::clock_t)-1) {
return double(clk) / CLOCKS_PER_SEC;
}
#endif // CGAL__GETRUSAGE //
get_static_timer_m_failed() = true;
return 0.0;
}
CGAL_INLINE_FUNCTION
double Timer::compute_precision() const {
// Computes timer precision in seconds dynamically. Note that
// the timer system call is probably non-trivial and will show
// up in this time here (probably for one call). But that is just
// fine that the call to the timer itself if reported as noise
// in the precision.
double min_res = DBL_MAX;
for ( int i = 0; i < 5; ++i) {
double current = user_process_time();
if ( get_static_timer_m_failed() )
return -1.0;
double next = user_process_time();
while ( current >= next) { // wait until timer increases
next = user_process_time();
if ( get_static_timer_m_failed() )
return -1.0;
}
// Get the minimum timing difference of all runs.
if ( min_res > next - current)
min_res = next - current;
}
return min_res;
}
CGAL_INLINE_FUNCTION
double Timer::precision() const {
// computes precision upon first call
// returns -1.0 if timer system call fails.
static double prec = compute_precision();
return prec;
}
CGAL_INLINE_FUNCTION
double Timer::max BOOST_PREVENT_MACRO_SUBSTITUTION () const {
// Depends on the operating system.
#ifdef CGAL__GETRUSAGE
return DBL_MAX;
#else // CGAL__GETRUSAGE //
return 2146.0;
#endif // CGAL__GETRUSAGE //
}
} //namespace CGAL
// EOF //
|