aboutsummaryrefslogtreecommitdiffstats
path: root/util/string/benchmark
diff options
context:
space:
mode:
authorAnton Samokhvalov <pg83@yandex.ru>2022-02-10 16:45:17 +0300
committerDaniil Cherednik <dcherednik@yandex-team.ru>2022-02-10 16:45:17 +0300
commitd3a398281c6fd1d3672036cb2d63f842d2cb28c5 (patch)
treedd4bd3ca0f36b817e96812825ffaf10d645803f2 /util/string/benchmark
parent72cb13b4aff9bc9cf22e49251bc8fd143f82538f (diff)
downloadydb-d3a398281c6fd1d3672036cb2d63f842d2cb28c5.tar.gz
Restoring authorship annotation for Anton Samokhvalov <pg83@yandex.ru>. Commit 2 of 2.
Diffstat (limited to 'util/string/benchmark')
-rw-r--r--util/string/benchmark/ascii/main.cpp174
-rw-r--r--util/string/benchmark/ascii/ya.make16
-rw-r--r--util/string/benchmark/cast/main.cpp104
-rw-r--r--util/string/benchmark/cast/ya.make16
-rw-r--r--util/string/benchmark/float_to_string/main.cpp8
-rw-r--r--util/string/benchmark/join/main.cpp26
-rw-r--r--util/string/benchmark/subst_global/main.cpp4
-rw-r--r--util/string/benchmark/ya.make4
8 files changed, 176 insertions, 176 deletions
diff --git a/util/string/benchmark/ascii/main.cpp b/util/string/benchmark/ascii/main.cpp
index 789300bde2..673047025d 100644
--- a/util/string/benchmark/ascii/main.cpp
+++ b/util/string/benchmark/ascii/main.cpp
@@ -1,22 +1,22 @@
#include <library/cpp/testing/benchmark/bench.h>
-
-#include <util/generic/xrange.h>
-#include <util/string/ascii.h>
-#include <util/generic/bitmap.h>
-#include <util/generic/singleton.h>
-
-namespace {
- struct TUpperMap: public TBitMap<256> {
- inline TUpperMap() noexcept {
- for (unsigned i = 'A'; i <= 'Z'; ++i) {
- Set((ui8)i);
- }
- }
-
- inline char ToLower(char x) const noexcept {
- return Get((ui8)x) ? x + ('a' - 'A') : x;
- }
- };
+
+#include <util/generic/xrange.h>
+#include <util/string/ascii.h>
+#include <util/generic/bitmap.h>
+#include <util/generic/singleton.h>
+
+namespace {
+ struct TUpperMap: public TBitMap<256> {
+ inline TUpperMap() noexcept {
+ for (unsigned i = 'A'; i <= 'Z'; ++i) {
+ Set((ui8)i);
+ }
+ }
+
+ inline char ToLower(char x) const noexcept {
+ return Get((ui8)x) ? x + ('a' - 'A') : x;
+ }
+ };
struct TToLowerLookup {
char Table[256];
@@ -31,66 +31,66 @@ namespace {
return Table[(ui8)x];
}
};
-}
-
-static inline char FastAsciiToLower(char c) {
- return (c >= 'A' && c <= 'Z') ? (c + ('a' - 'A')) : c;
-}
-
-static inline char FastAsciiToLower2(char c) {
- return c + ('a' - 'A') * (int)(c >= 'A' && c <= 'Z');
-}
-
-Y_CPU_BENCHMARK(AsciiToLower, iface) {
- for (const auto i : xrange(iface.Iterations())) {
- Y_UNUSED(i);
-
- for (int j = 0; j < 256; ++j) {
- Y_DO_NOT_OPTIMIZE_AWAY(AsciiToLower(j));
- }
- }
-}
-
-Y_CPU_BENCHMARK(AsciiToLowerChar, iface) {
- for (const auto i : xrange(iface.Iterations())) {
- Y_UNUSED(i);
-
- for (int j = 0; j < 256; ++j) {
- Y_DO_NOT_OPTIMIZE_AWAY(AsciiToLower((char)j));
- }
- }
-}
-
-Y_CPU_BENCHMARK(FastAsciiToLower, iface) {
- for (const auto i : xrange(iface.Iterations())) {
- Y_UNUSED(i);
-
- for (int j = 0; j < 256; ++j) {
- Y_DO_NOT_OPTIMIZE_AWAY(FastAsciiToLower(j));
- }
- }
-}
-
-Y_CPU_BENCHMARK(FastAsciiToLower2, iface) {
- for (const auto i : xrange(iface.Iterations())) {
- Y_UNUSED(i);
-
- for (int j = 0; j < 256; ++j) {
- Y_DO_NOT_OPTIMIZE_AWAY(FastAsciiToLower2(j));
- }
- }
-}
-
-Y_CPU_BENCHMARK(BitMapAsciiToLower, iface) {
- for (const auto i : xrange(iface.Iterations())) {
- Y_UNUSED(i);
-
- for (int j = 0; j < 256; ++j) {
- Y_DO_NOT_OPTIMIZE_AWAY(Singleton<TUpperMap>()->ToLower(j));
- }
- }
-}
-
+}
+
+static inline char FastAsciiToLower(char c) {
+ return (c >= 'A' && c <= 'Z') ? (c + ('a' - 'A')) : c;
+}
+
+static inline char FastAsciiToLower2(char c) {
+ return c + ('a' - 'A') * (int)(c >= 'A' && c <= 'Z');
+}
+
+Y_CPU_BENCHMARK(AsciiToLower, iface) {
+ for (const auto i : xrange(iface.Iterations())) {
+ Y_UNUSED(i);
+
+ for (int j = 0; j < 256; ++j) {
+ Y_DO_NOT_OPTIMIZE_AWAY(AsciiToLower(j));
+ }
+ }
+}
+
+Y_CPU_BENCHMARK(AsciiToLowerChar, iface) {
+ for (const auto i : xrange(iface.Iterations())) {
+ Y_UNUSED(i);
+
+ for (int j = 0; j < 256; ++j) {
+ Y_DO_NOT_OPTIMIZE_AWAY(AsciiToLower((char)j));
+ }
+ }
+}
+
+Y_CPU_BENCHMARK(FastAsciiToLower, iface) {
+ for (const auto i : xrange(iface.Iterations())) {
+ Y_UNUSED(i);
+
+ for (int j = 0; j < 256; ++j) {
+ Y_DO_NOT_OPTIMIZE_AWAY(FastAsciiToLower(j));
+ }
+ }
+}
+
+Y_CPU_BENCHMARK(FastAsciiToLower2, iface) {
+ for (const auto i : xrange(iface.Iterations())) {
+ Y_UNUSED(i);
+
+ for (int j = 0; j < 256; ++j) {
+ Y_DO_NOT_OPTIMIZE_AWAY(FastAsciiToLower2(j));
+ }
+ }
+}
+
+Y_CPU_BENCHMARK(BitMapAsciiToLower, iface) {
+ for (const auto i : xrange(iface.Iterations())) {
+ Y_UNUSED(i);
+
+ for (int j = 0; j < 256; ++j) {
+ Y_DO_NOT_OPTIMIZE_AWAY(Singleton<TUpperMap>()->ToLower(j));
+ }
+ }
+}
+
Y_CPU_BENCHMARK(LookupAsciiToLower, iface) {
for (const auto i : xrange(iface.Iterations())) {
Y_UNUSED(i);
@@ -112,12 +112,12 @@ Y_CPU_BENCHMARK(LookupAsciiToLowerNoSingleton, iface) {
}
}
-Y_CPU_BENCHMARK(tolower, iface) {
- for (const auto i : xrange(iface.Iterations())) {
- Y_UNUSED(i);
-
- for (int j = 0; j < 256; ++j) {
- Y_DO_NOT_OPTIMIZE_AWAY(tolower(j));
- }
- }
-}
+Y_CPU_BENCHMARK(tolower, iface) {
+ for (const auto i : xrange(iface.Iterations())) {
+ Y_UNUSED(i);
+
+ for (int j = 0; j < 256; ++j) {
+ Y_DO_NOT_OPTIMIZE_AWAY(tolower(j));
+ }
+ }
+}
diff --git a/util/string/benchmark/ascii/ya.make b/util/string/benchmark/ascii/ya.make
index e973ba183a..f95b9e0fa8 100644
--- a/util/string/benchmark/ascii/ya.make
+++ b/util/string/benchmark/ascii/ya.make
@@ -1,9 +1,9 @@
Y_BENCHMARK()
-
-OWNER(pg)
-
-SRCS(
- main.cpp
-)
-
-END()
+
+OWNER(pg)
+
+SRCS(
+ main.cpp
+)
+
+END()
diff --git a/util/string/benchmark/cast/main.cpp b/util/string/benchmark/cast/main.cpp
index 341c8a55d3..f604712ab6 100644
--- a/util/string/benchmark/cast/main.cpp
+++ b/util/string/benchmark/cast/main.cpp
@@ -1,66 +1,66 @@
#include <library/cpp/testing/benchmark/bench.h>
-
-#include <util/string/cast.h>
-#include <util/generic/xrange.h>
-
+
+#include <util/string/cast.h>
+#include <util/generic/xrange.h>
+
char str1[] = "1";
char str12[] = "12";
char str1234[] = "1234";
char str12345678[] = "12345678";
-Y_CPU_BENCHMARK(Parse_1, iface) {
- for (const auto i : xrange(iface.Iterations())) {
- Y_UNUSED(i);
+Y_CPU_BENCHMARK(Parse_1, iface) {
+ for (const auto i : xrange(iface.Iterations())) {
+ Y_UNUSED(i);
Y_DO_NOT_OPTIMIZE_AWAY(FromString<ui32>(str1, 1));
- }
-}
-
-Y_CPU_BENCHMARK(Parse_12, iface) {
- for (const auto i : xrange(iface.Iterations())) {
- Y_UNUSED(i);
+ }
+}
+
+Y_CPU_BENCHMARK(Parse_12, iface) {
+ for (const auto i : xrange(iface.Iterations())) {
+ Y_UNUSED(i);
Y_DO_NOT_OPTIMIZE_AWAY(FromString<ui32>(str12, 2));
- }
-}
-
-Y_CPU_BENCHMARK(Parse_1234, iface) {
- for (const auto i : xrange(iface.Iterations())) {
- Y_UNUSED(i);
+ }
+}
+
+Y_CPU_BENCHMARK(Parse_1234, iface) {
+ for (const auto i : xrange(iface.Iterations())) {
+ Y_UNUSED(i);
Y_DO_NOT_OPTIMIZE_AWAY(FromString<ui32>(str1234, 4));
- }
-}
-
-Y_CPU_BENCHMARK(Parse_12345678, iface) {
- for (const auto i : xrange(iface.Iterations())) {
- Y_UNUSED(i);
+ }
+}
+
+Y_CPU_BENCHMARK(Parse_12345678, iface) {
+ for (const auto i : xrange(iface.Iterations())) {
+ Y_UNUSED(i);
Y_DO_NOT_OPTIMIZE_AWAY(FromString<ui32>(str12345678, 8));
- }
-}
-
-//atoi
-Y_CPU_BENCHMARK(Atoi_1, iface) {
- for (const auto i : xrange(iface.Iterations())) {
- Y_UNUSED(i);
+ }
+}
+
+//atoi
+Y_CPU_BENCHMARK(Atoi_1, iface) {
+ for (const auto i : xrange(iface.Iterations())) {
+ Y_UNUSED(i);
Y_DO_NOT_OPTIMIZE_AWAY(atoi(str1));
- }
-}
-
-Y_CPU_BENCHMARK(Atoi_12, iface) {
- for (const auto i : xrange(iface.Iterations())) {
- Y_UNUSED(i);
+ }
+}
+
+Y_CPU_BENCHMARK(Atoi_12, iface) {
+ for (const auto i : xrange(iface.Iterations())) {
+ Y_UNUSED(i);
Y_DO_NOT_OPTIMIZE_AWAY(atoi(str12));
- }
-}
-
-Y_CPU_BENCHMARK(Atoi_1234, iface) {
- for (const auto i : xrange(iface.Iterations())) {
- Y_UNUSED(i);
+ }
+}
+
+Y_CPU_BENCHMARK(Atoi_1234, iface) {
+ for (const auto i : xrange(iface.Iterations())) {
+ Y_UNUSED(i);
Y_DO_NOT_OPTIMIZE_AWAY(atoi(str1234));
- }
-}
-
-Y_CPU_BENCHMARK(Atoi_12345678, iface) {
- for (const auto i : xrange(iface.Iterations())) {
- Y_UNUSED(i);
+ }
+}
+
+Y_CPU_BENCHMARK(Atoi_12345678, iface) {
+ for (const auto i : xrange(iface.Iterations())) {
+ Y_UNUSED(i);
Y_DO_NOT_OPTIMIZE_AWAY(atoi(str12345678));
- }
-}
+ }
+}
diff --git a/util/string/benchmark/cast/ya.make b/util/string/benchmark/cast/ya.make
index e973ba183a..f95b9e0fa8 100644
--- a/util/string/benchmark/cast/ya.make
+++ b/util/string/benchmark/cast/ya.make
@@ -1,9 +1,9 @@
Y_BENCHMARK()
-
-OWNER(pg)
-
-SRCS(
- main.cpp
-)
-
-END()
+
+OWNER(pg)
+
+SRCS(
+ main.cpp
+)
+
+END()
diff --git a/util/string/benchmark/float_to_string/main.cpp b/util/string/benchmark/float_to_string/main.cpp
index fed0de4b8f..1c7c0684a3 100644
--- a/util/string/benchmark/float_to_string/main.cpp
+++ b/util/string/benchmark/float_to_string/main.cpp
@@ -37,8 +37,8 @@ namespace {
TVector<TExample<T>> Examples;
TExamplesHolder()
- : Examples(N)
- {
+ : Examples(N)
+ {
TFastRng<ui64> prng{N * sizeof(T) * 42};
for (auto& x : Examples) {
x.Value = prng.GenRandReal4() + prng.Uniform(Max<ui16>());
@@ -52,8 +52,8 @@ namespace {
TVector<TExample<T>> Examples;
TNearZeroExamplesHolder()
- : Examples(N)
- {
+ : Examples(N)
+ {
TFastRng<ui64> prng{N * sizeof(T) * 42};
for (auto& x : Examples) {
x.Value = prng.GenRandReal4();
diff --git a/util/string/benchmark/join/main.cpp b/util/string/benchmark/join/main.cpp
index 4742089bf8..1a8633d3a8 100644
--- a/util/string/benchmark/join/main.cpp
+++ b/util/string/benchmark/join/main.cpp
@@ -34,7 +34,7 @@ namespace {
s = ::ToString(Prng.GenRand());
}
- template <typename T, typename... TArgs>
+ template <typename T, typename... TArgs>
void Randomize(T& t, TArgs&... args) {
Randomize(t);
Randomize(args...);
@@ -44,7 +44,7 @@ namespace {
TFastRng<ui64> Prng;
};
- template <size_t N, typename... T>
+ template <size_t N, typename... T>
struct TExamplesHolder {
using TExamples = TVector<std::tuple<T...>>;
TExamples Examples;
@@ -54,26 +54,26 @@ namespace {
{
TRandomizer r{N * sizeof(typename TExamples::value_type) * 42};
for (auto& x : Examples) {
- Apply([&r](T&... t) { r.Randomize(t...); }, x);
+ Apply([&r](T&... t) { r.Randomize(t...); }, x);
}
}
};
- template <typename... TArgs>
+ template <typename... TArgs>
TString JoinTuple(std::tuple<TArgs...> t) {
return Apply([](TArgs... x) -> TString { return Join("-", x...); }, t);
}
}
-#define DEFINE_BENCHMARK(count, types, ...) \
- Y_CPU_BENCHMARK(Join_##count##_##types, iface) { \
- const auto& examples = Default<TExamplesHolder<count, __VA_ARGS__>>().Examples; \
- for (const auto i : xrange(iface.Iterations())) { \
- Y_UNUSED(i); \
- for (const auto e : examples) { \
- Y_DO_NOT_OPTIMIZE_AWAY(JoinTuple(e)); \
- } \
- } \
+#define DEFINE_BENCHMARK(count, types, ...) \
+ Y_CPU_BENCHMARK(Join_##count##_##types, iface) { \
+ const auto& examples = Default<TExamplesHolder<count, __VA_ARGS__>>().Examples; \
+ for (const auto i : xrange(iface.Iterations())) { \
+ Y_UNUSED(i); \
+ for (const auto e : examples) { \
+ Y_DO_NOT_OPTIMIZE_AWAY(JoinTuple(e)); \
+ } \
+ } \
}
DEFINE_BENCHMARK(100, SS, TString, TString);
diff --git a/util/string/benchmark/subst_global/main.cpp b/util/string/benchmark/subst_global/main.cpp
index 000f5b47e0..e0decfa042 100644
--- a/util/string/benchmark/subst_global/main.cpp
+++ b/util/string/benchmark/subst_global/main.cpp
@@ -154,7 +154,7 @@ namespace {
for (const auto dummy : xrange(i.Iterations())) { \
Y_UNUSED(dummy); \
auto s = str; \
- NBench::Escape(s.data()); \
+ NBench::Escape(s.data()); \
Y_DO_NOT_OPTIMIZE_AWAY(SubstGlobal(s, ToUnderlying(D::WHAT), ToUnderlying(D::WITH))); \
NBench::Clobber(); \
} \
@@ -167,7 +167,7 @@ namespace {
for (const auto dummy : xrange(i.Iterations())) { \
Y_UNUSED(dummy); \
auto s = str; \
- NBench::Escape(s.data()); \
+ NBench::Escape(s.data()); \
Y_DO_NOT_OPTIMIZE_AWAY(SubstGlobal(s, ToUnderlying(D::WHAT), ToUnderlying(D::WITH))); \
NBench::Clobber(); \
} \
diff --git a/util/string/benchmark/ya.make b/util/string/benchmark/ya.make
index 4410edabaf..266b53c7b3 100644
--- a/util/string/benchmark/ya.make
+++ b/util/string/benchmark/ya.make
@@ -5,8 +5,8 @@ OWNER(
SUBSCRIBER(g:util-subscribers)
RECURSE(
- ascii
- cast
+ ascii
+ cast
float_to_string
float_to_string/metrics
join