|
MASA-Core
|
00001 /******************************************************************************* 00002 * 00003 * Copyright (c) 2010-2015 Edans Sandes 00004 * 00005 * This file is part of MASA-Core. 00006 * 00007 * MASA-Core is free software: you can redistribute it and/or modify 00008 * it under the terms of the GNU General Public License as published by 00009 * the Free Software Foundation, either version 3 of the License, or 00010 * (at your option) any later version. 00011 * 00012 * MASA-Core is distributed in the hope that it will be useful, 00013 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00014 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00015 * GNU General Public License for more details. 00016 * 00017 * You should have received a copy of the GNU General Public License 00018 * along with MASA-Core. If not, see <http://www.gnu.org/licenses/>. 00019 * 00020 ******************************************************************************/ 00021 00022 #ifndef _TIMER_HPP 00023 #define _TIMER_HPP 00024 00025 #include <vector> 00026 #include <map> 00027 #include <string> 00028 #include <stdio.h> 00029 using namespace std; 00030 #include <sys/time.h> 00031 00032 00033 class Timer { 00034 public: 00035 Timer(); 00036 virtual ~Timer(); 00037 00038 void init(); 00039 int createEvent(string name); 00040 float eventRecord(int event); 00041 float printStatistics(FILE* file=stdout); 00042 float totalTime(); 00043 bool intervalElapsed ( float interval ); 00044 static float getGlobalTime(); 00045 private: 00046 struct stat_t { 00047 string name; 00048 float sum; 00049 int count; 00050 struct timeval event; 00051 }; 00052 00053 bool hasEvent; 00054 timeval previousEvent; 00055 timeval repeatedEvent; 00056 timeval intervalEvent; 00057 timeval startEvent; 00058 static timeval staticEvent; 00059 static bool hasStaticEvent; 00060 00061 vector<stat_t> stats; 00062 00063 static float getElapsedTime(timeval *end_time, timeval *start_time); 00064 }; 00065 00066 #endif /* _TIMER_HPP */ 00067
1.7.6.1