MASA-Core
Timer.hpp
Go to the documentation of this file.
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