Bitcoin Core 28.99.0
P2P Digital Currency
gcs_filter.cpp
Go to the documentation of this file.
1// Copyright (c) 2018-2022 The Bitcoin Core developers
2// Distributed under the MIT software license, see the accompanying
3// file COPYING or http://www.opensource.org/licenses/mit-license.php.
4
5#include <bench/bench.h>
6#include <blockfilter.h>
7#include <uint256.h>
8
9#include <cstdint>
10#include <utility>
11#include <vector>
12
14{
15 GCSFilter::ElementSet elements;
16
17 // Testing the benchmarks with different number of elements show that a filter
18 // with at least 100,000 elements results in benchmarks that have the same
19 // ns/op. This makes it easy to reason about how long (in nanoseconds) a single
20 // filter element takes to process.
21 for (int i = 0; i < 100000; ++i) {
22 GCSFilter::Element element(32);
23 element[0] = static_cast<unsigned char>(i);
24 element[1] = static_cast<unsigned char>(i >> 8);
25 elements.insert(std::move(element));
26 }
27
28 return elements;
29}
30
32{
33 auto elements = GenerateGCSTestElements();
34
35 GCSFilter filter({0, 0, BASIC_FILTER_P, BASIC_FILTER_M}, elements);
36 BlockFilter block_filter(BlockFilterType::BASIC, {}, filter.GetEncoded(), /*skip_decode_check=*/false);
37
38 bench.run([&] {
39 block_filter.GetHash();
40 });
41}
42
44{
45 auto elements = GenerateGCSTestElements();
46
47 uint64_t siphash_k0 = 0;
48 bench.run([&]{
49 GCSFilter filter({siphash_k0, 0, BASIC_FILTER_P, BASIC_FILTER_M}, elements);
50
51 siphash_k0++;
52 });
53}
54
56{
57 auto elements = GenerateGCSTestElements();
58
59 GCSFilter filter({0, 0, BASIC_FILTER_P, BASIC_FILTER_M}, elements);
60 auto encoded = filter.GetEncoded();
61
62 bench.run([&] {
63 GCSFilter filter({0, 0, BASIC_FILTER_P, BASIC_FILTER_M}, encoded, /*skip_decode_check=*/false);
64 });
65}
66
68{
69 auto elements = GenerateGCSTestElements();
70
71 GCSFilter filter({0, 0, BASIC_FILTER_P, BASIC_FILTER_M}, elements);
72 auto encoded = filter.GetEncoded();
73
74 bench.run([&] {
75 GCSFilter filter({0, 0, BASIC_FILTER_P, BASIC_FILTER_M}, encoded, /*skip_decode_check=*/true);
76 });
77}
78
80{
81 auto elements = GenerateGCSTestElements();
82
83 GCSFilter filter({0, 0, BASIC_FILTER_P, BASIC_FILTER_M}, elements);
84
85 bench.run([&] {
86 filter.Match(GCSFilter::Element());
87 });
88}
constexpr uint8_t BASIC_FILTER_P
Definition: blockfilter.h:89
constexpr uint32_t BASIC_FILTER_M
Definition: blockfilter.h:90
Complete block filter struct as defined in BIP 157.
Definition: blockfilter.h:115
This implements a Golomb-coded set as defined in BIP 158.
Definition: blockfilter.h:29
std::vector< unsigned char > Element
Definition: blockfilter.h:31
std::unordered_set< Element, ByteVectorHash > ElementSet
Definition: blockfilter.h:32
const std::vector< unsigned char > & GetEncoded() const LIFETIMEBOUND
Definition: blockfilter.h:73
Main entry point to nanobench's benchmarking facility.
Definition: nanobench.h:627
Bench & run(char const *benchmarkName, Op &&op)
Repeatedly calls op() based on the configuration, and performs measurements.
Definition: nanobench.h:1234
static void GCSFilterConstruct(benchmark::Bench &bench)
Definition: gcs_filter.cpp:43
static GCSFilter::ElementSet GenerateGCSTestElements()
Definition: gcs_filter.cpp:13
static void GCSFilterDecode(benchmark::Bench &bench)
Definition: gcs_filter.cpp:55
BENCHMARK(GCSBlockFilterGetHash, benchmark::PriorityLevel::HIGH)
static void GCSBlockFilterGetHash(benchmark::Bench &bench)
Definition: gcs_filter.cpp:31
static void GCSFilterDecodeSkipCheck(benchmark::Bench &bench)
Definition: gcs_filter.cpp:67
static void GCSFilterMatch(benchmark::Bench &bench)
Definition: gcs_filter.cpp:79
@ HIGH
Definition: bench.h:48