2016-08-30 12:29:30 +08:00
|
|
|
#pragma once
|
|
|
|
|
2016-09-08 20:25:52 +08:00
|
|
|
#include "utils/numerics/saturate.hpp"
|
2016-08-30 15:53:02 +08:00
|
|
|
#include "utils/total_ordering.hpp"
|
|
|
|
|
2016-08-30 12:29:30 +08:00
|
|
|
// Represents number of to be returned elements from iterator. Where acutal
|
|
|
|
// number is probably somwhere in [min,max].
|
2016-08-30 15:53:02 +08:00
|
|
|
class Count : public TotalOrdering<Count>
|
2016-08-30 12:29:30 +08:00
|
|
|
{
|
|
|
|
|
|
|
|
public:
|
|
|
|
Count(size_t exact) : min(exact), max(exact) {}
|
|
|
|
|
|
|
|
Count(size_t min, size_t max) : min(min), max(max) {}
|
|
|
|
|
2016-08-31 01:13:23 +08:00
|
|
|
Count min_zero() const { return Count(0, max); }
|
2016-08-30 12:29:30 +08:00
|
|
|
|
2016-08-30 15:53:02 +08:00
|
|
|
size_t avg() const { return ((max - min) >> 1) + min; }
|
|
|
|
|
|
|
|
friend constexpr bool operator<(const Count &lhs, const Count &rhs)
|
|
|
|
{
|
|
|
|
return lhs.avg() < rhs.avg();
|
|
|
|
}
|
|
|
|
|
|
|
|
friend constexpr bool operator==(const Count &lhs, const Count &rhs)
|
|
|
|
{
|
|
|
|
return lhs.avg() == rhs.avg();
|
|
|
|
}
|
|
|
|
|
2016-09-08 20:25:52 +08:00
|
|
|
friend Count operator+(const Count &lhs, const Count &rhs)
|
|
|
|
{
|
|
|
|
return Count(num::saturating_add(lhs.min, rhs.min),
|
|
|
|
num::saturating_add(lhs.max, rhs.max));
|
|
|
|
}
|
|
|
|
|
2016-08-30 12:29:30 +08:00
|
|
|
size_t min;
|
|
|
|
size_t max;
|
|
|
|
};
|