#include <Stats.h>
Collaboration diagram for ACE_Stats:

| Public Methods | |
| ACE_Stats (void) | |
| Default constructor. More... | |
| int | sample (const ACE_INT32 value) | 
| Provide a new sample. Returns 0 on success, -1 if it fails due to running out of memory, or to rolling over of the sample count. More... | |
| ACE_UINT32 | samples (void) const | 
| Access the number of samples provided so far. More... | |
| ACE_INT32 | min_value (void) const | 
| Value of the minimum sample provided so far. More... | |
| ACE_INT32 | max_value (void) const | 
| Value of the maximum sample provided so far. More... | |
| void | mean (ACE_Stats_Value &mean, const ACE_UINT32 scale_factor=1) | 
| Access the mean of all samples provided so far. More... | |
| int | std_dev (ACE_Stats_Value &std_dev, const ACE_UINT32 scale_factor=1) | 
| Access the standard deviation, whole and fractional parts. See description of <mean> method for argument descriptions. More... | |
| int | print_summary (const u_int precision, const ACE_UINT32 scale_factor=1, FILE *=stdout) const | 
| Print summary statistics. More... | |
| void | reset (void) | 
| Initialize internal state. More... | |
| void | dump (void) const | 
| Print summary statistics to stdout. More... | |
| Static Public Methods | |
| void | quotient (const ACE_UINT64 dividend, const ACE_UINT32 divisor, ACE_Stats_Value "ient) | 
| Utility division function, for ACE_UINT64 dividend. More... | |
| void | quotient (const ACE_Stats_Value ÷nd, const ACE_UINT32 divisor, ACE_Stats_Value "ient) | 
| Utility division function, for ACE_Stats_Value dividend. More... | |
| void | square_root (const ACE_UINT64 n, ACE_Stats_Value &square_root) | 
| Sqrt function, which uses an oversimplified version of Newton's method. More... | |
| Private Attributes | |
| u_int | overflow_ | 
| Internal indication of whether there has been overflow. Contains the errno corresponding to the cause of overflow. More... | |
| ACE_UINT32 | number_of_samples_ | 
| Number of samples. More... | |
| ACE_INT32 | min_ | 
| Minimum sample value. More... | |
| ACE_INT32 | max_ | 
| Maximum sample value. More... | |
| ACE_Unbounded_Queue< ACE_INT32 > | samples_ | 
| The samples. More... | |
Simple statistical analysis package. Prominent features are:
 * ACE_Stats stats;
 * for (u_int i = 0; i < n; ++i)
 * {
 * const ACE_UINT32 sample = ...;
 * stats.sample (sample);
 * }
 * stats.print_summary (3);
 * 
| 
 | 
| Default constructor. 
 | 
| 
 | 
| Print summary statistics to stdout. 
 | 
| 
 | 
| Value of the maximum sample provided so far. 
 | 
| 
 | ||||||||||||
| Access the mean of all samples provided so far. The fractional part is to the specified number of digits. E.g., 3 fractional digits specifies that the fractional part is in thousandths. | 
| 
 | 
| Value of the minimum sample provided so far. 
 | 
| 
 | ||||||||||||||||
| Print summary statistics. If scale_factor is not 1, then the results are divided by it, i.e., each of the samples is scaled down by it. If internal overflow is reached with the specified scale factor, it successively tries to reduce it. Returns -1 if there is overflow even with a 0 scale factor. | 
| 
 | ||||||||||||||||
| Utility division function, for ACE_Stats_Value dividend. 
 | 
| 
 | ||||||||||||||||
| Utility division function, for ACE_UINT64 dividend. 
 | 
| 
 | 
| Initialize internal state. 
 | 
| 
 | 
| Provide a new sample. Returns 0 on success, -1 if it fails due to running out of memory, or to rolling over of the sample count. 
 | 
| 
 | 
| Access the number of samples provided so far. 
 | 
| 
 | ||||||||||||
| Sqrt function, which uses an oversimplified version of Newton's method. It's not fast, but it doesn't require floating point support. | 
| 
 | ||||||||||||
| Access the standard deviation, whole and fractional parts. See description of <mean> method for argument descriptions. 
 | 
| 
 | 
| Maximum sample value. 
 | 
| 
 | 
| Minimum sample value. 
 | 
| 
 | 
| Number of samples. 
 | 
| 
 | 
| Internal indication of whether there has been overflow. Contains the errno corresponding to the cause of overflow. 
 | 
| 
 | 
| The samples. 
 | 
 1.2.13.1 written by Dimitri van Heesch,
 © 1997-2001
1.2.13.1 written by Dimitri van Heesch,
 © 1997-2001