Go to the documentation of this file.
29 #ifndef __BASE_STATS_UNITS_HH__
30 #define __BASE_STATS_UNITS_HH__
32 #include <type_traits>
39 #define UNIT_CYCLE Stats::Units::Cycle::get()
40 #define UNIT_TICK Stats::Units::Tick::get()
41 #define UNIT_SECOND Stats::Units::Second::get()
42 #define UNIT_BIT Stats::Units::Bit::get()
43 #define UNIT_BYTE Stats::Units::Byte::get()
44 #define UNIT_JOULE Stats::Units::Joule::get()
45 #define UNIT_VOLT Stats::Units::Volt::get()
46 #define UNIT_CELSIUS Stats::Units::DegreeCelsius::get()
47 #define UNIT_RATE(T1, T2) Stats::Units::Rate<T1, T2>::get()
48 #define UNIT_RATIO Stats::Units::Ratio::get()
49 #define UNIT_COUNT Stats::Units::Count::get()
50 #define UNIT_WATT Stats::Units::Watt::get()
51 #define UNIT_UNSPECIFIED Stats::Units::Unspecified::get()
109 static Cycle instance;
126 static Tick instance;
177 static Byte instance;
194 static Watt instance;
212 static Joule instance;
229 static Volt instance;
249 static std::string
toString() {
return "Celsius"; }
268 static Count instance;
275 template <
typename T1,
typename T2>
278 static_assert(std::is_base_of<Base, T1>::value,
279 "Rate(T1,T2) must have T1 and T2 derived from"
280 "Stats::Units::Base");
281 static_assert(std::is_base_of<Base, T2>::value,
282 "Rate(T1,T2) must have T1 and T2 derived from"
283 "Stats::Units::Base");
298 return csprintf(
"(%s/%s)", T1::toString(), T2::toString());
317 static Ratio instance;
337 static std::string
toString() {
return "Unspecified"; }
349 #endif // __BASE_STATS_UNITS_HH__
static std::string toString()
void operator=(Joule const &)=delete
std::string getUnitString() const override
void operator=(DegreeCelsius const &)=delete
std::string getUnitString() const override
static std::string toString()
std::string getUnitString() const override
static std::string toString()
std::string getUnitString() const override
static std::string toString()
static DegreeCelsius * get()
std::string getUnitString() const override
static std::string toString()
std::string getUnitString() const override
std::string getUnitString() const override
void operator=(Tick const &)=delete
void operator=(Watt const &)=delete
void operator=(Second const &)=delete
static std::string toString()
void operator=(Rate< T1, T2 > const &)=delete
std::string getUnitString() const override
void operator=(Volt const &)=delete
std::string getUnitString() const override
void operator=(Count const &)=delete
static std::string toString()
static Rate< T1, T2 > * get()
void operator=(Unspecified const &)=delete
std::string getUnitString() const override
std::string getUnitString() const override
static std::string toString()
void operator=(Cycle const &)=delete
std::string getUnitString() const override
The Base class is the parent class of all unit classes.
static std::string toString()
static std::string toString()
static Unspecified * get()
static std::string toString()
virtual std::string getUnitString() const =0
std::string getUnitString() const override
void operator=(Ratio const &)=delete
void operator=(Bit const &)=delete
void operator=(Byte const &)=delete
static std::string toString()
std::string csprintf(const char *format, const Args &...args)
static std::string toString()
Generated on Tue Jun 22 2021 15:28:25 for gem5 by doxygen 1.8.17