//
// libsemigroups - C++ library for semigroups and monoids
// Copyright (C) 2020 James D. Mitchell
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/ >.
//
#include <cstddef> // for size_t
#include "bench-main.hpp" // for CATCH_CONFIG_ENABLE_BENCHMARKING
#include "catch.hpp" // for TEST_CASE, BENCHMARK, REQUIRE
#include "libsemigroups/bitset.hpp" // for BitSet
#include "libsemigroups/bmat.hpp" // for BMat adapters
#include "libsemigroups/froidure-pin.hpp" // for FroidurePin
#include "libsemigroups/matrix.hpp" // for BMat
#include "libsemigroups/report.hpp" // for ReportGuard
#include "libsemigroups/transf.hpp" // for Transformation
namespace libsemigroups {
////////////////////////////////////////////////////////////////////////
// Alternative implementations of Lambda for BMat<>
////////////////////////////////////////////////////////////////////////
template <typename T>
struct LambdaBMatAlt1 {
template <typename Mat>
void operator ()(T& res, Mat const & x) const {
using S = typename T::value_type;
size_t const N = S().size();
if (x.number_of_rows() > N) {
LIBSEMIGROUPS_EXCEPTION(
"expected matrix of dimension at most %llu, found %llu" ,
N,
x.number_of_rows());
}
T pt;
for (size_t i = 0; i < x.number_of_rows(); ++i) {
S cup;
cup.reset();
cup.set(i, true );
pt.push_back(std::move(cup));
}
ImageRightAction<Mat, T>()(res, pt, x);
}
template <typename Mat>
T operator ()(Mat const & x) const {
T res;
this->operator ()(res, x);
return res;
}
};
template <typename T>
struct LambdaBMatAlt2 {
template <typename Mat>
void operator ()(T& res, Mat const & x) const {
using S = typename T::value_type;
size_t const N = S().size();
if (x.number_of_rows() > N) {
LIBSEMIGROUPS_EXCEPTION(
"expected matrix of dimension at most %llu, found %llu" ,
N,
x.number_of_rows());
}
static thread_local T pt;
pt.clear();
for (size_t i = 0; i < x.number_of_rows(); ++i) {
S cup;
cup.reset();
cup.set(i, true );
pt.push_back(std::move(cup));
}
ImageRightAction<Mat, T>()(res, pt, x);
}
template <typename Mat>
T operator ()(Mat const & x) const {
T res;
this->operator ()(res, x);
return res;
}
};
////////////////////////////////////////////////////////////////////////
// Alternative implementation of Rank for BMat<>
////////////////////////////////////////////////////////////////////////
template <typename Mat>
struct Rank<Mat, void > {
size_t operator ()(Mat const & x, size_t = 0) {
return matrix_helpers::row_space_size(x);
}
};
////////////////////////////////////////////////////////////////////////
// Examples providing candidate boolean matrices for the benchmarks
////////////////////////////////////////////////////////////////////////
template <typename T>
void BMat_example1(T& S) {
using BMat = typename T::element_type;
S.add_generator(BMat({{1, 0, 0, 0, 0, 0, 0, 0},
{0, 1, 0, 0, 0, 0, 0, 0},
{0, 0, 1, 0, 0, 0, 0, 0},
{0, 0, 0, 1, 0, 0, 0, 0},
{0, 0, 0, 0, 1, 0, 0, 0},
{0, 0, 0, 0, 0, 0, 1, 0},
{0, 0, 0, 0, 0, 0, 0, 1},
{0, 0, 0, 0, 0, 1, 0, 0}}));
S.add_generator(BMat({{0, 1, 0, 1, 0, 1, 0, 0},
{0, 1, 1, 0, 1, 1, 0, 0},
{1, 0, 1, 1, 0, 0, 0, 0},
{0, 1, 0, 0, 1, 0, 0, 0},
{0, 0, 1, 0, 0, 1, 0, 0},
{0, 1, 0, 1, 1, 0, 0, 0},
{1, 0, 0, 0, 0, 0, 0, 0},
{0, 0, 0, 0, 0, 0, 0, 0}}));
S.add_generator(BMat({{0, 1, 0, 1, 0, 1, 0, 0},
{1, 0, 1, 0, 0, 1, 0, 0},
{1, 0, 1, 1, 0, 1, 0, 0},
{0, 0, 1, 0, 1, 0, 0, 0},
{1, 1, 0, 1, 0, 1, 0, 0},
{0, 1, 0, 1, 0, 1, 0, 0},
{0, 0, 0, 0, 0, 0, 0, 0},
{0, 0, 0, 0, 0, 0, 0, 0}}));
}
template <typename T>
void BMat_example2(T& S) {
using BMat = typename T::element_type;
S.add_generator(
BMat({{0, 1, 0, 0}, {1, 0, 0, 0}, {0, 0, 1, 0}, {0, 0, 0, 1}}));
S.add_generator(
BMat({{0, 1, 0, 0}, {0, 0, 1, 0}, {0, 0, 0, 1}, {1, 0, 0, 0}}));
S.add_generator(
BMat({{1, 0, 0, 0}, {0, 1, 0, 0}, {0, 0, 1, 0}, {1, 0, 0, 1}}));
S.add_generator(
BMat({{1, 0, 0, 0}, {0, 1, 0, 0}, {0, 0, 1, 0}, {0, 0, 0, 0}}));
}
template <typename T>
void transf_example1(T& S) {
using Transf = typename T::element_type;
S.add_generator(Transf({1, 7, 2, 6, 0, 4, 1, 5}));
S.add_generator(Transf({2, 4, 6, 1, 4, 5, 2, 7}));
S.add_generator(Transf({3, 0, 7, 2, 4, 6, 2, 4}));
S.add_generator(Transf({3, 2, 3, 4, 5, 3, 0, 1}));
S.add_generator(Transf({4, 3, 7, 7, 4, 5, 0, 4}));
S.add_generator(Transf({5, 6, 3, 0, 3, 0, 5, 1}));
S.add_generator(Transf({6, 0, 1, 1, 1, 6, 3, 4}));
S.add_generator(Transf({7, 7, 4, 0, 6, 4, 1, 7}));
}
////////////////////////////////////////////////////////////////////////
// Benchmark functions
////////////////////////////////////////////////////////////////////////
template <typename Mat, typename T>
void benchmark_BMat_lambda(FroidurePin<Mat> const & S, std::string title) {
T result;
BENCHMARK("using " + title) {
for (auto it = S.cbegin(); it < S.cend(); ++it) {
Lambda<Mat, T>()(result, *it);
}
};
}
template <typename Mat, typename T>
void benchmark_BMat_lambda_alt1(FroidurePin<Mat> const & S,
std::string title) {
T result;
BENCHMARK("using " + title) {
for (auto it = S.cbegin(); it < S.cend(); ++it) {
LambdaBMatAlt1<T>()(result, *it);
}
};
}
template <typename Mat, typename T>
void benchmark_BMat_lambda_alt2(FroidurePin<Mat> const & S,
std::string title) {
T result;
BENCHMARK("using " + title) {
for (auto it = S.cbegin(); it < S.cend(); ++it) {
LambdaBMatAlt2<T>()(result, *it);
}
};
}
template <typename Mat, typename T>
void benchmark_BMat_rho(FroidurePin<Mat> const & S, std::string title) {
T result;
BENCHMARK("using " + title) {
for (auto it = S.cbegin(); it < S.cend(); ++it) {
Rho<Mat, T>()(result, *it);
}
};
}
template <typename T>
void benchmark_transf_rho(FroidurePin<Transf<>> const & S, std::string title) {
T result;
BENCHMARK("using " + title) {
for (auto it = S.cbegin(); it < S.cend(); ++it) {
Rho<Transf<>, T>()(result, *it);
}
};
}
template <typename T>
void benchmark_transf_lambda(FroidurePin<Transf<>> const & S,
std::string title) {
T result;
BENCHMARK("using " + title) {
for (auto it = S.cbegin(); it < S.cend(); ++it) {
Lambda<Transf<>, T>()(result, *it);
}
};
}
////////////////////////////////////////////////////////////////////////
// The actual benchmarks for BMats
////////////////////////////////////////////////////////////////////////
TEST_CASE("Example 1: BMat<> + StaticVector1, 64>" ,
"[quick][000][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<>> S;
BMat_example1(S);
S.run();
REQUIRE(S.size() == 255);
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<BitSet<64>, 64>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<>, detail::StaticVector1<BitSet<64>, 64>>(
S, "LambdaBMatAlt1 (using BMat<>, ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<>, detail::StaticVector1<BitSet<64>, 64>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 1: BMat<8> + StaticVector1, 64>" ,
"[quick][016][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<8>> S;
BMat_example1(S);
S.run();
REQUIRE(S.size() == 255);
benchmark_BMat_lambda<BMat<8>, detail::StaticVector1<BitSet<64>, 64>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<8>, detail::StaticVector1<BitSet<64>, 64>>(
S,
"LambdaBMatAlt1 (using BMat<8>, ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<8>, detail::StaticVector1<BitSet<64>, 64>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 2: BMat<> + StaticVector1, 64>" ,
"[quick][006][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<>> S;
BMat_example2(S);
S.run();
REQUIRE(S.size() == 63904);
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<BitSet<64>, 64>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<>, detail::StaticVector1<BitSet<64>, 64>>(
S, "LambdaBMatAlt1 (using BMat<>, ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<>, detail::StaticVector1<BitSet<64>, 64>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 2: BMat<4> + StaticVector1, 64>" ,
"[quick][017][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<4>> S;
BMat_example2(S);
S.run();
REQUIRE(S.size() == 63904);
benchmark_BMat_lambda<BMat<4>, detail::StaticVector1<BitSet<64>, 64>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<4>, detail::StaticVector1<BitSet<64>, 64>>(
S,
"LambdaBMatAlt1 (using BMat<4>, ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<4>, detail::StaticVector1<BitSet<64>, 64>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 1: BMat<> + StaticVector1, 8>" ,
"[quick][001][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<>> S;
BMat_example1(S);
S.run();
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<BitSet<8>, 8>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<>, detail::StaticVector1<BitSet<8>, 8>>(
S, "LambdaBMatAlt1 (using BMat<>,ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<>, detail::StaticVector1<BitSet<8>, 8>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 1: BMat<8> + StaticVector1, 8>" ,
"[quick][018][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<8>> S;
BMat_example1(S);
S.run();
benchmark_BMat_lambda<BMat<8>, detail::StaticVector1<BitSet<8>, 8>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<8>, detail::StaticVector1<BitSet<8>, 8>>(
S, "LambdaBMatAlt1 (using BMat<8>,ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<8>, detail::StaticVector1<BitSet<8>, 8>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 2: BMat<> + StaticVector1, 8>" ,
"[quick][007][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<>> S;
BMat_example2(S);
S.run();
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<BitSet<8>, 8>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<>, detail::StaticVector1<BitSet<8>, 8>>(
S, "LambdaBMatAlt1 (using BMat<>, ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<>, detail::StaticVector1<BitSet<8>, 8>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 2: BMat<4> + StaticVector1, 8>" ,
"[quick][019][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<4>> S;
BMat_example2(S);
S.run();
benchmark_BMat_lambda<BMat<4>, detail::StaticVector1<BitSet<8>, 8>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<4>, detail::StaticVector1<BitSet<8>, 8>>(
S,
"LambdaBMatAlt1 (using BMat<4>, ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<4>, detail::StaticVector1<BitSet<8>, 8>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 1: BMat<> + std::vector>" ,
"[quick][002][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<>> S;
BMat_example1(S);
S.run();
benchmark_BMat_lambda<BMat<>, std::vector<BitSet<64>>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<>, std::vector<BitSet<64>>>(
S, "LambdaBMatAlt1 (using BMat<>, ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<>, std::vector<BitSet<64>>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 1: BMat<8> + std::vector>" ,
"[quick][020][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<8>> S;
BMat_example1(S);
S.run();
benchmark_BMat_lambda<BMat<8>, std::vector<BitSet<64>>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<8>, std::vector<BitSet<64>>>(
S,
"LambdaBMatAlt1 (using BMat<8>, ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<8>, std::vector<BitSet<64>>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 2: BMat<> + std::vector>" ,
"[quick][008][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<>> S;
BMat_example2(S);
S.run();
benchmark_BMat_lambda<BMat<>, std::vector<BitSet<64>>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<>, std::vector<BitSet<64>>>(
S, "LambdaBMatAlt1 (using BMat<>, ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<>, std::vector<BitSet<64>>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 2: BMat<4> + std::vector>" ,
"[quick][021][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<4>> S;
BMat_example2(S);
S.run();
benchmark_BMat_lambda<BMat<4>, std::vector<BitSet<64>>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<4>, std::vector<BitSet<64>>>(
S,
"LambdaBMatAlt1 (using BMat<4>, ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<4>, std::vector<BitSet<64>>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 1: BMat<> + std::vector>" ,
"[quick][003][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<>> S;
BMat_example1(S);
S.run();
benchmark_BMat_lambda<BMat<>, std::vector<BitSet<8>>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<>, std::vector<BitSet<8>>>(
S, "LambdaBMatAlt1 (using BMat<>, ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<>, std::vector<BitSet<8>>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 1: BMat<8> + std::vector>" ,
"[quick][022][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<8>> S;
BMat_example1(S);
S.run();
benchmark_BMat_lambda<BMat<8>, std::vector<BitSet<8>>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<8>, std::vector<BitSet<8>>>(
S,
"LambdaBMatAlt1 (using BMat<8>, ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<8>, std::vector<BitSet<8>>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 2: BMat<> + std::vector>" ,
"[quick][009][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<>> S;
BMat_example2(S);
S.run();
benchmark_BMat_lambda<BMat<>, std::vector<BitSet<8>>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<>, std::vector<BitSet<8>>>(
S, "LambdaBMatAlt1 (using BMat<>, ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<>, std::vector<BitSet<8>>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 2: BMat<4> + std::vector>" ,
"[quick][023][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<4>> S;
BMat_example2(S);
S.run();
benchmark_BMat_lambda<BMat<4>, std::vector<BitSet<8>>>(
S, "Lambda> (duplicate code)" );
benchmark_BMat_lambda_alt1<BMat<4>, std::vector<BitSet<8>>>(
S,
"LambdaBMatAlt1 (using BMat<4>, ImageRightAction, non-static dummy)" );
benchmark_BMat_lambda_alt2<BMat<4>, std::vector<BitSet<8>>>(
S,
"LambdaBMatAlt2 (using ImageRightAction, static thread_local "
"dummy)" );
}
TEST_CASE("Example 1: Lambda> std::bitset vs BitSet" ,
"[quick][004][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<>> S;
BMat_example1(S);
S.run();
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<BitSet<64>, 64>>(
S, "StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<std::bitset<64>, 64>>(
S, "StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<BitSet<8>, 8>>(
S, "StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<std::bitset<8>, 8>>(
S, "StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<>, std::vector<BitSet<64>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<std::bitset<64>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<BitSet<8>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<std::bitset<8>>>(
S, "std::vector>" );
}
TEST_CASE("Example 1: Lambda> std::bitset vs BitSet" ,
"[quick][024][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<8>> S;
BMat_example1(S);
S.run();
benchmark_BMat_lambda<BMat<8>, detail::StaticVector1<BitSet<64>, 64>>(
S, "StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<8>, detail::StaticVector1<std::bitset<64>, 64>>(
S, "StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<8>, detail::StaticVector1<BitSet<8>, 8>>(
S, "StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<8>, detail::StaticVector1<std::bitset<8>, 8>>(
S, "StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<8>, std::vector<BitSet<64>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<8>, std::vector<std::bitset<64>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<8>, std::vector<BitSet<8>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<8>, std::vector<std::bitset<8>>>(
S, "std::vector>" );
}
TEST_CASE("Example 2: Lambda> std::bitset vs BitSet" ,
"[quick][010][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<>> S;
BMat_example2(S);
S.run();
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<BitSet<64>, 64>>(
S, "StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<std::bitset<64>, 64>>(
S, "StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<BitSet<8>, 8>>(
S, "StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<std::bitset<8>, 8>>(
S, "StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<>, std::vector<BitSet<64>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<std::bitset<64>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<BitSet<8>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<std::bitset<8>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<BitSet<4>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<std::bitset<4>>>(
S, "std::vector>" );
}
TEST_CASE("Example 2: Lambda> std::bitset vs BitSet" ,
"[quick][025][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<4>> S;
BMat_example2(S);
S.run();
benchmark_BMat_lambda<BMat<4>, detail::StaticVector1<BitSet<64>, 64>>(
S, "StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<4>, detail::StaticVector1<std::bitset<64>, 64>>(
S, "StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<4>, detail::StaticVector1<BitSet<8>, 8>>(
S, "StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<4>, detail::StaticVector1<std::bitset<8>, 8>>(
S, "StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<4>, std::vector<BitSet<64>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<4>, std::vector<std::bitset<64>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<4>, std::vector<BitSet<8>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<4>, std::vector<std::bitset<8>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<4>, std::vector<BitSet<4>>>(
S, "std::vector>" );
benchmark_BMat_lambda<BMat<4>, std::vector<std::bitset<4>>>(
S, "std::vector>" );
}
TEST_CASE("Example 1: Lambda> std::bitset, BitSet too small" ,
"[quick][005][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<>> S;
BMat_example1(S);
S.run();
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<std::bitset<128>, 8>>(
S, "StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<>, std::vector<std::bitset<128>>>(
S, "std::vector>" );
}
TEST_CASE("Example 1: Lambda> std::bitset, BitSet too small" ,
"[quick][026][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<8>> S;
BMat_example1(S);
S.run();
benchmark_BMat_lambda<BMat<8>, detail::StaticVector1<std::bitset<128>, 8>>(
S, "StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<8>, std::vector<std::bitset<128>>>(
S, "std::vector>" );
}
TEST_CASE("Example 1: Rho> vs Lambda>" , "[quick][011][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<>> S;
BMat_example1(S);
S.run();
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<BitSet<64>, 64>>(
S, "Lambda + StaticVector1, 64>" );
benchmark_BMat_rho<BMat<>, detail::StaticVector1<BitSet<64>, 64>>(
S, "Rho + StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<std::bitset<64>, 64>>(
S, "Lambda + StaticVector1, 64>" );
benchmark_BMat_rho<BMat<>, detail::StaticVector1<std::bitset<64>, 64>>(
S, "Rho + StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<BitSet<8>, 8>>(
S, "Lambda + StaticVector1, 8>" );
benchmark_BMat_rho<BMat<>, detail::StaticVector1<BitSet<8>, 8>>(
S, "Rho + StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<std::bitset<8>, 8>>(
S, "Lambda + StaticVector1, 8>" );
benchmark_BMat_rho<BMat<>, detail::StaticVector1<std::bitset<8>, 8>>(
S, "Rho + StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<>, std::vector<BitSet<64>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<>, std::vector<BitSet<64>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<std::bitset<64>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<>, std::vector<std::bitset<64>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<BitSet<8>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<>, std::vector<BitSet<8>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<std::bitset<8>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<>, std::vector<std::bitset<8>>>(
S, "Rho + std::vector>" );
}
TEST_CASE("Example 1: Rho> vs Lambda>" ,
"[quick][027][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<8>> S;
BMat_example1(S);
S.run();
benchmark_BMat_lambda<BMat<8>, detail::StaticVector1<BitSet<64>, 64>>(
S, "Lambda + StaticVector1, 64>" );
benchmark_BMat_rho<BMat<8>, detail::StaticVector1<BitSet<64>, 64>>(
S, "Rho + StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<8>, detail::StaticVector1<std::bitset<64>, 64>>(
S, "Lambda + StaticVector1, 64>" );
benchmark_BMat_rho<BMat<8>, detail::StaticVector1<std::bitset<64>, 64>>(
S, "Rho + StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<8>, detail::StaticVector1<BitSet<8>, 8>>(
S, "Lambda + StaticVector1, 8>" );
benchmark_BMat_rho<BMat<8>, detail::StaticVector1<BitSet<8>, 8>>(
S, "Rho + StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<8>, detail::StaticVector1<std::bitset<8>, 8>>(
S, "Lambda + StaticVector1, 8>" );
benchmark_BMat_rho<BMat<8>, detail::StaticVector1<std::bitset<8>, 8>>(
S, "Rho + StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<8>, std::vector<BitSet<64>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<8>, std::vector<BitSet<64>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<8>, std::vector<std::bitset<64>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<8>, std::vector<std::bitset<64>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<8>, std::vector<BitSet<8>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<8>, std::vector<BitSet<8>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<8>, std::vector<std::bitset<8>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<8>, std::vector<std::bitset<8>>>(
S, "Rho + std::vector>" );
}
TEST_CASE("Example 2: Rho> vs Lambda>" , "[quick][012][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<>> S;
BMat_example2(S);
S.run();
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<BitSet<64>, 64>>(
S, "Lambda + StaticVector1, 64>" );
benchmark_BMat_rho<BMat<>, detail::StaticVector1<BitSet<64>, 64>>(
S, "Rho + StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<std::bitset<64>, 64>>(
S, "Lambda + StaticVector1, 64>" );
benchmark_BMat_rho<BMat<>, detail::StaticVector1<std::bitset<64>, 64>>(
S, "Rho + StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<BitSet<8>, 8>>(
S, "Lambda + StaticVector1, 8>" );
benchmark_BMat_rho<BMat<>, detail::StaticVector1<BitSet<8>, 8>>(
S, "Rho + StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<>, detail::StaticVector1<std::bitset<8>, 8>>(
S, "Lambda + StaticVector1, 8>" );
benchmark_BMat_rho<BMat<>, detail::StaticVector1<std::bitset<8>, 8>>(
S, "Rho + StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<>, std::vector<BitSet<64>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<>, std::vector<BitSet<64>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<std::bitset<64>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<>, std::vector<std::bitset<64>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<BitSet<8>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<>, std::vector<BitSet<8>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<std::bitset<8>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<>, std::vector<std::bitset<8>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<BitSet<4>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<>, std::vector<BitSet<4>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<>, std::vector<std::bitset<4>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<>, std::vector<std::bitset<4>>>(
S, "Rho + std::vector>" );
}
TEST_CASE("Example 2: Rho> vs Lambda>" ,
"[quick][028][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<4>> S;
BMat_example2(S);
S.run();
benchmark_BMat_lambda<BMat<4>, detail::StaticVector1<BitSet<64>, 64>>(
S, "Lambda + StaticVector1, 64>" );
benchmark_BMat_rho<BMat<4>, detail::StaticVector1<BitSet<64>, 64>>(
S, "Rho + StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<4>, detail::StaticVector1<std::bitset<64>, 64>>(
S, "Lambda + StaticVector1, 64>" );
benchmark_BMat_rho<BMat<4>, detail::StaticVector1<std::bitset<64>, 64>>(
S, "Rho + StaticVector1, 64>" );
benchmark_BMat_lambda<BMat<4>, detail::StaticVector1<BitSet<8>, 8>>(
S, "Lambda + StaticVector1, 8>" );
benchmark_BMat_rho<BMat<4>, detail::StaticVector1<BitSet<8>, 8>>(
S, "Rho + StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<4>, detail::StaticVector1<std::bitset<8>, 8>>(
S, "Lambda + StaticVector1, 8>" );
benchmark_BMat_rho<BMat<4>, detail::StaticVector1<std::bitset<8>, 8>>(
S, "Rho + StaticVector1, 8>" );
benchmark_BMat_lambda<BMat<4>, std::vector<BitSet<64>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<4>, std::vector<BitSet<64>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<4>, std::vector<std::bitset<64>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<4>, std::vector<std::bitset<64>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<4>, std::vector<BitSet<8>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<4>, std::vector<BitSet<8>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<4>, std::vector<std::bitset<8>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<4>, std::vector<std::bitset<8>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<4>, std::vector<BitSet<4>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<4>, std::vector<BitSet<4>>>(
S, "Rho + std::vector>" );
benchmark_BMat_lambda<BMat<4>, std::vector<std::bitset<4>>>(
S, "Lambda + std::vector>" );
benchmark_BMat_rho<BMat<4>, std::vector<std::bitset<4>>>(
S, "Rho + std::vector>" );
}
TEST_CASE("Example 4: BMat<> (dim = 8), rank" , "[quick][015][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<>> S;
BMat_example1(S);
S.run();
REQUIRE(S.size() == 255);
std::vector<BMat<>> gens = {BMat<>({{1, 0, 0, 0, 0, 0, 0, 0},
{0, 1, 0, 0, 0, 0, 0, 0},
{0, 0, 1, 0, 0, 0, 0, 0},
{0, 0, 0, 1, 0, 0, 0, 0},
{0, 0, 0, 0, 1, 0, 0, 0},
{0, 0, 0, 0, 0, 0, 1, 0},
{0, 0, 0, 0, 0, 0, 0, 1},
{0, 0, 0, 0, 0, 1, 0, 0}}),
BMat<>({{0, 1, 0, 1, 0, 1, 0, 0},
{0, 1, 1, 0, 1, 1, 0, 0},
{1, 0, 1, 1, 0, 0, 0, 0},
{0, 1, 0, 0, 1, 0, 0, 0},
{0, 0, 1, 0, 0, 1, 0, 0},
{0, 1, 0, 1, 1, 0, 0, 0},
{1, 0, 0, 0, 0, 0, 0, 0},
{0, 0, 0, 0, 0, 0, 0, 0}}),
BMat<>({{0, 1, 0, 1, 0, 1, 0, 0},
{1, 0, 1, 0, 0, 1, 0, 0},
{1, 0, 1, 1, 0, 1, 0, 0},
{0, 0, 1, 0, 1, 0, 0, 0},
{1, 1, 0, 1, 0, 1, 0, 0},
{0, 1, 0, 1, 0, 1, 0, 0},
{0, 0, 0, 0, 0, 0, 0, 0},
{0, 0, 0, 0, 0, 0, 0, 0}})};
BENCHMARK("row space size" ) {
for (auto it = S.cbegin(); it < S.cend(); ++it) {
Rank<BMat<>, void >()(*it);
}
};
BENCHMARK("transformation rank" ) {
RankState<BMat<>> st(gens.cbegin(), gens.cend());
for (auto it = S.cbegin(); it < S.cend(); ++it) {
Rank<BMat<>>()(st, *it);
}
};
}
TEST_CASE("Example 4: BMat<8> (dim = 8), rank" , "[quick][029][bmat]" ) {
auto rg = ReportGuard(false );
FroidurePin<BMat<8>> S;
BMat_example1(S);
S.run();
REQUIRE(S.size() == 255);
std::vector<BMat<8>> gens = {BMat<8>({{1, 0, 0, 0, 0, 0, 0, 0},
{0, 1, 0, 0, 0, 0, 0, 0},
{0, 0, 1, 0, 0, 0, 0, 0},
{0, 0, 0, 1, 0, 0, 0, 0},
{0, 0, 0, 0, 1, 0, 0, 0},
{0, 0, 0, 0, 0, 0, 1, 0},
{0, 0, 0, 0, 0, 0, 0, 1},
{0, 0, 0, 0, 0, 1, 0, 0}}),
BMat<8>({{0, 1, 0, 1, 0, 1, 0, 0},
{0, 1, 1, 0, 1, 1, 0, 0},
{1, 0, 1, 1, 0, 0, 0, 0},
{0, 1, 0, 0, 1, 0, 0, 0},
{0, 0, 1, 0, 0, 1, 0, 0},
{0, 1, 0, 1, 1, 0, 0, 0},
{1, 0, 0, 0, 0, 0, 0, 0},
{0, 0, 0, 0, 0, 0, 0, 0}}),
BMat<8>({{0, 1, 0, 1, 0, 1, 0, 0},
{1, 0, 1, 0, 0, 1, 0, 0},
{1, 0, 1, 1, 0, 1, 0, 0},
{0, 0, 1, 0, 1, 0, 0, 0},
{1, 1, 0, 1, 0, 1, 0, 0},
{0, 1, 0, 1, 0, 1, 0, 0},
{0, 0, 0, 0, 0, 0, 0, 0},
{0, 0, 0, 0, 0, 0, 0, 0}})};
BENCHMARK("row space size" ) {
for (auto it = S.cbegin(); it < S.cend(); ++it) {
Rank<BMat<8>, void >()(*it);
}
};
BENCHMARK("transformation rank" ) {
RankState<BMat<8>> st(gens.cbegin(), gens.cend());
for (auto it = S.cbegin(); it < S.cend(); ++it) {
Rank<BMat<8>>()(st, *it);
}
};
}
////////////////////////////////////////////////////////////////////////
// The actual benchmarks for Transformations
////////////////////////////////////////////////////////////////////////
TEST_CASE("Example 3: transformations, rho" , "[quick][013][transf]" ) {
auto rg = ReportGuard(false );
FroidurePin<Transf<>> S;
transf_example1(S);
S.run();
REQUIRE(S.size() == 597369);
benchmark_transf_rho<detail::StaticVector1<size_t, 64>>(
S, "Rho, detail::StaticVector1" );
benchmark_transf_rho<detail::StaticVector1<size_t, 8>>(
S, "Rho, detail::StaticVector1" );
benchmark_transf_rho<std::vector<size_t>>(
S, "Rho, std::vector" );
}
TEST_CASE("Example 3: transformations, lambda" , "[quick][014][transf]" ) {
auto rg = ReportGuard(false );
FroidurePin<Transf<>> S;
transf_example1(S);
S.run();
REQUIRE(S.size() == 597369);
benchmark_transf_lambda<detail::StaticVector1<size_t, 64>>(
S, "Lambda, detail::StaticVector1" );
benchmark_transf_lambda<detail::StaticVector1<size_t, 8>>(
S, "Lambda, detail::StaticVector1" );
benchmark_transf_lambda<std::vector<size_t>>(
S, "Lambda, std::vector" );
benchmark_transf_lambda<BitSet<64>>(S, "Lambda, BitSet<64>" );
}
} // namespace libsemigroups
quality 90%
¤ Dauer der Verarbeitung: 0.16 Sekunden
(vorverarbeitet)
¤
*© Formatika GbR, Deutschland