Go to the documentation of this file.
29 #ifndef __BASE_DUELING_HH__
30 #define __BASE_DUELING_HH__
90 bool isSample(uint64_t
id,
bool& team)
const;
167 DuelingMonitor(std::size_t constituency_size, std::size_t team_size = 1,
168 unsigned num_bits = 10,
double low_threshold = 0.5,
169 double high_threshold = 0.5);
209 #endif // __BASE_DUELING_HH__
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.
virtual ~Dueler()=default
bool getWinner() const
Get the team that is currently winning the duel.
const uint64_t id
Unique identifier of this instance.
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...
const std::size_t teamSize
Number of entries that belong to each team within a constituency.
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,...
~DuelingMonitor()=default
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.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Duel between two sampled options to determine which is the winner.
Generated on Wed Jul 28 2021 12:10:28 for gem5 by doxygen 1.8.17