gcs/gcsbench_test: adds Zip/HashMatchAny comparsions
This commit is contained in:
parent
784cec0650
commit
36301f211d
1 changed files with 125 additions and 29 deletions
|
@ -15,7 +15,7 @@ import (
|
||||||
|
|
||||||
func genRandFilterElements(numElements uint) ([][]byte, error) {
|
func genRandFilterElements(numElements uint) ([][]byte, error) {
|
||||||
testContents := make([][]byte, numElements)
|
testContents := make([][]byte, numElements)
|
||||||
for i := range contents {
|
for i := range testContents {
|
||||||
randElem := make([]byte, 32)
|
randElem := make([]byte, 32)
|
||||||
if _, err := rand.Read(randElem); err != nil {
|
if _, err := rand.Read(randElem); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -33,7 +33,6 @@ var (
|
||||||
|
|
||||||
// BenchmarkGCSFilterBuild benchmarks building a filter.
|
// BenchmarkGCSFilterBuild benchmarks building a filter.
|
||||||
func BenchmarkGCSFilterBuild50000(b *testing.B) {
|
func BenchmarkGCSFilterBuild50000(b *testing.B) {
|
||||||
b.StopTimer()
|
|
||||||
var testKey [gcs.KeySize]byte
|
var testKey [gcs.KeySize]byte
|
||||||
for i := 0; i < gcs.KeySize; i += 4 {
|
for i := 0; i < gcs.KeySize; i += 4 {
|
||||||
binary.BigEndian.PutUint32(testKey[i:], rand.Uint32())
|
binary.BigEndian.PutUint32(testKey[i:], rand.Uint32())
|
||||||
|
@ -44,7 +43,8 @@ func BenchmarkGCSFilterBuild50000(b *testing.B) {
|
||||||
b.Fatalf("unable to generate random item: %v", genErr)
|
b.Fatalf("unable to generate random item: %v", genErr)
|
||||||
}
|
}
|
||||||
|
|
||||||
b.StartTimer()
|
b.ReportAllocs()
|
||||||
|
b.ResetTimer()
|
||||||
|
|
||||||
var localFilter *gcs.Filter
|
var localFilter *gcs.Filter
|
||||||
for i := 0; i < b.N; i++ {
|
for i := 0; i < b.N; i++ {
|
||||||
|
@ -60,7 +60,6 @@ func BenchmarkGCSFilterBuild50000(b *testing.B) {
|
||||||
|
|
||||||
// BenchmarkGCSFilterBuild benchmarks building a filter.
|
// BenchmarkGCSFilterBuild benchmarks building a filter.
|
||||||
func BenchmarkGCSFilterBuild100000(b *testing.B) {
|
func BenchmarkGCSFilterBuild100000(b *testing.B) {
|
||||||
b.StopTimer()
|
|
||||||
var testKey [gcs.KeySize]byte
|
var testKey [gcs.KeySize]byte
|
||||||
for i := 0; i < gcs.KeySize; i += 4 {
|
for i := 0; i < gcs.KeySize; i += 4 {
|
||||||
binary.BigEndian.PutUint32(testKey[i:], rand.Uint32())
|
binary.BigEndian.PutUint32(testKey[i:], rand.Uint32())
|
||||||
|
@ -71,7 +70,8 @@ func BenchmarkGCSFilterBuild100000(b *testing.B) {
|
||||||
b.Fatalf("unable to generate random item: %v", genErr)
|
b.Fatalf("unable to generate random item: %v", genErr)
|
||||||
}
|
}
|
||||||
|
|
||||||
b.StartTimer()
|
b.ReportAllocs()
|
||||||
|
b.ResetTimer()
|
||||||
|
|
||||||
var localFilter *gcs.Filter
|
var localFilter *gcs.Filter
|
||||||
for i := 0; i < b.N; i++ {
|
for i := 0; i < b.N; i++ {
|
||||||
|
@ -91,16 +91,15 @@ var (
|
||||||
|
|
||||||
// BenchmarkGCSFilterMatch benchmarks querying a filter for a single value.
|
// BenchmarkGCSFilterMatch benchmarks querying a filter for a single value.
|
||||||
func BenchmarkGCSFilterMatch(b *testing.B) {
|
func BenchmarkGCSFilterMatch(b *testing.B) {
|
||||||
b.StopTimer()
|
|
||||||
filter, err := gcs.BuildGCSFilter(P, M, key, contents)
|
filter, err := gcs.BuildGCSFilter(P, M, key, contents)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
b.Fatalf("Failed to build filter")
|
b.Fatalf("Failed to build filter")
|
||||||
}
|
}
|
||||||
b.StartTimer()
|
|
||||||
|
|
||||||
var (
|
b.ReportAllocs()
|
||||||
localMatch bool
|
b.ResetTimer()
|
||||||
)
|
|
||||||
|
var localMatch bool
|
||||||
for i := 0; i < b.N; i++ {
|
for i := 0; i < b.N; i++ {
|
||||||
localMatch, err = filter.Match(key, []byte("Nate"))
|
localMatch, err = filter.Match(key, []byte("Nate"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -115,24 +114,121 @@ func BenchmarkGCSFilterMatch(b *testing.B) {
|
||||||
match = localMatch
|
match = localMatch
|
||||||
}
|
}
|
||||||
|
|
||||||
// BenchmarkGCSFilterMatchAny benchmarks querying a filter for a list of
|
var (
|
||||||
// values.
|
randElems1, _ = genRandFilterElements(1)
|
||||||
func BenchmarkGCSFilterMatchAny(b *testing.B) {
|
randElems10, _ = genRandFilterElements(10)
|
||||||
b.StopTimer()
|
randElems100, _ = genRandFilterElements(100)
|
||||||
filter, err := gcs.BuildGCSFilter(P, M, key, contents)
|
randElems1000, _ = genRandFilterElements(1000)
|
||||||
if err != nil {
|
randElems10000, _ = genRandFilterElements(10000)
|
||||||
b.Fatalf("Failed to build filter")
|
randElems100000, _ = genRandFilterElements(100000)
|
||||||
}
|
randElems1000000, _ = genRandFilterElements(1000000)
|
||||||
b.StartTimer()
|
randElems10000000, _ = genRandFilterElements(10000000)
|
||||||
|
|
||||||
|
filterElems1000, _ = genRandFilterElements(1000)
|
||||||
|
filter1000, _ = gcs.BuildGCSFilter(P, M, key, filterElems1000)
|
||||||
|
filterElems5000, _ = genRandFilterElements(5000)
|
||||||
|
filter5000, _ = gcs.BuildGCSFilter(P, M, key, filterElems5000)
|
||||||
|
filterElems10000, _ = genRandFilterElements(10000)
|
||||||
|
filter10000, _ = gcs.BuildGCSFilter(P, M, key, filterElems10000)
|
||||||
|
)
|
||||||
|
|
||||||
|
// matchAnyBenchmarks contains combinations of random filters and queries used
|
||||||
|
// to measure performance of various MatchAny implementations.
|
||||||
|
var matchAnyBenchmarks = []struct {
|
||||||
|
name string
|
||||||
|
query [][]byte
|
||||||
|
filter *gcs.Filter
|
||||||
|
}{
|
||||||
|
{"q100-f1K", randElems100, filter1000},
|
||||||
|
{"q1K-f1K", randElems1000, filter1000},
|
||||||
|
{"q10K-f1K", randElems10000, filter1000},
|
||||||
|
{"q100K-f1K", randElems100000, filter1000},
|
||||||
|
{"q1M-f1K", randElems1000000, filter1000},
|
||||||
|
{"q10M-f1K", randElems10000000, filter1000},
|
||||||
|
|
||||||
|
{"q100-f5K", randElems100, filter5000},
|
||||||
|
{"q1K-f5K", randElems1000, filter5000},
|
||||||
|
{"q10K-f5K", randElems10000, filter5000},
|
||||||
|
{"q100K-f5K", randElems100000, filter5000},
|
||||||
|
{"q1M-f5K", randElems1000000, filter5000},
|
||||||
|
{"q10M-f5K", randElems10000000, filter5000},
|
||||||
|
|
||||||
|
{"q100-f10K", randElems100, filter10000},
|
||||||
|
{"q1K-f10K", randElems1000, filter10000},
|
||||||
|
{"q10K-f10K", randElems10000, filter10000},
|
||||||
|
{"q100K-f10K", randElems100000, filter10000},
|
||||||
|
{"q1M-f10K", randElems1000000, filter10000},
|
||||||
|
{"q10M-f10K", randElems10000000, filter10000},
|
||||||
|
}
|
||||||
|
|
||||||
|
// BenchmarkGCSFilterMatchAny benchmarks the sort-and-zip MatchAny impl.
|
||||||
|
func BenchmarkGCSFilterZipMatchAny(b *testing.B) {
|
||||||
|
for _, test := range matchAnyBenchmarks {
|
||||||
|
b.Run(test.name, func(b *testing.B) {
|
||||||
|
b.ReportAllocs()
|
||||||
|
|
||||||
var (
|
var (
|
||||||
localMatch bool
|
localMatch bool
|
||||||
|
err error
|
||||||
)
|
)
|
||||||
|
|
||||||
for i := 0; i < b.N; i++ {
|
for i := 0; i < b.N; i++ {
|
||||||
localMatch, err = filter.MatchAny(key, contents2)
|
localMatch, err = test.filter.ZipMatchAny(
|
||||||
|
key, test.query,
|
||||||
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
b.Fatalf("unable to match filter: %v", err)
|
b.Fatalf("unable to match filter: %v", err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
match = localMatch
|
match = localMatch
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// BenchmarkGCSFilterMatchAny benchmarks the hash-join MatchAny impl.
|
||||||
|
func BenchmarkGCSFilterHashMatchAny(b *testing.B) {
|
||||||
|
for _, test := range matchAnyBenchmarks {
|
||||||
|
b.Run(test.name, func(b *testing.B) {
|
||||||
|
b.ReportAllocs()
|
||||||
|
|
||||||
|
var (
|
||||||
|
localMatch bool
|
||||||
|
err error
|
||||||
|
)
|
||||||
|
|
||||||
|
for i := 0; i < b.N; i++ {
|
||||||
|
localMatch, err = test.filter.HashMatchAny(
|
||||||
|
key, test.query,
|
||||||
|
)
|
||||||
|
if err != nil {
|
||||||
|
b.Fatalf("unable to match filter: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
match = localMatch
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// BenchmarkGCSFilterMatchAny benchmarks the hybrid MatchAny impl.
|
||||||
|
func BenchmarkGCSFilterMatchAny(b *testing.B) {
|
||||||
|
for _, test := range matchAnyBenchmarks {
|
||||||
|
b.Run(test.name, func(b *testing.B) {
|
||||||
|
b.ReportAllocs()
|
||||||
|
|
||||||
|
var (
|
||||||
|
localMatch bool
|
||||||
|
err error
|
||||||
|
)
|
||||||
|
|
||||||
|
for i := 0; i < b.N; i++ {
|
||||||
|
localMatch, err = test.filter.MatchAny(
|
||||||
|
key, test.query,
|
||||||
|
)
|
||||||
|
if err != nil {
|
||||||
|
b.Fatalf("unable to match filter: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
match = localMatch
|
||||||
|
})
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue