2 //=============================================================================
6 * Utility Stats class that maintains the readings.
8 * @author Pradeep Gore <pradeep@cs.wustl.edu>
10 //=============================================================================
14 #include "ace/OS_NS_time.h"
15 #include "ace/Singleton.h"
16 #include "tao/orbconf.h"
17 #include "tao/debug.h"
18 #include "ace/High_Res_Timer.h"
23 * @brief maintains readings recorded by tasks.
29 ACE_hrtime_t base_time_
;
32 typedef ACE_Singleton
<Base_Time
, TAO_SYNCH_MUTEX
> BASE_TIME
;
37 * @brief maintains readings recorded by tasks.
43 Task_Stats (size_t max_samples
);
51 /// Set the base time value.
52 void base_time (ACE_hrtime_t time
);
54 /// Set the end time value.
55 void end_time (ACE_hrtime_t time
);
58 int sample (ACE_UINT64 inv_start_time
, ACE_UINT64 inv_end_time
);
60 void dump_samples (const ACE_TCHAR
*file_name
, const ACE_TCHAR
*msg
,
61 ACE_High_Res_Timer::global_scale_factor_type scale_factor
);
63 void dump_latency_stats (ACE_TCHAR
*out_msg
,
64 ACE_High_Res_Timer::global_scale_factor_type sf
);
66 /// Base and end times
67 ACE_hrtime_t base_time_
;
68 ACE_hrtime_t end_time_
;
70 /// The maximum number of samples
71 ACE_UINT32 max_samples_
;
73 /// The number of samples
74 ACE_UINT32 samples_count_
;
76 /// The samples : the time of invocation. and the recorded exec. time .
77 ACE_UINT64
*time_inv_
;
78 ACE_UINT64
*time_exec_
;
81 ACE_UINT64 exec_time_min_
;
83 /// The number of the sample that had the minimum value
84 ACE_UINT32 exec_time_min_at_
;
87 ACE_UINT64 exec_time_max_
;
89 /// The number of the sample that had the maximum value
90 ACE_UINT32 exec_time_max_at_
;
92 /// The sum of all the values
95 /// The sum of the square of all the values
99 #if defined (__ACE_INLINE__)
100 #include "Task_Stats.inl"
101 #endif /* __ACE_INLINE__ */
103 #endif /* TASK_STATS_H */