StopWatch.hh

00001 /*===========================================================================*\
00002  *                                                                           *
00003  *                              OpenFlipper                                  *
00004  *      Copyright (C) 2001-2009 by Computer Graphics Group, RWTH Aachen      *
00005  *                           www.openflipper.org                             *
00006  *                                                                           *
00007  *---------------------------------------------------------------------------*
00008  *  This file is part of OpenFlipper.                                        *
00009  *                                                                           *
00010  *  OpenFlipper is free software: you can redistribute it and/or modify      *
00011  *  it under the terms of the GNU Lesser General Public License as           *
00012  *  published by the Free Software Foundation, either version 3 of           *
00013  *  the License, or (at your option) any later version with the              *
00014  *  following exceptions:                                                    *
00015  *                                                                           *
00016  *  If other files instantiate templates or use macros                       *
00017  *  or inline functions from this file, or you compile this file and         *
00018  *  link it with other files to produce an executable, this file does        *
00019  *  not by itself cause the resulting executable to be covered by the        *
00020  *  GNU Lesser General Public License. This exception does not however       *
00021  *  invalidate any other reasons why the executable file might be            *
00022  *  covered by the GNU Lesser General Public License.                        *
00023  *                                                                           *
00024  *  OpenFlipper is distributed in the hope that it will be useful,           *
00025  *  but WITHOUT ANY WARRANTY; without even the implied warranty of           *
00026  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the            *
00027  *  GNU Lesser General Public License for more details.                      *
00028  *                                                                           *
00029  *  You should have received a copy of the GNU LesserGeneral Public          *
00030  *  License along with OpenFlipper. If not,                                  *
00031  *  see <http://www.gnu.org/licenses/>.                                      *
00032  *                                                                           *
00033 \*===========================================================================*/
00034 
00035 /*===========================================================================*\
00036  *                                                                           *
00037  *   $Revision: 6743 $                                                       *
00038  *   $Author: moebius $                                                      *
00039  *   $Date: 2009-08-05 11:03:10 +0200 (Mi, 05. Aug 2009) $                   *
00040  *                                                                           *
00041 \*===========================================================================*/
00042 
00043 
00044 
00045 //=============================================================================
00046 //
00047 //  CLASS StopWatch
00048 //
00049 //=============================================================================
00050 
00051 
00052 #ifndef ACG_STOPWATCH_HH
00053 #define ACG_STOPWATCH_HH
00054 
00055 
00056 //== INCLUDES =================================================================
00057 
00058 
00059 #ifdef _WIN32
00060 
00061 #include <windows.h>
00062 
00063 #else // Linux
00064 
00065 #include <sys/time.h>
00066 
00067 #endif
00068 
00069 #include "../Config/ACGDefines.hh"
00070 
00071 
00072 //== NAMESPACES ===============================================================
00073 
00074 
00075 namespace ACG {
00076 
00077 
00078 //== CLASS DEFINITION =========================================================
00079 
00080 
00081 
00089 class ACGDLLEXPORT StopWatch
00090 {
00091 public:
00092 
00094   StopWatch() {
00095     #ifdef _WIN32
00096       QueryPerformanceFrequency(&freq_);
00097     #endif
00098   }
00099 
00101   ~StopWatch() {}
00102 
00104   void start() {
00105     #ifdef _WIN32
00106       QueryPerformanceCounter(&starttime_);
00107     #else
00108       starttime_ = current_time();
00109     #endif
00110   }
00111 
00113   double restart() {
00114     #ifdef _WIN32
00115       QueryPerformanceCounter(&endtime_);
00116     #else
00117       endtime_ = current_time();
00118     #endif
00119 
00120     double t = elapsed();
00121     start();
00122     return t;
00123   }
00124 
00126   double stop() {
00127     #ifdef _WIN32
00128       QueryPerformanceCounter(&endtime_);
00129     #else
00130       endtime_ = current_time();
00131     #endif
00132 
00133     return elapsed();
00134   }
00135 
00137   double elapsed() const {
00138     #ifdef _WIN32
00139       return (double)(endtime_.QuadPart - starttime_.QuadPart)
00140            / (double)freq_.QuadPart * 1000.0f;
00141     #else
00142       return ((endtime_.tv_sec  - starttime_.tv_sec )*1000.0 +
00143               (endtime_.tv_usec - starttime_.tv_usec)*0.001);
00144     #endif
00145   }
00146 
00147 
00148 private:
00149 
00150   #ifdef _WIN32
00151     LARGE_INTEGER starttime_, endtime_;
00152     LARGE_INTEGER freq_;
00153   #else // Linux
00154     timeval current_time() const {
00155       struct timeval tv;
00156       gettimeofday(&tv, 0);
00157       return tv;
00158     }
00159 
00160     timeval starttime_, endtime_;
00161   #endif
00162 
00163 };
00164 
00165 
00166 //=============================================================================
00167 } // namespace ACG
00168 //=============================================================================
00169 #endif // ACG_STOPWATCH_HH defined
00170 //=============================================================================
00171 

acg pic Project OpenFlipper, ©  Computer Graphics Group, RWTH Aachen. Documentation generated using doxygen .