-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbargraph.hpp
59 lines (53 loc) · 1.76 KB
/
bargraph.hpp
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
55
56
57
58
59
// Copyright 2021 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#pragma once
#include <stdio.h>
#include <vector>
template <typename ValueType>
class BarGraph
{
public:
std::vector<ValueType> history_; // is actually a ring buffer.
int next_; // index to the slot where the next insertion will go
int length_; // total # of data points that have ever been added
explicit BarGraph(int capacity) : next_(0), length_(0)
{
history_.resize(capacity);
std::fill(history_.begin(), history_.end(), 0);
}
// The last value is in [0], so on and so forth
// Note: if there are not enough data, this function will return as much
// as is available
std::vector<float> GetLastNValues(int x)
{
std::vector<float> ret;
const int N = static_cast<int>(history_.size());
int imax = x;
imax = std::min(imax, length_);
imax = std::min(imax, N);
int idx = (next_ - 1 + N) % N;
for (int i = 0; i < imax; i++)
{
ret.push_back(history_[idx]);
idx = (idx - 1 + N) % N;
}
return ret;
}
void AddValue(ValueType x)
{
history_[next_] = x;
next_ = (next_ + 1) % history_.size();
length_++;
}
};