-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathdiscover_test.go
54 lines (49 loc) · 1.28 KB
/
discover_test.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 matrixprofile
import (
"math"
"testing"
)
func TestArcCurve(t *testing.T) {
testdata := []struct {
mpIdx []int
expectedHisto []float64
}{
{[]int{}, []float64{}},
{[]int{1, 1, 1, 1, 1}, []float64{0, 0, 2, 1, 0}},
{[]int{4, 5, 6, 0, 2, 1, 0}, []float64{0, 3, 5, 6, 4, 2, 0}},
{[]int{4, 5, 12, 0, 2, 1, 0}, []float64{0, 3, 5, 5, 3, 1, 0}},
{[]int{4, 5, -1, 0, 2, 1, 0}, []float64{0, 3, 5, 5, 3, 1, 0}},
{[]int{4, 5, 6, 2, 2, 1, 0}, []float64{0, 2, 4, 6, 4, 2, 0}},
{[]int{2, 3, 0, 0, 6, 3, 4}, []float64{0, 3, 2, 0, 1, 2, 0}},
}
var histo []float64
for _, d := range testdata {
histo = arcCurve(d.mpIdx)
if len(histo) != len(d.expectedHisto) {
t.Errorf("Expected %d elements, but got %d, %+v", len(d.expectedHisto), len(histo), d)
}
for i := 0; i < len(histo); i++ {
if math.Abs(float64(histo[i]-d.expectedHisto[i])) > 1e-7 {
t.Errorf("Expected %v,\nbut got\n%v for\n%+v", d.expectedHisto, histo, d)
break
}
}
}
}
func TestIac(t *testing.T) {
testdata := []struct {
x float64
n int
expected float64
}{
{0, 124, 0},
{124, 124, 0},
{62, 124, 62},
}
var out float64
for _, d := range testdata {
if out = iac(d.x, d.n); out != d.expected {
t.Errorf("Expected %.3f but got %.3f", d.expected, out)
}
}
}