summaryrefslogtreecommitdiffstats
path: root/time/akg_benchmark.cc
blob: 6bb0c8d5d4a13ebc48ebc5a83e74ec62e25874e5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
/*
* This file is part of rasdaman community.
*
* Rasdaman community is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Rasdaman community 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with rasdaman community.  If not, see <http://www.gnu.org/licenses/>.
*
* Copyright 2003, 2004, 2005, 2006, 2007, 2008, 2009 Peter Baumann /
rasdaman GmbH.
*
* For more information please see <http://www.rasdaman.org>
* or contact Peter Baumann via <baumann@rasdaman.com>.
*/

/*************************************************************************
 *
 *
 * PURPOSE:
 *   
 *    
 *
 * COMMENTS:
 *   none
 *
 ***********************************************************************/

#include "akgtime.hh"
#include<iomanip>

using namespace akg;

    
BenchmarkTimer::BenchmarkTimer(const char *lText, bool highPrecision) throw()
  {
    text = (char*)lText;
    
    precHigh = highPrecision;
   }
BenchmarkTimer::~BenchmarkTimer() throw()
  {
   }

void BenchmarkTimer::reset() throw()
  {
    tvStart.tv_sec  = 0;
    tvStart.tv_usec = 0;
    tvEnd.tv_sec    = 0;
    tvEnd.tv_usec   = 0;
   }
   
void BenchmarkTimer::start() throw()
  { 
    gettimeofday(&tvStart,NULL);
   }

void BenchmarkTimer::stop() throw()
  {
    gettimeofday(&tvEnd,NULL);
    timeval_subtract(&tvResult,&tvEnd,&tvStart);
   }

void BenchmarkTimer::setPrecision(bool high) throw()
  {
    precHigh = high;
   }

bool BenchmarkTimer::getPrecision() const throw()
  {
    return precHigh;
   }
      
int BenchmarkTimer::timeval_subtract(timeval *lResult,timeval *x,timeval *y) throw()
 {
       /* Perform the carry for the later subtraction by updating Y. */
       if (x->tv_usec < y->tv_usec) {
         int nsec = (y->tv_usec - x->tv_usec) / 1000000 + 1;
         y->tv_usec -= 1000000 * nsec;
         y->tv_sec += nsec;
       }
       if (x->tv_usec - y->tv_usec > 1000000) {
         int nsec = (x->tv_usec - y->tv_usec) / 1000000;
         y->tv_usec += 1000000 * nsec;
         y->tv_sec -= nsec;
       }
     
       /* Compute the time remaining to wait.
          `tv_usec' is certainly positive. */
       lResult->tv_sec = x->tv_sec - y->tv_sec;
       lResult->tv_usec = (x->tv_usec - y->tv_usec);
     
       /* Return 1 if result is negative. */
       return x->tv_sec < y->tv_sec;
  }


std::ostream& akg::operator<<(std::ostream &os, BenchmarkTimer &bm)
  {
    if(bm.precHigh == true)
      { 
        unsigned int msec = bm.tvResult.tv_sec*1000 + bm.tvResult.tv_usec / 1000;
        unsigned int usec = bm.tvResult.tv_usec % 1000;
    
        os<<bm.text<<"="<<msec<<'.'<<std::setfill('0')<<std::setw(3)<<usec<<"ms";    
       }
    else
      {
      	unsigned int msec = bm.tvResult.tv_usec / 1000;
        unsigned int sec  = bm.tvResult.tv_sec;

        os<<bm.text<<"="<<sec<<'.'<<std::setfill('0')<<std::setw(3)<<msec<<"s";       
       }   
    return os;
   }