mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-22 08:10:44 +01:00
2e12119a9e
Natural sorting is needed for sort_by_label_natural() and sort_by_label_natural_desc()
functions in MetricsQL - see https://github.com/VictoriaMetrics/VictoriaMetrics/issues/6192
and https://github.com/VictoriaMetrics/VictoriaMetrics/pull/6256
Natural sorting will be also used by `| sort ...` pipe in VictoriaLogs -
see https://docs.victoriametrics.com/victorialogs/logsql/#sort-pipe
(cherry picked from commit 707f3a69db
)
60 lines
2.0 KiB
Go
60 lines
2.0 KiB
Go
package stringsutil
|
|
|
|
import (
|
|
"testing"
|
|
)
|
|
|
|
func BenchmarkLessNatural(b *testing.B) {
|
|
b.Run("distinct_string_prefixes", func(b *testing.B) {
|
|
benchmarkLessNatural(b, []string{
|
|
"aaa", "bbb", "ccc", "ddd", "eee", "fff", "g", "hh", "kkk", "ooo", "ppppp", "wwww", "zzz", "qqq",
|
|
})
|
|
})
|
|
b.Run("distinct_numeric_values", func(b *testing.B) {
|
|
benchmarkLessNatural(b, []string{
|
|
"111", "222", "333", "44", "5555", "666", "7", "88", "999", "000", "123", "452", "34", "234",
|
|
})
|
|
})
|
|
b.Run("common_string_prefixes_distinct_string_suffixes", func(b *testing.B) {
|
|
benchmarkLessNatural(b, []string{
|
|
"XXXaaa", "XXXbbb", "XXXccc", "XXXddd", "XXXeee", "XXXfff", "XXXg", "XXXhh", "XXXkkk", "XXXooo", "XXXppppp", "XXXwwww", "XXXzzz", "XXXqqq",
|
|
})
|
|
})
|
|
b.Run("common_string_prefixes_distinct_numeric_suffixes", func(b *testing.B) {
|
|
benchmarkLessNatural(b, []string{
|
|
"XXX111", "XXX222", "XXX33", "XXX4", "XXX555", "XXX666", "XXX7", "XXX88", "XXX999", "XXX000", "XXX12345", "XXX3211", "XXX873", "XXX98",
|
|
})
|
|
})
|
|
b.Run("common_string_values", func(b *testing.B) {
|
|
benchmarkLessNatural(b, []string{
|
|
"XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX",
|
|
})
|
|
})
|
|
b.Run("common_numeric_prefixes", func(b *testing.B) {
|
|
benchmarkLessNatural(b, []string{
|
|
"111aaa", "111bbb", "111ccc", "111ddd", "111eee", "111fff", "111g", "111hh", "111kkk", "111ooo", "111ppppp", "111wwww", "111zzz", "111qqq",
|
|
})
|
|
})
|
|
b.Run("common_numeric_values", func(b *testing.B) {
|
|
benchmarkLessNatural(b, []string{
|
|
"11111", "11111", "11111", "11111", "11111", "11111", "11111", "11111", "11111", "11111", "11111", "11111", "11111", "11111",
|
|
})
|
|
})
|
|
}
|
|
|
|
func benchmarkLessNatural(b *testing.B, a []string) {
|
|
b.ReportAllocs()
|
|
b.SetBytes(int64(len(a) - 1))
|
|
b.RunParallel(func(pb *testing.PB) {
|
|
n := uint64(0)
|
|
for pb.Next() {
|
|
for i := 1; i < len(a); i++ {
|
|
if LessNatural(a[i-1], a[i]) {
|
|
n++
|
|
}
|
|
}
|
|
}
|
|
GlobalSink.Add(n)
|
|
})
|
|
}
|