This commit removes the uint64Slice type and performs sorting during
filter construction and ZipMatchAny using sort.Slice. The benchmarks
indicated that this speeds up BuildGCSFilter and ZipMatchAny by 10-12%,
likely to the overhead of needing to resolve the sort.Interface methods.
The benchmarks indicate that this improvement is not present for the
smallest query size in our benchmarks, i.e. 100 elements, but the
reduction is only about 3%. This would indicate the at these small
values, the use of reflection is actually slightly slower than interface
method resolution in total.
This commit removes the uint64Slice type and performs sorting during filter construction and ZipMatchAny using sort.Slice. The benchmarks indicated that this speeds up BuildGCSFilter and ZipMatchAny by 10-12%, likely to the overhead of needing to resolve the sort.Interface methods.
The benchmarks indicate that this improvement is not present for the smallest query size in our benchmarks, i.e. 100 elements, but the reduction is only about 3%. This would indicate the at these small values, the use of reflection is actually slightly slower than interface method resolution in total.
BuildGCSFilter
Before:
After:
ZipMatchAny
Before:
After: