2014 Eurobot fork
Dependencies: mbed-rtos mbed QEI
tvmet/util/Timer.h
- Committer:
- madcowswe
- Date:
- 2013-04-06
- Revision:
- 15:9c5aaeda36dc
File content as of revision 15:9c5aaeda36dc:
/* * Tiny Vector Matrix Library * Dense Vector Matrix Libary of Tiny size using Expression Templates * * Copyright (C) 2001 - 2007 Olaf Petzold <opetzold@users.sourceforge.net> * * This library is free software; 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 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * * $Id: Timer.h,v 1.9 2007-06-23 15:58:59 opetzold Exp $ */ #ifndef TVMET_UTIL_TIMER_H #define TVMET_UTIL_TIMER_H #if defined(TVMET_HAVE_SYS_TIME_H) && defined(TVMET_HAVE_UNISTD_H) # include <sys/time.h> # include <sys/resource.h> # include <unistd.h> #else # include <ctime> #endif namespace tvmet { namespace util { /** \class Timer Timer.h "tvmet/util/Timer.h" \brief A quick& dirty portable timer, measures elapsed time. It is recommended that implementations measure wall clock rather than CPU time since the intended use is performance measurement on systems where total elapsed time is more important than just process or CPU time. The accuracy of timings depends on the accuracy of timing information provided by the underlying platform, and this varies from platform to platform. */ class Timer { Timer(const Timer&); Timer& operator=(const Timer&); public: // types typedef double time_t; public: /** starts the timer immediatly. */ Timer() { m_start_time = getTime(); } /** restarts the timer */ void restart() { m_start_time = getTime(); } /** return elapsed time in seconds */ time_t elapsed() const { return (getTime() - m_start_time); } private: time_t getTime() const { #if defined(TVMET_HAVE_SYS_TIME_H) && defined(TVMET_HAVE_UNISTD_H) getrusage(RUSAGE_SELF, &m_rusage); time_t sec = m_rusage.ru_utime.tv_sec; // user, no system time time_t usec = m_rusage.ru_utime.tv_usec; // user, no system time return sec + usec/1e6; #else return static_cast<time_t>(std::clock()) / static_cast<time_t>(CLOCKS_PER_SEC); #endif } private: #if defined(TVMET_HAVE_SYS_TIME_H) && defined(TVMET_HAVE_UNISTD_H) mutable struct rusage m_rusage; #endif time_t m_start_time; }; } // namespace util } // namespace tvmet #endif // TVMET_UTIL_TIMER_H // Local Variables: // mode:C++ // tab-width:8 // End: