source: Sophya/trunk/SophyaLib/SysTools/resusage.h@ 2213

Last change on this file since 2213 was 2212, checked in by ansari, 23 years ago

Mise a jour de la documentation SysTools, Reza 15/10/2002

File size: 4.2 KB
Line 
1// This may look like C code, but it is really -*- C++ -*-
2// permet d'obtenir des informations sur les ressources utilisees
3// R. Ansari - Juillet 2002
4// LAL (Orsay) / IN2P3-CNRS DAPNIA/SPP (Saclay) / CEA
5
6#ifndef RESUSAGE_H_SEEN
7#define RESUSAGE_H_SEEN
8
9#include "machdefs.h"
10#include <iostream.h>
11
12namespace SOPHYA {
13
14//! Acces to nformation about resource usage (memory, CPU, ...)
15
16class ResourceUsage
17{
18public:
19 ResourceUsage();
20 ~ResourceUsage();
21
22 int Update();
23
24 // Memory usage in kilo-bytes
25 // NOTE: getDataSize() getStackSize() retournent des valeurs bizarres
26 //! Returns the current memory (Resident) size (in kilo-bytes)
27 inline uint_8 getMemorySize() { return cur_rss; }
28 //! Returns the maximum allowed memory size: Min( \c MaxResidentSize , \c MaxDataSize ))
29 inline uint_8 getMaxMemorySize()
30 { return((getMaxResidentSize()<getMaxDataSize()) ?
31 getMaxResidentSize() :getMaxDataSize() ); }
32 //! Returns the increase in memory usage since the previous call to \b Update()
33 inline uint_8 getDeltaMemorySize() { return delta_rss; }
34
35 //! Returns the maximum allowd data segment size (in kilo-bytes)
36 inline uint_8 getMaxDataSize() { return((max_datasz>0)?max_datasz:1024); }
37 //! Returns the current data segment size (in kilo-bytes)
38 inline uint_8 getDataSize() { return cur_datasz; }
39 //! Returns the maximum allowed resident size (in kilo-bytes)
40 inline uint_8 getMaxResidentSize() { return((max_rss>0)?max_rss:1024); }
41 //! Returns the current resident memory size (in kilo-bytes)
42 inline uint_8 getResidentSize() { return cur_rss; }
43 //! Returns the maximum allowed stack size (in kilo-bytes)
44 inline uint_8 getMaxStackSize() { return max_stack; }
45 //! Returns the current stack size (in kilo-bytes)
46 inline uint_8 getStackSize() { return cur_stack; }
47
48
49 // Time in milli-second
50 //! Returns the total CPU time used (in milli-second)
51 inline uint_8 getCPUTime() { return cur_tottm; }
52 //! Returns the total elapsed time (in milli-second)
53 inline uint_8 getElapsedTime() { return elapsed_time; }
54 //! Returns the average load ( CPU time / elapsed time)
55 inline double getAverageCPULoad()
56 { return ((elapsed_time>1) ? (double)cur_tottm/(double)elapsed_time: 1.);}
57
58 //! Returns the CPU time used since the previous call to \b Update() (in milli-second)
59 inline uint_8 getDeltaCPUTime() { return delta_tottm; }
60 //! Returns the elapsed time since the previous call to \b Update() (in milli-second)
61 inline uint_8 getDeltaElapsedTime() { return delta_elapsed_time; }
62 //! Returns the CPU load since the previous call to \b Update()
63 inline double getCPULoad()
64 { return ((delta_elapsed_time>1) ? (double)delta_tottm/(double)delta_elapsed_time: 1.);}
65
66
67 //! Returns the total CPU time (in milli-second)
68 inline uint_8 getTotalCPUTime() { return cur_tottm; }
69 //! Returns the CPU time in user mode (in milli-second)
70 inline uint_8 getUserCPUTime() { return cur_usrtm; }
71 //! Returns the CPU time in system mode (in milli-second)
72 inline uint_8 getSysCPUTime() { return cur_systm; }
73
74
75 void Print(ostream& os, int lp=0, bool upd=true);
76 //! Alias for the \b Print() method.
77 inline void print(ostream& os, int lp=0, bool upd=true){ Print(os,lp,upd); }
78
79protected:
80 uint_8 max_datasz; // Max data segment size (KBytes)
81 uint_8 max_rss; // Max resident size
82 uint_8 max_stack; // Max stack size
83
84 uint_8 cur_datasz; // Current data segment size
85 uint_8 cur_rss; // Current resident size
86 uint_8 cur_stack; // Current stack size
87
88 uint_8 cur_tottm; // Current total CPU-Time - in milli-second
89 uint_8 cur_usrtm; // Current user CPU-Time - in milli-second
90 uint_8 cur_systm; // Current system CPU-Time - in milli-second
91 uint_8 elapsed_time; // Elapsed time - in milli-second
92 uint_8 t0_time; // time T0 in seconds
93
94 // Delta_values : difference since last call to Update()
95 uint_8 delta_rss; // Max resident size
96 uint_8 delta_tottm; // Delta total CPU-Time - in milli-second
97
98 uint_8 delta_elapsed_time; // Elapsed time - in milli-second
99
100};
101
102//! Prints the resource usage information on the output stream
103inline ostream& operator << (ostream& os, ResourceUsage& ru)
104{ ru.Print(os,0,true); return(os); }
105
106} // namespace SOPHYA
107
108#endif
109
Note: See TracBrowser for help on using the repository browser.