A class to compute statistics about quantities of interest. More...
#include <sot/talos_balance/utils/statistics.hh>
Classes | |
struct | QuantityData |
Public Member Functions | |
Statistics () | |
~Statistics () | |
long double | get_average (std::string name) |
long double | get_last (std::string name) |
long double | get_max (std::string name) |
long double | get_min (std::string name) |
long double | get_total (std::string name) |
bool | quantity_exists (std::string name) |
void | report (std::string name, int precision=2, std::ostream &output=std::cout) |
void | report_all (int precision=2, std::ostream &output=std::cout) |
void | reset (std::string name) |
void | reset_all () |
void | store (std::string name, const double &value) |
void | turn_off () |
void | turn_on () |
Protected Attributes | |
bool | active |
std::map< std::string, QuantityData > * | records_of |
A class to compute statistics about quantities of interest.
The Statistics class can be used to keep track of the minimum, maximum, average of quantities of interest.
To report the results just call:
Thou can also provide an additional std::ostream& parameter to report() to redirect the logging on a different output. Also, you can use the get_total/min/max/average() methods to get the individual numeric data, without all the details of the logging. You can also extend Statistics to implement your own logging syntax.
To report all the measurements:
Same as above, you can redirect the output by providing a std::ostream& parameter.
Definition at line 66 of file statistics.hh.
Statistics | ( | ) |
Constructor
Definition at line 31 of file statistics.cpp.
~Statistics | ( | ) |
Destructor
Definition at line 35 of file statistics.cpp.
long double get_average | ( | std::string | name | ) |
Returns average execution of a certain quantity
Definition at line 148 of file statistics.cpp.
long double get_last | ( | std::string | name | ) |
Return last measurement of a certain quantity
Definition at line 178 of file statistics.cpp.
long double get_max | ( | std::string | name | ) |
Returns maximum execution of a certain quantity
Definition at line 168 of file statistics.cpp.
long double get_min | ( | std::string | name | ) |
Returns minimum execution of a certain quantity
Definition at line 158 of file statistics.cpp.
long double get_total | ( | std::string | name | ) |
Returns total execution of a certain quantity
Definition at line 138 of file statistics.cpp.
bool quantity_exists | ( | std::string | name | ) |
Tells if a quantity with a certain name exists
Definition at line 37 of file statistics.cpp.
void report | ( | std::string | name, |
int | precision = 2 , |
||
std::ostream & | output = std::cout |
||
) |
Dump the data of a certain quantity record
Definition at line 109 of file statistics.cpp.
void report_all | ( | int | precision = 2 , |
std::ostream & | output = std::cout |
||
) |
Dump the data of all the quantity records
Definition at line 72 of file statistics.cpp.
void reset | ( | std::string | name | ) |
Reset a certain quantity record
Definition at line 83 of file statistics.cpp.
void reset_all | ( | ) |
Resets all the quantity records
Definition at line 62 of file statistics.cpp.
void store | ( | std::string | name, |
const double & | value | ||
) |
Record the value of the specified quantity
Definition at line 41 of file statistics.cpp.
void turn_off | ( | ) |
Turn off statistics, all the Statistics::* methods return without doing anything after this method is called.
Definition at line 104 of file statistics.cpp.
void turn_on | ( | ) |
Turn on statistics, restore operativity after a turn_off().
Definition at line 99 of file statistics.cpp.
|
protected |
Flag to hold the statistics status
Definition at line 137 of file statistics.hh.
|
protected |
Pointer to the dynamic structure which holds the collection of quantity data
Definition at line 141 of file statistics.hh.