summaryrefslogtreecommitdiffstats
path: root/ml/BitBufferCounter.h
blob: db924d7762f1097d353d62a917fade29a72dd9ed (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
// SPDX-License-Identifier: GPL-3.0-or-later

#ifndef BIT_BUFFER_COUNTER_H
#define BIT_BUFFER_COUNTER_H

#include "ml-private.h"

namespace ml {

class BitBufferCounter {
public:
    BitBufferCounter(size_t Capacity) : V(Capacity, 0), NumSetBits(0), N(0) {}

    std::vector<bool> getBuffer() const;

    void insert(bool Bit);

    void print(std::ostream &OS) const;

    bool isFilled() const {
       return N >= V.size();
    }

    size_t numSetBits() const {
        return NumSetBits;
    }

private:
    inline size_t size() const {
        return N < V.size() ? N : V.size();
    }

    inline size_t start() const {
        if (N <= V.size())
            return 0;

        return N % V.size();
    }

private:
    std::vector<bool> V;
    size_t NumSetBits;

    size_t N;
};

} // namespace ml

inline std::ostream& operator<<(std::ostream &OS, const ml::BitBufferCounter &BBC) {
    BBC.print(OS);
    return OS;
}

#endif /* BIT_BUFFER_COUNTER_H */