// 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$ // SPDX-License-Identifier: LGPL-3.0+ // // // Author(s) : Lutz Kettner // Matthias Baesken #ifndef CGAL_REAL_TIMER_H #define CGAL_REAL_TIMER_H 1 #include #include // For the numerical limits #include namespace CGAL { // SECTION: A Timer Measuring Real-Time // ======================================================================== // // DEFINITION // // A timer `t' of type Real_timer is an object with a state. It is either // running or it is stopped. The state is controlled with `t.start()' // and `t.stop()'. The timer counts the time elapsed since its creation // or last reset. It counts only the time where it is in the running // state. The time information is given in seconds. class CGAL_EXPORT Real_timer { private: double elapsed; double started; int interv; bool running; #ifdef CGAL_HEADER_ONLY static bool& get_static_realtimer_m_failed() { static bool m_failed = false; return m_failed; } #else // CGAL_HEADER_ONLY static bool m_failed; static bool& get_static_realtimer_m_failed() { return Real_timer::m_failed; } #endif // CGAL_HEADER_ONLY double get_real_time() const; // in seconds double compute_precision() const; // in seconds public: Real_timer() : elapsed(0.0), started(0.0), interv(0), running(false) {} void start(); void stop (); void reset(); bool is_running() const { return running; } double time() const; int intervals() const { return interv; } double precision() const; // Returns timer precison. Computes it dynamically at first call. // Returns -1.0 if timer system call fails, which, for a proper coded // test towards precision leads to an immediate stop of an otherwise // infinite loop (fixed tolerance * total time >= precision). double max BOOST_PREVENT_MACRO_SUBSTITUTION () const { return DBL_MAX; } }; // ----------------------------------------------------------------------- // Member functions for Real_timer // =========================== inline void Real_timer::start() { CGAL_precondition( ! running); started = get_real_time(); running = true; ++ interv; } inline void Real_timer::stop() { CGAL_precondition( running); double t = get_real_time(); elapsed += (t - started); started = 0.0; running = false; } inline void Real_timer::reset() { interv = 0; elapsed = 0.0; if (running) { started = get_real_time(); ++ interv; } else { started = 0.0; } } inline double Real_timer::time() const { if (running) { double t = get_real_time(); return elapsed + (t - started); } return elapsed; } } //namespace CGAL #ifdef CGAL_HEADER_ONLY #include #endif // CGAL_HEADER_ONLY #endif // CGAL_REAL_TIMER_H // // EOF //