Go to the documentation of this file.
40 : _isSample(false), _team(0)
49 "This dueler is already a sample for id %llu",
id);
64 std::size_t team_size,
unsigned num_bits,
double low_threshold,
65 double high_threshold)
66 :
id(1 << numInstances), constituencySize(constituency_size),
67 teamSize(team_size), lowThreshold(low_threshold),
68 highThreshold(high_threshold),
selector(num_bits), regionCounter(0),
72 "There must be at least team size entries per team in a constituency");
75 "The low threshold must be within the range ]0.0, 1.0[");
77 "The high threshold must be within the range ]0.0, 1.0[");
79 "The low threshold must be below the high threshold");
double calcSaturation() const
Calculate saturation percentile of the current counter's value with regard to its maximum possible va...
const double lowThreshold
If the winning team was "True", and the counter is decreased further than this threshold,...
void setSample(uint64_t id, bool team)
Make this entry a sampling entry for a specific Dueling instance.
uint64_t _team
If entry is a sample, it belongs to one of two possible teams.
void initEntry(Dueler *dueler)
Initialize a dueler entry, deciding wether it is a sample or not.
bool isSample(uint64_t id, bool &team) const
Check if entry is a sample for the given instance.
DuelingMonitor(std::size_t constituency_size, std::size_t team_size=1, unsigned num_bits=10, double low_threshold=0.5, double high_threshold=0.5)
SatCounter32 selector
Counter that determines which dueler is winning.
uint64_t _isSample
Whether this entry is a sample or a follower.
static unsigned numInstances
Number of times this class has been instantiated.
bool getWinner() const
Get the team that is currently winning the duel.
const std::size_t constituencySize
Given a table containing X entries, a constituency is a region of the table such that it contains X/c...
constexpr int popCount(uint64_t val)
Returns the number of set ones in the provided value.
const std::size_t teamSize
Number of entries that belong to each team within a constituency.
uint8_t saturate()
Saturate the counter.
int regionCounter
Counts the number of entries have been initialized in the current constituency.
const double highThreshold
If the winning team was "False", and the counter is increased further than this threshold,...
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
Bitfield< 31, 16 > selector
Dueler()
By default initializes entries as followers.
bool isSample(const Dueler *dueler, bool &team) const
Check if the given dueler is a sample for this instance.
A dueler is an entry that may or may not be accounted for sampling.
void sample(const Dueler *dueler)
If given dueler is a sampling entry, sample it and check if the winning team must be updated.
bool winner
The team that is currently winning.
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Generated on Wed Jul 13 2022 10:39:23 for gem5 by doxygen 1.8.17