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