forked from sajari/regression
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcrosses_test.go
45 lines (38 loc) · 1.23 KB
/
crosses_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
package regression
import (
"testing"
)
func TestPowCrosses(t *testing.T) {
cross1 := PowCross(0, 2) //cross of the variable at index 0
if cross1.Calculate([]float64{2})[0] != 4 {
t.Error("Incorrect value")
}
cross2 := PowCross(1, 2) //cross of the variable at index 1
if cross2.Calculate([]float64{2, -3})[0] != 9 {
t.Error("Incorrect value, got", cross2.Calculate([]float64{2, -3}))
}
}
func TestMultiplicationCrosses(t *testing.T) {
cross1 := MultiplierCross(0, 1, 3)
if cross1.Calculate([]float64{2, 3, 4, 5})[0] != 30 {
t.Errorf("Incorrect value, expected 30 got %.2f", cross1.Calculate([]float64{2, 3, 4, 5})[0])
}
cross2 := MultiplierCross(0, 1)
if cross2.Calculate([]float64{2, 3})[0] != 6 {
t.Errorf("Incorrect value, expected 6 got %.2f", cross1.Calculate([]float64{2, 3, 4, 5})[0])
}
}
func TestFunctionalCrossExtendNames(t *testing.T) {
varNames := map[int]string{1: "Number of cars", 0: "fgsd"}
cross := PowCross(1, 2) //cross of the variable at index 0
newVars := cross.ExtendNames(varNames, len(varNames))
if len(varNames) != 3 {
t.Error("Expected another name")
}
if varNames[2] != "(Number of cars)^2" {
t.Error("Expected '(Number of cars)^2'")
}
if newVars != 1 {
t.Error("Expected 1 new var")
}
}