Merge #8107: bench: Added base58 encoding/decoding benchmarks
5fac1f3
bench: Added base58 encoding/decoding benchmarks (Yuri Zhykin)
This commit is contained in:
commit
52b803e09b
2 changed files with 58 additions and 1 deletions
|
@ -9,7 +9,8 @@ bench_bench_bitcoin_SOURCES = \
|
|||
bench/bench.h \
|
||||
bench/Examples.cpp \
|
||||
bench/rollingbloom.cpp \
|
||||
bench/crypto_hash.cpp
|
||||
bench/crypto_hash.cpp \
|
||||
bench/base58.cpp
|
||||
|
||||
bench_bench_bitcoin_CPPFLAGS = $(AM_CPPFLAGS) $(BITCOIN_INCLUDES) $(EVENT_CLFAGS) $(EVENT_PTHREADS_CFLAGS) -I$(builddir)/bench/
|
||||
bench_bench_bitcoin_CXXFLAGS = $(AM_CXXFLAGS) $(PIE_FLAGS)
|
||||
|
|
56
src/bench/base58.cpp
Normal file
56
src/bench/base58.cpp
Normal file
|
@ -0,0 +1,56 @@
|
|||
// Copyright (c) 2016 the Bitcoin Core developers
|
||||
// Distributed under the MIT software license, see the accompanying
|
||||
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||
|
||||
#include "bench.h"
|
||||
|
||||
#include "main.h"
|
||||
#include "base58.h"
|
||||
|
||||
#include <vector>
|
||||
#include <string>
|
||||
|
||||
|
||||
static void Base58Encode(benchmark::State& state)
|
||||
{
|
||||
unsigned char buff[32] = {
|
||||
17, 79, 8, 99, 150, 189, 208, 162, 22, 23, 203, 163, 36, 58, 147,
|
||||
227, 139, 2, 215, 100, 91, 38, 11, 141, 253, 40, 117, 21, 16, 90,
|
||||
200, 24
|
||||
};
|
||||
unsigned char* b = buff;
|
||||
while (state.KeepRunning()) {
|
||||
EncodeBase58(b, b + 32);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
static void Base58CheckEncode(benchmark::State& state)
|
||||
{
|
||||
unsigned char buff[32] = {
|
||||
17, 79, 8, 99, 150, 189, 208, 162, 22, 23, 203, 163, 36, 58, 147,
|
||||
227, 139, 2, 215, 100, 91, 38, 11, 141, 253, 40, 117, 21, 16, 90,
|
||||
200, 24
|
||||
};
|
||||
unsigned char* b = buff;
|
||||
std::vector<unsigned char> vch;
|
||||
vch.assign(b, b + 32);
|
||||
while (state.KeepRunning()) {
|
||||
EncodeBase58Check(vch);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
static void Base58Decode(benchmark::State& state)
|
||||
{
|
||||
const char* addr = "17VZNX1SN5NtKa8UQFxwQbFeFc3iqRYhem";
|
||||
std::vector<unsigned char> vch;
|
||||
while (state.KeepRunning()) {
|
||||
DecodeBase58(addr, vch);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
BENCHMARK(Base58Encode);
|
||||
BENCHMARK(Base58CheckEncode);
|
||||
BENCHMARK(Base58Decode);
|
Loading…
Reference in a new issue