TSDB: Improve xor-chunk benchmarks

Benchmarks must do the same work N times.
Run 3 cases, where the values are constant, vary a bit, and vary a lot.

Also aim for 120 samples same as TSDB default.

Signed-off-by: Bryan Boreham <bjboreham@gmail.com>
pull/14932/head
Bryan Boreham 2024-09-16 08:48:49 +01:00
parent bb47f78929
commit b65f1b6560
1 changed files with 29 additions and 21 deletions

View File

@ -251,54 +251,62 @@ func benchmarkIterator(b *testing.B, newChunk func() Chunk) {
} }
} }
func newXORChunk() Chunk {
return NewXORChunk()
}
func BenchmarkXORIterator(b *testing.B) { func BenchmarkXORIterator(b *testing.B) {
benchmarkIterator(b, func() Chunk { benchmarkIterator(b, newXORChunk)
return NewXORChunk()
})
} }
func BenchmarkXORAppender(b *testing.B) { func BenchmarkXORAppender(b *testing.B) {
benchmarkAppender(b, func() Chunk { r := rand.New(rand.NewSource(1))
return NewXORChunk() b.Run("constant", func(b *testing.B) {
benchmarkAppender(b, func() (int64, float64) {
return 1000, 0
}, newXORChunk)
})
b.Run("random steps", func(b *testing.B) {
benchmarkAppender(b, func() (int64, float64) {
return int64(r.Intn(100) - 50 + 15000), // 15 seconds +- up to 100ms of jitter.
float64(r.Intn(100) - 50) // Varying from -50 to +50 in 100 discrete steps.
}, newXORChunk)
})
b.Run("random 0-1", func(b *testing.B) {
benchmarkAppender(b, func() (int64, float64) {
return int64(r.Intn(100) - 50 + 15000), // 15 seconds +- up to 100ms of jitter.
r.Float64() // Random between 0 and 1.0.
}, newXORChunk)
}) })
} }
func benchmarkAppender(b *testing.B, newChunk func() Chunk) { func benchmarkAppender(b *testing.B, deltas func() (int64, float64), newChunk func() Chunk) {
var ( var (
t = int64(1234123324) t = int64(1234123324)
v = 1243535.123 v = 1243535.123
) )
const nSamples = 120 // Same as tsdb.DefaultSamplesPerChunk.
var exp []pair var exp []pair
for i := 0; i < b.N; i++ { for i := 0; i < nSamples; i++ {
// t += int64(rand.Intn(10000) + 1) dt, dv := deltas()
t += int64(1000) t += dt
// v = rand.Float64() v += dv
v += float64(100)
exp = append(exp, pair{t: t, v: v}) exp = append(exp, pair{t: t, v: v})
} }
b.ReportAllocs() b.ReportAllocs()
b.ResetTimer() b.ResetTimer()
var chunks []Chunk for i := 0; i < b.N; i++ {
for i := 0; i < b.N; {
c := newChunk() c := newChunk()
a, err := c.Appender() a, err := c.Appender()
if err != nil { if err != nil {
b.Fatalf("get appender: %s", err) b.Fatalf("get appender: %s", err)
} }
j := 0
for _, p := range exp { for _, p := range exp {
if j > 250 {
break
}
a.Append(p.t, p.v) a.Append(p.t, p.v)
i++
j++
} }
chunks = append(chunks, c)
} }
fmt.Println("num", b.N, "created chunks", len(chunks))
} }