Go to the documentation of this file.
58 #ifndef __BASE_STATISTICS_HH__
59 #define __BASE_STATISTICS_HH__
90 template <
class Stat,
class Base>
99 bool check()
const {
return s.check(); }
105 visitor.
visit(*
static_cast<Base *
>(
this));
107 bool zero()
const {
return s.zero(); }
110 template <
class Stat>
121 template <
class Stat>
143 this->
s.result(rvec);
150 template <
class Stat>
157 template <
class Stat>
166 template <
class Stat>
206 bool zero()
const {
return true; }
216 template <
class Derived,
template <
class>
class InfoProxyType>
220 typedef InfoProxyType<Derived>
Info;
223 Derived &
self() {
return *
static_cast<Derived *
>(
this); }
277 const std::string &
name()
const {
return this->
info()->name; }
288 this->
info()->setSeparator(_sep);
293 return this->
info()->separatorString;
304 this->
info()->unit = _unit;
317 this->
info()->desc = _desc;
329 this->
info()->precision = _precision;
341 this->
info()->flags.set(_flags);
351 template <
class Stat>
355 this->
info()->prereq = prereq.info();
360 template <
class Derived,
template <
class>
class InfoProxyType>
364 typedef InfoProxyType<Derived>
Info;
368 const char *
desc =
nullptr)
385 Derived &
self = this->
self();
386 Info *
info =
self.info();
389 if (subn.size() <=
index)
390 subn.resize(
index + 1);
412 if (subd.size() <=
index)
413 subd.resize(
index + 1);
422 Derived &
self = this->
self();
425 size_t size =
self.size();
433 Derived &
self = this->
self();
436 size_t size =
self.size();
442 template <
class Derived,
template <
class>
class InfoProxyType>
446 typedef InfoProxyType<Derived>
Info;
461 Derived &
self = this->
self();
466 info->y_subnames[
i] = names[
i];
473 Derived &
self = this->
self();
476 assert(
index <
self.y);
477 info->y_subnames.resize(
self.y);
485 return this->
info()->y_subnames[
i];
500 template <
class Derived,
class Stor>
520 return reinterpret_cast<Storage *
>(storage);
532 return reinterpret_cast<const Storage *
>(storage);
545 const char *
desc =
nullptr)
574 template <
typename U>
582 template <
typename U>
590 template <
typename U>
641 template <
class T,
class Enabled=
void>
662 typename
std::enable_if_t<std::is_constructible<std::function<Result()>,
679 template <
class T,
class V>
694 template <
class Derived>
745 template <
class T,
class V>
776 template <
class Stat>
853 template <
typename U>
865 template <
typename U>
877 template <
typename U>
902 template <
class Derived,
class Stor>
937 assert(
s > 0 &&
"size must be positive!");
938 assert(!
storage &&
"already initialized");
956 vec[
i] =
data(
i)->value();
968 vec[
i] =
data(
i)->result();
1018 data(
i)->~Storage();
1019 delete []
reinterpret_cast<char *
>(
storage);
1030 Derived &
self = this->
self();
1044 return Proxy(this->
self(), index);
1048 template <
class Stat>
1059 typename Stat::Storage *
1066 const typename Stat::Storage *
1124 template <
class Derived,
class Stor>
1161 data(
i)->~Storage();
1162 delete []
reinterpret_cast<char *
>(
storage);
1168 assert(_x > 0 && _y > 0 &&
"sizes must be positive!");
1169 assert(!
storage &&
"already initialized");
1171 Derived &
self = this->
self();
1196 return Proxy(this->
self(), offset,
y);
1209 return data(0)->zero();
1268 template <
class Derived,
class Stor>
1288 return reinterpret_cast<Storage *
>(storage);
1298 return reinterpret_cast<const Storage *
>(storage);
1322 template <
typename U>
1358 template <
class Stat>
1361 template <
class Derived,
class Stor>
1392 assert(
s > 0 &&
"size must be positive!");
1393 assert(!
storage &&
"already initialized");
1420 data(
i)->~Storage();
1421 delete []
reinterpret_cast<char *
>(
storage);
1427 return Proxy(this->
self(), index);
1440 if (!
data(
i)->zero())
1462 template <
class Stat>
1491 template <
typename U>
1507 return data()->zero();
1548 virtual std::string
str()
const = 0;
1582 template <
class Stat>
1604 return proxy.result();
1677 std::string tmp =
"(";
1691 static std::string
str() {
return "+"; }
1697 static std::string
str() {
return "-"; }
1703 static std::string
str() {
return "*"; }
1709 static std::string
str() {
return "/"; }
1715 static std::string
str() {
return "%"; }
1721 static std::string
str() {
return "-"; }
1787 assert(lvec.size() > 0 && rvec.size() > 0);
1789 if (lvec.size() == 1 && rvec.size() == 1) {
1792 }
else if (lvec.size() == 1) {
1797 }
else if (rvec.size() == 1) {
1802 }
else if (rvec.size() == lvec.size()) {
1823 assert(lvec.size() > 0 && rvec.size() > 0);
1824 assert(lvec.size() == rvec.size() ||
1825 lvec.size() == 1 || rvec.size() == 1);
1828 if (lvec.size() == rvec.size() && lvec.size() > 1) {
1833 return op(lsum, rsum);
1851 }
else if (
rs == 1) {
1854 assert(ls ==
rs &&
"Node vector sizes are not equal");
1950 const char *
desc =
nullptr)
1977 const char *
desc =
nullptr)
1997 const char *
desc =
nullptr)
2022 const char *
desc =
nullptr)
2048 const char *
desc =
nullptr)
2074 const char *
desc =
nullptr)
2100 const char *
desc =
nullptr)
2118 return this->
self();
2136 const char *
desc =
nullptr)
2142 const char *
desc =
nullptr)
2158 return this->
self();
2182 const char *
desc =
nullptr)
2192 const char *
desc =
nullptr)
2221 const char *
desc =
nullptr)
2231 const char *
desc =
nullptr)
2254 const char *
desc =
nullptr)
2262 const char *
desc =
nullptr)
2282 return this->
self();
2301 const char *
desc =
nullptr)
2309 const char *
desc =
nullptr)
2326 return this->
self();
2345 const char *
desc =
nullptr)
2353 const char *
desc =
nullptr)
2370 return this->
self();
2374 template <
class Stat>
2389 this->
s.result(vec);
2395 std::string
str()
const {
return this->
s.str(); }
2398 template <
class Stat>
2409 template <
class Derived,
class Stor>
2463 template <
typename U>
2504 const char *
desc =
nullptr)
2511 const char *
desc =
nullptr)
2528 return this->
self();
2550 const char *
desc =
nullptr);
2553 const char *
desc =
nullptr);
2568 template<
typename T>
2627 std::string
str()
const;
2725 template <
class Stat>
2847 return Temp(std::make_shared<
BinaryNode<std::multiplies<Result> > >(
l,
r));
2859 return Temp(std::make_shared<
UnaryNode<std::negate<Result> > >(
l));
2862 template <
typename T>
2869 template <
typename T>
2879 return Temp(std::make_shared<
SumNode<std::plus<Result> > >(
val));
2929 #endif // __BASE_STATISTICS_HH__
DataWrap(Group *parent, const char *name, const Units::Base *unit, const char *desc)
Distribution(Group *parent, const char *name, const Units::Base *unit, const char *desc=nullptr)
ScalarProxy(Stat &s, off_type i)
Create and initialize this proxy, do not register it with the database.
const Storage * data() const
Retrieve a const pointer to the storage.
V(T::* MethodPointer)() const
void operator++()
Increment the stat by 1.
Histogram(Group *parent, const char *name, const Units::Base *unit, const char *desc=nullptr)
StandardDeviation(Group *parent=nullptr)
Construct and initialize this distribution.
Temp(unsigned short value)
Create a ConstNode.
Derived & scalar(T &value)
Vector2d(Group *parent=nullptr)
const VResult & result() const
Return the result vector of this subtree.
SparseHistogram(Group *parent, const char *name, const char *desc=nullptr)
Derived & method(T *obj, V(T::*method)() const)
Extended functor that calls the specified method of the provided object.
Result total() const
Return the total of the result vector.
VectorStandardDeviation(Group *parent, const char *name, const Units::Base *unit, const char *desc=nullptr)
SparseHistogram(Group *parent=nullptr)
Result total() const
Return the total of the result vector.
Proxy operator[](off_type index)
void operator++(int)
Increment the stat by 1.
void processResetQueue()
Process all the callbacks in the reset callbacks queue.
Vector2d(Group *parent, const char *name, const Units::Base *unit, const char *desc=nullptr)
VectorDistribution(Group *parent, const char *name, const char *desc=nullptr)
const VectorProxy & operator=(const VectorProxy &sp)
Temp operator+(Temp l, Temp r)
void operator=(const U &v)
Set the data value to the given value.
VectorDistBase(Group *parent, const char *name, const Units::Base *unit, const char *desc)
Templatized storage and interface to a per-tick average stat.
Result total() const override
Return the total of the result vector.
const Stat::Storage * data() const
InfoProxyType< Derived > Info
M5_ALIGNED(8) char storage[sizeof(Storage)]
The storage for this stat.
Result total() const
Return the total of the result vector.
ValueBase(Group *parent, const char *name, const Units::Base *unit, const char *desc)
Templatized storage and interface for a histogram stat.
AverageVector(Group *parent, const char *name, const char *desc=nullptr)
DistProxy(Stat &s, off_type i)
NodePtr getNodePtr() const
Makde gcc < 4.6.3 happy and explicitly get the underlying node.
Temp(unsigned int value)
Create a ConstNode.
ScalarInfoProxy(Stat &stat)
size_type size() const
Return the number of elements, always 1 for a scalar.
VectorAverageDeviation & init(size_type size)
Initialize storage for this distribution.
VectorAverageDeviation(Group *parent, const char *name, const Units::Base *unit, const char *desc=nullptr)
Implementation of a vector of stats.
Temp(double value)
Create a ConstNode.
StandardDeviation(Group *parent, const char *name, const char *desc=nullptr)
const Storage * data() const
Retrieve a const pointer to the storage.
size_type size() const
Return the number of nodes in the subtree starting at this node.
Value(Group *parent, const char *name, const Units::Base *unit, const char *desc=nullptr)
void prepare()
Prepare the stat for dumping.
Implementation of a scalar stat.
void registerDumpCallback(const std::function< void()> &callback)
Register a callback that should be called whenever statistics are about to be dumped.
DistProxy< Derived > Proxy
const std::string to_string(sc_enc enc)
The parameters for a distribution stat.
Temp(float value)
Create a ConstNode.
size_type size() const override
Return the number of nodes in the subtree starting at this node.
const ScalarProxy & operator=(const ScalarProxy &sp)
Set this proxy equal to the provided one.
Derived & ysubname(off_type index, const std::string &subname)
Derived & functor(const T &func)
Temp(const NodePtr &n)
Copy the given pointer to this class.
size_type size() const
Return the number of elements, always 1 for a scalar.
std::function< Result()> functor
size_type size() const
Return the number of entries in this stat.
void visit(Output &visitor)
Visitor entry for outputing statistics data.
size_type size() const
Return the number of entries in this stat.
Implementation of a sparse histogram stat.
VCounter cvec
Local storage for the entry values, used for printing.
Storage * data()
Retrieve the storage.
const VResult & result() const
Result total() const
Return the total of the result vector.
A proxy class to access the stat at a given index in a VectorBase stat.
void operator-=(const U &v)
Decrement the stat by the given value.
std::vector< std::string > y_subnames
Proxy operator[](off_type index)
Return a reference (ScalarProxy) to the stat at the given index.
void visit(Output &visitor)
Storage * data(off_type index)
Retrieve the storage.
Temp(signed char value)
Create a ConstNode.
Calculates the per tick mean and variance of the samples.
std::string str() const override
VectorDistInfoProxy< Derived > Info
Temp(signed long long value)
Create a ConstNode.
const VResult & result() const
Return the result vector of this subtree.
const FlagsType display
Print this stat.
const Storage * data(off_type index) const
Retrieve a const pointer to the storage.
Base class for formula statistic node.
A vector of scalar stats.
VectorProxy(const VectorProxy &sp)
Result result() const
Return the current value of this statas a result type.
This is a vector of AverageDeviation stats.
A vector of distributions.
VectorDistribution(Group *parent=nullptr)
virtual Result result() const =0
Proxy operator[](off_type index)
Templatized storage and interface for a distribution stat.
Storage * storage
The storage of this stat.
VectorStatNode(const VectorInfo *d)
Vector(Group *parent, const char *name, const Units::Base *unit, const char *desc=nullptr)
Counter value() const
Return the current value of this stat as its base type.
Temp(const Scalar &s)
Create a new ScalarStatNode.
void operator++(int)
Increment the stat by 1.
NodePtr node
Pointer to a Node object.
DataWrapVec(Group *parent=nullptr, const char *name=nullptr, const Units::Base *unit=UNIT_UNSPECIFIED, const char *desc=nullptr)
Derived & flags(Flags _flags)
Set the flags and marks this stat to print at the end of simulation.
virtual Result total() const =0
Return the total of the result vector.
VectorAverageDeviation(Group *parent, const char *name, const char *desc=nullptr)
DataWrapVec2d(Group *parent, const char *name, const Units::Base *unit, const char *desc)
Result total() const
Return the total of the result vector.
Derived & ysubnames(const char **names)
virtual Result total() const =0
AverageVector(Group *parent, const char *name, const Units::Base *unit, const char *desc=nullptr)
AverageDeviation(Group *parent, const char *name, const Units::Base *unit, const char *desc=nullptr)
Vector(Group *parent=nullptr)
size_type size() const
Return the number of nodes in the subtree starting at this node.
This is a simple scalar statistic, like a counter.
ScalarProxy< Stat > operator[](off_type index)
const Stat::Storage * data(off_type index) const
The parameters for a distribution stat.
Distribution(Group *parent, const char *name, const char *desc=nullptr)
virtual Counter value() const =0
Helper class to construct formula node trees.
virtual const VResult & result() const =0
Return the result vector of this subtree.
Storage * data()
Retrieve the storage.
Average(Group *parent=nullptr)
Counter value() const
Return the current value of this stat as its base type.
Temp(const AverageVector &s)
Derived & prereq(const Stat &prereq)
Set the prerequisite stat and marks this stat to print at the end of simulation.
VectorDistInfoProxy(Stat &stat)
Vector(Group *parent, const char *name, const char *desc=nullptr)
void setInfo(Group *parent, Info *info)
Set up an info class for this statistic.
ScalarStatNode(const ScalarInfo *d)
Temp(const ScalarProxy< Stat > &p)
Create a new ScalarProxyNode.
void(* Handler)()
Register reset and dump handlers.
const Info * resolve(const std::string &name)
Stat & stat
Pointer to the parent Vector.
VectorDistribution(Group *parent, const char *name, const Units::Base *unit, const char *desc=nullptr)
void registerResetCallback(const std::function< void()> &callback)
Register a callback that should be called whenever statistics are reset.
void operator--(int)
Decrement the stat by 1.
void reset()
Reset the stat to the default state.
virtual Result total() const =0
const std::string & setSeparator() const
Storage * data(off_type index)
M5_ALIGNED(8) char storage[sizeof(Storage)]
The storage of this stat.
DataWrap & operator=(const DataWrap &)=delete
Temp(signed long value)
Create a ConstNode.
bool zero() const
Return true if no samples have been added.
VectorStandardDeviation(Group *parent, const char *name, const char *desc=nullptr)
ConstVectorNode(const T &s)
Templatized storage and interface for a sparse histogram stat.
void reset()
Reset the stat to the default state.
Temp operator-(Temp l, Temp r)
const VResult & result() const
Return the result vector of this subtree.
bool check() const
Check that this stat has been set up properly and is ready for use.
virtual const VResult & result() const =0
const VResult & result() const override
Return the result vector of this subtree.
virtual std::string str() const =0
VectorProxy(Stat &s, off_type o, size_type l)
InfoProxyType< Derived > Info
AverageVector(Group *parent=nullptr)
Derived & subdesc(off_type index, const std::string &desc)
Set the subfield description for the given index and marks this stat to print at the end of simulatio...
Vector2dInfoProxy< Derived > Info
void result(VResult &vec) const
Copy the values to a local vector and return a reference to it.
SparseHistInfoProxy< Derived > Info
The parameters for a sparse histogram stat.
void operator++()
Increment the stat by 1.
Calculates the mean and variance of all the samples.
A proxy similar to the FunctorProxy, but allows calling a method of a bound object,...
Info * info()
Grab the information class for this statistic.
Templatized storage for distribution that calculates per tick mean and variance.
Temp(const Vector &s)
Create a new VectorStatNode.
BinaryNode(NodePtr &a, NodePtr &b)
Derived & setSeparator(const std::string &_sep)
Set the character(s) used between the name and vector number on vectors, dist, etc.
Average(Group *parent, const char *name, const Units::Base *unit, const char *desc=nullptr)
std::list< Info * > & statsList()
Storage * data()
Retrieve the storage.
Templatized storage and interface for a distribution that calculates mean and variance.
VectorProxy< Derived > Proxy
VectorStandardDeviation & init(size_type size)
Initialize storage for this distribution.
VectorStandardDeviation(Group *parent=nullptr)
virtual size_type size() const =0
std::vector< DistData > data
A simple distribution stat.
Derived & name(const std::string &name)
Set the name and marks this stat to print at the end of simulation.
Temp constantVector(T val)
AverageDeviation(Group *parent, const char *name, const char *desc=nullptr)
const std::string & name()
Derived & init(size_type size)
Set this vector to have the given size.
DistInfoProxy(Stat &stat)
const VResult & result() const
Return the result vector of this subtree.
const Storage * data() const
Retrieve a const pointer to the storage.
std::string ysubname(off_type i) const
const Info * info() const
virtual size_type size() const =0
Return the number of nodes in the subtree starting at this node.
void operator+=(const U &v)
Increment the stat by the given value.
Implementation of a distribution stat.
double Result
All results are doubles.
void operator+=(const U &v)
Increment the stat by the given value.
virtual void visit(const ScalarInfo &info)=0
ScalarBase(Group *parent=nullptr, const char *name=nullptr, const Units::Base *unit=UNIT_UNSPECIFIED, const char *desc=nullptr)
Scalar(Group *parent, const char *name, const char *desc=nullptr)
Temp operator/(Temp l, Temp r)
A stat that calculates the per tick average of a value.
void sample(const U &v, int n=1)
Add a value to the distribtion n times.
Vector2dBase(Group *parent, const char *name, const Units::Base *unit, const char *desc)
double Counter
All counters are of 64-bit values.
Temp(unsigned long value)
Create a ConstNode.
size_type size() const
Return the number of nodes in the subtree starting at this node.
void operator--()
Decrement the stat by 1.
ScalarProxy< Derived > Proxy
Proxy type.
Templatized storage and interface for a simple scalar stat.
void reset()
Reset stat value to default.
Vector2d(Group *parent, const char *name, const char *desc=nullptr)
SparseHistInfoProxy(Stat &stat)
void setInit()
Save Storage class parameters if any.
Derived & functor(T &func)
void sample(const U &v, int n=1)
Histogram(Group *parent=nullptr)
const VResult & result() const
const Storage * data(off_type index) const
void processDumpQueue()
Process all the callbacks in the dump callbacks queue.
void operator--()
Decrement the stat by 1.
A 2-Dimensional vecto of scalar stats.
Temp operator*(Temp l, Temp r)
void setName(const std::string &name)
Set the name of this statistic.
Temp(const Value &s)
Create a new ScalarStatNode.
const VResult & result() const
Return the result vector of this subtree.
AverageDeviation(Group *parent=nullptr)
Construct and initialize this distribution.
const Storage * data(off_type index) const
void operator=(const U &v)
Set the data value to the given value.
Overload hash function for BasicBlockRange type.
Derived & precision(int _precision)
Set the precision and marks this stat to print at the end of simulation.
Distribution & init(Counter min, Counter max, Counter bkt)
Set the parameters of this distribution.
The Base class is the parent class of all unit classes.
void dump()
Dump all statistics data to the registered outputs.
A vector of Average stats.
Distribution(Group *parent=nullptr)
VectorBase(Group *parent, const char *name, const Units::Base *unit, const char *desc)
void operator--(int)
Decrement the stat by 1.
void reset()
Reset stat value to default.
Result total() const
Return the total of the result vector.
std::string name
The name of the stat.
char storage[sizeof(Storage)]
The storage for this stat.
void add(DistBase &d)
Add the argument distribution to the this distribution.
Temp(signed int value)
Create a ConstNode.
Temp(signed short value)
Create a ConstNode.
DistData data
Local storage for the entry values, used for printing.
VectorDistribution & init(size_type size, Counter min, Counter max, Counter bkt)
Initialize storage and parameters for this distribution.
const DistProxy & operator=(const DistProxy &sp)
Derived & init(size_type _x, size_type _y)
void sample(const U &v, int n=1)
Add a value to the distribtion n times.
void reset()
Proxy has no state.
const std::string & name() const
SparseHistData data
Local storage for the entry values, used for printing.
size_type size() const
Return the number of nodes in the subtree starting at this node.
Derived & subname(off_type index, const std::string &name)
Set the subfield name for the given index, and marks this stat to print at the end of simulation.
bool zero() const
Return true if no samples have been added.
void setParams(const StorageParams *params)
Save Storage class parameters if any.
DistInfoProxy< Derived > Info
Result total() const
Return a total of all entries in this vector.
void addStat(Stats::Info *info)
Register a stat with this group.
ScalarProxyNode(const ScalarProxy< Stat > &p)
size_type size() const
Return the number of nodes in the subtree starting at this node.
SparseHistBase(Group *parent, const char *name, const Units::Base *unit, const char *desc)
Scalar(Group *parent, const char *name, const Units::Base *unit, const char *desc=nullptr)
SparseHistogram & init(size_type size)
Set the parameters of this histogram.
const VResult & result() const
Return the result vector of this subtree.
Scalar(Group *parent=nullptr)
Histogram & init(size_type size)
Set the parameters of this histogram.
const ScalarProxy< Stat > proxy
StandardDeviation(Group *parent, const char *name, const Units::Base *unit, const char *desc=nullptr)
std::map< const void *, Info * > MapType
Value(Group *parent=nullptr)
Value(Group *parent, const char *name, const char *desc=nullptr)
size_type size() const
Return the number of nodes in the subtree starting at this node.
MethodProxy(T *obj, MethodPointer meth)
void operator-=(const U &v)
Decrement the stat by the given value.
Vector2dInfoProxy(Stat &stat)
VectorAverageDeviation(Group *parent=nullptr)
Histogram(Group *parent, const char *name, const char *desc=nullptr)
void registerHandlers(Handler reset_handler, Handler dump_handler)
void reset()
Reset stat value to default.
ScalarProxy(const ScalarProxy &sp)
Create a copy of the provided ScalarProxy.
void value(VCounter &vec) const
SparseHistogram(Group *parent, const char *name, const Units::Base *unit, const char *desc=nullptr)
Derived & desc(const std::string &_desc)
Set the description and marks this stat to print at the end of simulation.
DistProxy(const DistProxy &sp)
Average(Group *parent, const char *name, const char *desc=nullptr)
VectorInfoProxy(Stat &stat)
Derived & unit(const Units::Base *_unit)
Set the unit of the stat.
Stat::Storage * data(off_type index)
This is a vector of StandardDeviation stats.
Temp(unsigned char value)
Create a ConstNode.
FunctorProxy(const T &func)
std::string csprintf(const char *format, const Args &...args)
Temp(const Average &s)
Create a new ScalarStatNode.
off_type index
The index to access in the parent VectorBase.
Result total() const
Return a total of all entries in this vector.
Temp(unsigned long long value)
Create a ConstNode.
size_type size() const
Return the number of nodes in the subtree starting at this node.
const VResult & result() const
Return the result vector of this subtree.
DistBase(Group *parent, const char *name, const Units::Base *unit, const char *desc)
std::shared_ptr< Node > NodePtr
Shared pointer to a function Node.
InfoProxyType< Derived > Info
bool check() const
Check that this stat has been set up properly and is ready for use.
Storage * data(off_type index)
Result total() const
Return the total of the result vector.
Generated on Tue Jun 22 2021 15:28:25 for gem5 by doxygen 1.8.17