-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathringbuffer.go
54 lines (47 loc) · 886 Bytes
/
ringbuffer.go
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
package vardiff
type RingBuffer struct {
IsFull bool
MaxSize int64
Cursor int64
Data []int64
}
func NewRingBuffer(maxSize int64) *RingBuffer {
return &RingBuffer{
IsFull: false,
MaxSize: maxSize,
Cursor: 0,
Data: make([]int64, 0),
}
}
func (rb *RingBuffer) Append(x int64) {
if rb.IsFull {
rb.Data[rb.Cursor] = x
rb.Cursor = (rb.Cursor + 1) % rb.MaxSize
} else {
rb.Data = append(rb.Data, x)
rb.Cursor++
if int64(len(rb.Data)) == rb.MaxSize {
rb.Cursor = 0
rb.IsFull = true
}
}
}
func (rb *RingBuffer) Avg() float64 {
var sum int64
for i := range rb.Data {
sum = sum + rb.Data[i]
}
return float64(sum) / float64(rb.Size())
}
func (rb *RingBuffer) Size() int64 {
if rb.IsFull {
return rb.MaxSize
} else {
return rb.Cursor
}
}
func (rb *RingBuffer) Clear() {
rb.Data = make([]int64, 0)
rb.Cursor = 0
rb.IsFull = false
}