Crates.io | rustics |
lib.rs | rustics |
version | 1.0.0 |
source | src |
created_at | 2023-09-28 06:30:19.926846 |
updated_at | 2024-11-09 03:38:56.41017 |
description | simple statistic library for performance analysis |
homepage | |
repository | https://github.com/jbertoni/Rustics |
max_upload_size | |
id | 985603 |
size | 545,177 |
A minimal statistics library for performance monitoring
Rustics implements a simple set of statistics structs intended primarily for measuring performance parameters. The struct implementations compute various statistical characterizations of the data, such as the mean and variance. The trait Rustics defines the common interface for all statistical types.
Most modules have sample code in their documentation, and many testing modules contain example functions called "sample_usage",
At this time, statistics can be gathered for i64 values, time periods (also of type i64), and f64 samples. Statistics can gathered collected as a running total of all samples recorded, or as a window covering the last N events.
The structs for time samples require a timer implementation. See the time module for information on timers and to see some sample implementations.
In addition to the more detailed statistics types, the library supports a simple counter for which no other statistics are generated. This can be useful for counting events, for example.
This library also implements a form of hierarchical statistics. The hierarchical statistics combine a set of Rustics instances into a single Rustics instance. This summation can allow keeping historical data at a lower storage cost, and can reduce floating-point loss of precision. See the hier.rs file and documentation for more information.
Rustics also implements sets that contain Rustics instances. All the
instances in a set can be printed via the print() method of the set, and
other functions are provided, as well. Rustics provides one set type that
contains Rustics instances as Arc<Mutex
Sets are recursive: a set can have a set as a member. All the Rustics instances in a set hierarchy can be printed with a single method call, and the contained Rustics instances can be cleared with a single method, as well.
The set implementation automatically creates hierarchical titles for Rustics instances. For example, if a user has a set named "Network Statistics" and that set contains a Rustics instance named "Packet Latency", the title printed for that instance will be "Network Statistics ==> Packet Latency".