mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-20 15:16:42 +00:00
wip
This commit is contained in:
parent
3d8060e302
commit
ac846f057a
1 changed files with 96 additions and 4 deletions
|
@ -79,7 +79,7 @@ func benchmarkMarshalVarUint64s(b *testing.B, maxValue uint64) {
|
||||||
var data []uint64
|
var data []uint64
|
||||||
n := maxValue
|
n := maxValue
|
||||||
for i := 0; i < numsCount; i++ {
|
for i := 0; i < numsCount; i++ {
|
||||||
if n <= 0 {
|
if n > maxValue {
|
||||||
n = maxValue
|
n = maxValue
|
||||||
}
|
}
|
||||||
data = append(data, n)
|
data = append(data, n)
|
||||||
|
@ -119,7 +119,7 @@ func benchmarkMarshalVarInt64s(b *testing.B, maxValue int64) {
|
||||||
var data []int64
|
var data []int64
|
||||||
n := maxValue
|
n := maxValue
|
||||||
for i := 0; i < numsCount; i++ {
|
for i := 0; i < numsCount; i++ {
|
||||||
if n <= 0 {
|
if n < -maxValue {
|
||||||
n = maxValue
|
n = maxValue
|
||||||
}
|
}
|
||||||
data = append(data, n)
|
data = append(data, n)
|
||||||
|
@ -139,6 +139,52 @@ func benchmarkMarshalVarInt64s(b *testing.B, maxValue int64) {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func BenchmarkUnmarshalVarUint64(b *testing.B) {
|
||||||
|
b.Run("up-to-(1<<7)-1", func(b *testing.B) {
|
||||||
|
benchmarkUnmarshalVarUint64(b, (1<<7)-1)
|
||||||
|
})
|
||||||
|
b.Run("up-to-(1<<14)-1", func(b *testing.B) {
|
||||||
|
benchmarkUnmarshalVarUint64(b, (1<<14)-1)
|
||||||
|
})
|
||||||
|
b.Run("up-to-(1<<28)-1", func(b *testing.B) {
|
||||||
|
benchmarkUnmarshalVarUint64(b, (1<<28)-1)
|
||||||
|
})
|
||||||
|
b.Run("up-to-(1<<64)-1", func(b *testing.B) {
|
||||||
|
benchmarkUnmarshalVarUint64(b, (1<<64)-1)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func benchmarkUnmarshalVarUint64(b *testing.B, maxValue uint64) {
|
||||||
|
const numsCount = 8000
|
||||||
|
var data []byte
|
||||||
|
n := maxValue
|
||||||
|
for i := 0; i < numsCount; i++ {
|
||||||
|
if n > maxValue {
|
||||||
|
n = maxValue
|
||||||
|
}
|
||||||
|
data = MarshalVarUint64(data, n)
|
||||||
|
n--
|
||||||
|
}
|
||||||
|
b.ResetTimer()
|
||||||
|
b.ReportAllocs()
|
||||||
|
b.SetBytes(numsCount)
|
||||||
|
b.RunParallel(func(pb *testing.PB) {
|
||||||
|
var sink uint64
|
||||||
|
for pb.Next() {
|
||||||
|
src := data
|
||||||
|
for len(src) > 0 {
|
||||||
|
tail, n, err := UnmarshalVarUint64(src)
|
||||||
|
if err != nil {
|
||||||
|
panic(fmt.Errorf("unexpected error: %w", err))
|
||||||
|
}
|
||||||
|
sink += n
|
||||||
|
src = tail
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Sink.Add(sink)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
func BenchmarkUnmarshalVarUint64s(b *testing.B) {
|
func BenchmarkUnmarshalVarUint64s(b *testing.B) {
|
||||||
b.Run("up-to-(1<<7)-1", func(b *testing.B) {
|
b.Run("up-to-(1<<7)-1", func(b *testing.B) {
|
||||||
benchmarkUnmarshalVarUint64s(b, (1<<7)-1)
|
benchmarkUnmarshalVarUint64s(b, (1<<7)-1)
|
||||||
|
@ -159,7 +205,7 @@ func benchmarkUnmarshalVarUint64s(b *testing.B, maxValue uint64) {
|
||||||
var data []byte
|
var data []byte
|
||||||
n := maxValue
|
n := maxValue
|
||||||
for i := 0; i < numsCount; i++ {
|
for i := 0; i < numsCount; i++ {
|
||||||
if n <= 0 {
|
if n > maxValue {
|
||||||
n = maxValue
|
n = maxValue
|
||||||
}
|
}
|
||||||
data = MarshalVarUint64(data, n)
|
data = MarshalVarUint64(data, n)
|
||||||
|
@ -185,6 +231,52 @@ func benchmarkUnmarshalVarUint64s(b *testing.B, maxValue uint64) {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func BenchmarkUnmarshalVarInt64(b *testing.B) {
|
||||||
|
b.Run("up-to-(1<<6)-1", func(b *testing.B) {
|
||||||
|
benchmarkUnmarshalVarInt64(b, (1<<6)-1)
|
||||||
|
})
|
||||||
|
b.Run("up-to-(1<<13)-1", func(b *testing.B) {
|
||||||
|
benchmarkUnmarshalVarInt64(b, (1<<13)-1)
|
||||||
|
})
|
||||||
|
b.Run("up-to-(1<<27)-1", func(b *testing.B) {
|
||||||
|
benchmarkUnmarshalVarInt64(b, (1<<27)-1)
|
||||||
|
})
|
||||||
|
b.Run("up-to-(1<<63)-1", func(b *testing.B) {
|
||||||
|
benchmarkUnmarshalVarInt64(b, (1<<63)-1)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func benchmarkUnmarshalVarInt64(b *testing.B, maxValue int64) {
|
||||||
|
const numsCount = 8000
|
||||||
|
var data []byte
|
||||||
|
n := maxValue
|
||||||
|
for i := 0; i < numsCount; i++ {
|
||||||
|
if n < -maxValue {
|
||||||
|
n = maxValue
|
||||||
|
}
|
||||||
|
data = MarshalVarInt64(data, n)
|
||||||
|
n--
|
||||||
|
}
|
||||||
|
b.ResetTimer()
|
||||||
|
b.ReportAllocs()
|
||||||
|
b.SetBytes(numsCount)
|
||||||
|
b.RunParallel(func(pb *testing.PB) {
|
||||||
|
var sink uint64
|
||||||
|
for pb.Next() {
|
||||||
|
src := data
|
||||||
|
for len(src) > 0 {
|
||||||
|
tail, n, err := UnmarshalVarInt64(src)
|
||||||
|
if err != nil {
|
||||||
|
panic(fmt.Errorf("unexpected error: %w", err))
|
||||||
|
}
|
||||||
|
sink += uint64(n)
|
||||||
|
src = tail
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Sink.Add(sink)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
func BenchmarkUnmarshalVarInt64s(b *testing.B) {
|
func BenchmarkUnmarshalVarInt64s(b *testing.B) {
|
||||||
b.Run("up-to-(1<<6)-1", func(b *testing.B) {
|
b.Run("up-to-(1<<6)-1", func(b *testing.B) {
|
||||||
benchmarkUnmarshalVarInt64s(b, (1<<6)-1)
|
benchmarkUnmarshalVarInt64s(b, (1<<6)-1)
|
||||||
|
@ -205,7 +297,7 @@ func benchmarkUnmarshalVarInt64s(b *testing.B, maxValue int64) {
|
||||||
var data []byte
|
var data []byte
|
||||||
n := maxValue
|
n := maxValue
|
||||||
for i := 0; i < numsCount; i++ {
|
for i := 0; i < numsCount; i++ {
|
||||||
if n <= 0 {
|
if n < -maxValue {
|
||||||
n = maxValue
|
n = maxValue
|
||||||
}
|
}
|
||||||
data = MarshalVarInt64(data, n)
|
data = MarshalVarInt64(data, n)
|
||||||
|
|
Loading…
Reference in a new issue