memgraph/include/utils/iterator/count.hpp

39 lines
971 B
C++
Raw Normal View History

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) {}
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;
};