Gaudi Framework, version v25r2
Home
Generated: Wed Jun 4 2014
Main Page
Related Pages
Modules
Namespaces
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Properties
Friends
Macros
Groups
Pages
.cern.ch
sw
Gaudi
releases
GAUDI
GAUDI_v25r2
GaudiAlg
src
components
TimerForSequencer.cpp
Go to the documentation of this file.
1
2
// local
3
#include "
TimerForSequencer.h
"
4
5
//-----------------------------------------------------------------------------
6
// Implementation file for class : TimerForSequencer
7
//
8
// 2013-04-21 : Chris Jones
9
//-----------------------------------------------------------------------------
10
11
double
TimerForSequencer::stop
()
12
{
13
double
cpuTime
= double(
System::cpuTime
(
System::microSec
) -
m_startCpu
);
14
double
lastTime
= double(
System::currentTime
(
System::microSec
) -
m_startClock
);
15
16
//== Change to normalized millisecond
17
cpuTime *=
m_factor
;
18
lastTime *=
m_factor
;
19
20
//== Update the counter
21
m_num
+= 1;
22
m_sum
+=
lastTime
;
23
m_sumCpu
+=
cpuTime
;
24
25
if
( 1 ==
m_num
)
26
{
27
m_min
=
lastTime
;
28
m_max
=
lastTime
;
29
}
30
else
31
{
32
if
( lastTime <
m_min
)
m_min
=
lastTime
;
33
if
( lastTime >
m_max
)
m_max
=
lastTime
;
34
}
35
m_lastTime
=
lastTime
;
36
m_lastCpu
=
cpuTime
;
37
return
lastTime
;
38
}
39
40
MsgStream
&
TimerForSequencer::fillStream
(
MsgStream
&
s
)
const
41
{
42
double
ave = 0.;
43
double
cpu
= 0.;
44
45
if
( 0 !=
m_num
)
46
{
47
ave =
m_sum
/
m_num
;
48
cpu =
m_sumCpu
/
m_num
;
49
}
50
51
return
s <<
m_name
.substr(0,
m_size
)
52
<<
format
(
"| %9.3f | %9.3f | %8.3f %9.1f | %7d | %9.3f |"
,
53
cpu, ave,
m_min
,
m_max
,
m_num
,
m_sum
* 0.001 );
54
}
55
56
std::string
TimerForSequencer::header
( std::string::size_type size )
57
{
58
if
( size < 21 ) size = 21;
59
const
std::string blank( size - 20,
' '
);
60
const
std::string
s
=
61
"Algorithm"
+ blank +
"(millisec) | <user> | <clock> |"
+
62
" min max | entries | total (s) |"
;
63
return
s
;
64
}
Generated at Wed Jun 4 2014 14:48:55 for Gaudi Framework, version v25r2 by
Doxygen
version 1.8.2 written by
Dimitri van Heesch
, © 1997-2004