Go to the documentation of this file.
30 #ifndef __BASE_STATS_STORAGE_HH__
31 #define __BASE_STATS_STORAGE_HH__
274 "Bucket size (%f) must be greater than zero",
bucket_size);
277 "Bucket size (%f) does not divide range [%f:%f] into equal-" \
349 min_val = CounterLimits::max();
350 max_val = CounterLimits::min();
465 "There must be at least two buckets in a histogram");
520 data.cvec.resize(buckets);
761 MCounter::iterator it;
763 for (it =
cmap.begin(); it !=
cmap.end(); it++) {
764 data.cmap[(*it).first] = (*it).second;
783 #endif // __BASE_STATS_STORAGE_HH__
void growUp()
Given a bucket size B, and a range of values [0, N], this function doubles the bucket size to double ...
Tick last
The tick that current last changed.
AvgStor(Info *info)
Build and initializes this stat storage.
SampleStor(Info *info)
Create and initialize this storage.
void reset(Info *info)
Reset stat value to default.
void dec(Counter val)
Deccrement the current count by the provided value, calls set.
bool zero() const
Return true if no samples have been added.
void prepare(Info *info)
Prepare stat data for dumping or serialization.
Data structure of sparse histogram.
The parameters for a distribution stat.
Counter min
The minimum value to track.
Templatized storage and interface to a per-tick average stat.
VCounter cvec
Counter for each bucket.
Tick lastReset
The tick of the last reset.
Templatized storage and interface for a histogram stat.
size_type buckets
The number of buckets.
Result result() const
Return the current average.
size_type size() const
Return the number of buckets in this distribution.
void reset(Info *info)
Reset stat value to default.
Counter min_val
The smallest value sampled.
size_type size() const
Return the number of entries in this stat, 1.
The parameters for a distribution stat.
Counter max_bucket
Lower bound of the last bucket's range.
uint64_t Tick
Tick count type.
void prepare(Info *info, DistData &data)
Params(Counter _min, Counter _max, Counter _bucket_size)
Counter samples
The number of samples.
AvgSampleStor(Info *info)
Create and initialize this storage.
Counter samples
Counter for number of samples.
void growDown()
Given a bucket size B, and a range of values [0, N], this function doubles the bucket size to double ...
std::map< Counter, int > MCounter
map of counters
Counter max
The maximum value to track.
Counter value() const
Return the current count.
Counter min_track
The minimum value to track.
Counter sum
Current total.
Params(size_type _buckets)
Counter squares
The sum of squares.
Counter logs
The sum of logarithm of each sample, used to compute geometric mean.
Templatized storage and interface for a distribution stat.
void prepare(Info *info, DistData &data)
Counter min_bucket
Lower bound of the first bucket's range.
const StorageParams * storageParams
Counter squares
The sum of squares.
void reset(Info *info)
Reset stat value to default.
Counter bucket_size
The number of entries in each bucket.
StatStor(Info *info)
Builds this storage element and calls the base constructor of the datatype.
Counter samples
The number of samples.
The parameters for a distribution stat.
void sample(Counter val, int number)
Add a value to the distribution for the given number of times.
MCounter cmap
Counter for each bucket.
Counter squares
The sum of squares.
void prepare(Info *info, DistData &data)
bool zero() const
Returns true if any calls to sample have been made.
Counter max_track
The maximum value to track.
Counter squares
Current sum of squares.
Counter sum
The current sum.
Templatized storage and interface for a sparse histogram stat.
void reset(Info *info)
Reset stat value to default.
VCounter cvec
Counter for each bucket.
The parameters for a sparse histogram stat.
Templatized storage for distribution that calculates per tick mean and variance.
Counter current
The current count.
size_type size() const
Return the number of entries, in this case 1.
virtual ~StorageParams()=default
Templatized storage and interface for a distribution that calculates mean and variance.
Counter max_val
The largest value sampled.
void dec(Counter val)
Decrement the stat by the given value.
void reset(Info *info)
Reset stat value to default.
SparseHistStor(Info *info)
Counter bucket_size
The number of entries in each bucket.
double Result
All results are doubles.
Counter underflow
The number of values sampled less than min.
void inc(Counter val)
Increment the stat by the given value.
Result total
The total count for all tick.
double Counter
All counters are of 64-bit values.
#define warn_if(cond,...)
Conditional warning macro that checks the supplied condition and only prints a warning if the conditi...
bool zero() const
Returns true if any calls to sample have been made.
Templatized storage and interface for a simple scalar stat.
void inc(Counter val)
Increment the current count by the provided value, calls set.
Counter data
The statistic value.
void add(HistStor *other)
Adds the contents of the given storage to this storage.
Result result() const
Return the value of this stat as a result type.
void sample(Counter val, int number)
Add a value to the distribution for the given number of times.
bool zero() const
Returns true if any calls to sample have been made.
void prepare(Info *info)
Prepare stat data for dumping or serialization.
Counter sum
The current sum.
void growOut()
Given a bucket size B, and a range of values [M, N], where M < 0, this function doubles the bucket si...
Counter sum
The current sum.
void set(Counter val)
The the stat to the given value.
Tick curTick()
The universal simulation clock.
size_type size() const
Return the number of buckets in this distribution.
Counter value() const
Return the value of this stat as its base type.
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
void prepare(Info *info, DistData &data)
size_type size() const
Return the number of buckets in this distribution.
void prepare(Info *info, SparseHistData &data)
void sample(Counter val, int number)
Add a value to the distribution for the given number of times.
void reset(Info *info)
Reset stat value to default.
void set(Counter val)
Set the current count to the one provided, update the total and last set values.
void reset(Info *info)
Reset stat value to default.
void sample(Counter val, int number)
Add a value the given number of times to this running average.
Counter bucket_size
The number of entries in each bucket.
bool zero() const
Return true if no samples have been added.
size_type buckets
The number of buckets.
Counter samples
The number of samples.
Counter overflow
The number of values sampled more than max.
void sample(Counter val, int number)
Add a value to the distribution for the given number of times.
Generated on Tue Mar 23 2021 19:41:24 for gem5 by doxygen 1.8.17