forked from jjneely/buckytools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
datapoints.go
43 lines (36 loc) · 1.16 KB
/
datapoints.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
package buckytools
import (
"math"
"sort"
"time"
)
import "github.com/azhiltsov/buckytools/whisper"
// FindValidDataPoints does a backwards walk through time to examine the
// highest resolution data for each archive / time period. We collect valid
// data points and return them in a *[]TimeSeriesPoint. The second value
// return is an int containing the total number of points examined. This
// allows one to calculate the percentage of used and unused points stored
// in the Whisper database.
func FindValidDataPoints(wsp *whisper.Whisper) ([]*whisper.TimeSeriesPoint, int, error) {
points := make([]*whisper.TimeSeriesPoint, 0)
count := 0
retentions := whisper.RetentionsByPrecision{wsp.Retentions()}
sort.Sort(retentions)
start := int(time.Now().Unix())
from := 0
for _, r := range retentions.Iterator() {
from = int(time.Now().Unix()) - r.MaxRetention()
ts, err := wsp.Fetch(from, start)
if err != nil {
return make([]*whisper.TimeSeriesPoint, 0, 0), 0, err
}
count = count + len(ts.Values())
for _, v := range ts.Points() {
if !math.IsNaN(v.Value) {
points = append(points, v)
}
}
start = from
}
return points, count, nil
}