2023-05-25 14:15:14 +00:00
|
|
|
package indicator
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
|
|
|
|
"github.com/c9s/bbgo/pkg/fixedpoint"
|
|
|
|
"github.com/c9s/bbgo/pkg/types"
|
|
|
|
)
|
|
|
|
|
2023-05-29 13:44:23 +00:00
|
|
|
func Test_v2_Subtract(t *testing.T) {
|
2023-05-25 14:15:14 +00:00
|
|
|
stream := &types.StandardStream{}
|
2023-06-01 04:39:30 +00:00
|
|
|
kLines := KLines(stream, "", "")
|
2023-05-25 14:15:14 +00:00
|
|
|
closePrices := ClosePrices(kLines)
|
|
|
|
fastEMA := EWMA2(closePrices, 10)
|
|
|
|
slowEMA := EWMA2(closePrices, 25)
|
|
|
|
subtract := Subtract(fastEMA, slowEMA)
|
|
|
|
|
|
|
|
for i := .0; i < 50.0; i++ {
|
|
|
|
stream.EmitKLineClosed(types.KLine{Close: fixedpoint.NewFromFloat(19_000.0 + i)})
|
|
|
|
}
|
|
|
|
|
|
|
|
t.Logf("fastEMA: %+v", fastEMA.slice)
|
|
|
|
t.Logf("slowEMA: %+v", slowEMA.slice)
|
|
|
|
|
|
|
|
assert.Equal(t, len(subtract.a), len(subtract.b))
|
2023-05-30 03:35:24 +00:00
|
|
|
assert.Equal(t, len(subtract.a), len(subtract.slice))
|
|
|
|
assert.InDelta(t, subtract.slice[0], subtract.a[0]-subtract.b[0], 0.0001)
|
2023-05-25 14:15:14 +00:00
|
|
|
}
|