Merge #8107: bench: Added base58 encoding/decoding benchmarks

5fac1f3 bench: Added base58 encoding/decoding benchmarks (Yuri Zhykin)
This commit is contained in:
Wladimir J. van der Laan 2016-05-30 13:05:43 +02:00 committed by Alexander Block
parent a39b1f7b8d
commit cee571bda4
2 changed files with 58 additions and 1 deletions

View File

@ -9,7 +9,8 @@ bench_bench_dash_SOURCES = \
bench/bench.h \
bench/Examples.cpp \
bench/rollingbloom.cpp \
bench/crypto_hash.cpp
bench/crypto_hash.cpp \
bench/base58.cpp
bench_bench_dash_CPPFLAGS = $(AM_CPPFLAGS) $(BITCOIN_INCLUDES) $(EVENT_CLFAGS) $(EVENT_PTHREADS_CFLAGS) -I$(builddir)/bench/
bench_bench_dash_CXXFLAGS = $(AM_CXXFLAGS) $(PIE_FLAGS)

56
src/bench/base58.cpp Normal file
View 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 "validation.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);