forked from sdcoffey/techan
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathindicator_stochastic_oscillator_test.go
85 lines (72 loc) · 2.54 KB
/
indicator_stochastic_oscillator_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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
package techan
import (
"math"
"testing"
"github.com/sdcoffey/big"
"github.com/stretchr/testify/assert"
)
var fastStochValues = []float64{
100,
100,
100.0 * 12.0 / 16.0,
100.0 * 2.0 / 16.0,
100.0 * 6.0 / 16.0,
100.0 * 2.0 / 16.0,
100.0 * 3.0 / 15.0,
100.0 * 2.0 / 16.0,
100.0 * 4.0 / 13.0,
100.0 * 11.0 / 17.0,
100.0 * 24.0 / 49.0,
}
func TestFastStochasticIndicator(t *testing.T) {
ts := mockTimeSeriesOCHL(
[]float64{10, 12, 12, 8},
[]float64{11, 14, 14, 9},
[]float64{10, 20, 24, 10},
[]float64{9, 10, 11, 9},
[]float64{11, 14, 14, 9},
[]float64{9, 10, 11, 9},
[]float64{10, 12, 12, 10},
[]float64{9, 10, 11, 8},
[]float64{6, 5, 8, 1},
[]float64{15, 12, 18, 9},
[]float64{35, 25, 50, 20},
)
window := 6
k := NewFastStochasticIndicator(ts, window)
decimalEquals(t, fastStochValues[0], k.Calculate(0))
decimalEquals(t, fastStochValues[1], k.Calculate(1))
decimalEquals(t, fastStochValues[2], k.Calculate(2))
decimalEquals(t, fastStochValues[3], k.Calculate(3))
decimalEquals(t, fastStochValues[4], k.Calculate(4))
decimalEquals(t, fastStochValues[5], k.Calculate(5))
decimalEquals(t, fastStochValues[6], k.Calculate(6))
decimalEquals(t, fastStochValues[7], k.Calculate(7))
decimalEquals(t, fastStochValues[8], k.Calculate(8))
decimalEquals(t, fastStochValues[9], k.Calculate(9))
decimalEquals(t, fastStochValues[10], k.Calculate(10))
}
func TestSlowStochasticIndicator(t *testing.T) {
ts := mockTimeSeriesFl(fastStochValues...)
window := 3
d := NewSlowStochasticIndicator(NewClosePriceIndicator(ts), window)
decimalEquals(t, 0, d.Calculate(0))
decimalEquals(t, 0, d.Calculate(1))
decimalEquals(t, 100.0*(12.0/16.0+1+1)/3.0, d.Calculate(2))
decimalEquals(t, 100.0*(2.0/16.0+12.0/16.0+1)/3.0, d.Calculate(3))
decimalEquals(t, 100.0*(6.0/16.0+2.0/16.0+12.0/16.0)/3.0, d.Calculate(4))
decimalEquals(t, 100.0*(2.0/16.0+6.0/16.0+2.0/16.0)/3.0, d.Calculate(5))
decimalEquals(t, 100.0*(3.0/15.0+2.0/16.0+6.0/16.0)/3.0, d.Calculate(6))
decimalEquals(t, 100.0*(2.0/16.0+3.0/15.0+2.0/16.0)/3.0, d.Calculate(7))
decimalEquals(t, 100.0*(4.0/13.0+2.0/16.0+3.0/15.0)/3.0, d.Calculate(8))
decimalEquals(t, 100.0*(11.0/17.0+4.0/13.0+2.0/16.0)/3.0, d.Calculate(9))
decimalEquals(t, 100.0*(24.0/49.0+11.0/17.0+4.0/13.0)/3.0, d.Calculate(10))
}
func TestFastStochasticIndicatorNoPriceChange(t *testing.T) {
ts := mockTimeSeriesOCHL(
[]float64{42, 42, 42, 42},
[]float64{42, 42, 42, 42},
)
k := NewFastStochasticIndicator(ts, 2)
assert.Equal(t, big.NewDecimal(math.Inf(1)).FormattedString(2), k.Calculate(1).FormattedString(2))
}