From 7f19d641647ac4ef313ed88d6b5c140983ce5436 Mon Sep 17 00:00:00 2001 From: Vincent Ambo Date: Wed, 15 Jul 2020 08:20:18 +0100 Subject: Squashed 'third_party/immer/' content from commit ad3e3556d git-subtree-dir: third_party/immer git-subtree-split: ad3e3556d38bb75966dd24c61a774970a7c7957e --- benchmark/vector/misc/drop.cpp | 63 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 63 insertions(+) create mode 100644 benchmark/vector/misc/drop.cpp (limited to 'benchmark/vector/misc/drop.cpp') diff --git a/benchmark/vector/misc/drop.cpp b/benchmark/vector/misc/drop.cpp new file mode 100644 index 000000000000..c2ca48390b13 --- /dev/null +++ b/benchmark/vector/misc/drop.cpp @@ -0,0 +1,63 @@ +// +// immer: immutable data structures for C++ +// Copyright (C) 2016, 2017, 2018 Juan Pedro Bolivar Puente +// +// This software is distributed under the Boost Software License, Version 1.0. +// See accompanying file LICENSE or copy at http://boost.org/LICENSE_1_0.txt +// + +#include "benchmark/vector/drop.hpp" + +#include +#include +#include +#include +#include + +#if IMMER_BENCHMARK_LIBRRB +extern "C" { +#define restrict __restrict__ +#include +#undef restrict +} +#endif + +#if IMMER_BENCHMARK_LIBRRB +NONIUS_BENCHMARK("librrb", benchmark_drop_librrb(make_librrb_vector)) +NONIUS_BENCHMARK("librrb/F", benchmark_drop_librrb(make_librrb_vector_f)) +NONIUS_BENCHMARK("l/librrb", benchmark_drop_lin_librrb(make_librrb_vector)) +NONIUS_BENCHMARK("l/librrb/F", benchmark_drop_lin_librrb(make_librrb_vector_f)) +NONIUS_BENCHMARK("t/librrb", benchmark_drop_mut_librrb(make_librrb_vector)) +NONIUS_BENCHMARK("t/librrb/F", benchmark_drop_mut_librrb(make_librrb_vector_f)) +#endif + +NONIUS_BENCHMARK("flex/4B", benchmark_drop>()) +NONIUS_BENCHMARK("flex/5B", benchmark_drop>()) +NONIUS_BENCHMARK("flex/6B", benchmark_drop>()) +NONIUS_BENCHMARK("flex/GC", benchmark_drop>()) +NONIUS_BENCHMARK("flex/NO", benchmark_drop>()) +NONIUS_BENCHMARK("flex/UN", benchmark_drop>()) +NONIUS_BENCHMARK("flex_s/GC", benchmark_drop>()) + +NONIUS_BENCHMARK("flex/F/5B", benchmark_drop, push_front_fn>()) +NONIUS_BENCHMARK("flex/F/GC", benchmark_drop, push_front_fn>()) +NONIUS_BENCHMARK("flex/F/GCF", benchmark_drop, push_front_fn>()) +NONIUS_BENCHMARK("flex_s/F/GC", benchmark_drop, push_front_fn>()) + +NONIUS_BENCHMARK("l/flex/5B", benchmark_drop_lin>()) +NONIUS_BENCHMARK("l/flex/GC", benchmark_drop_lin>()) +NONIUS_BENCHMARK("l/flex/NO", benchmark_drop_lin>()) +NONIUS_BENCHMARK("l/flex/UN", benchmark_drop_lin>()) +NONIUS_BENCHMARK("l/flex/F/5B", benchmark_drop_lin, push_front_fn>()) + +NONIUS_BENCHMARK("m/flex/5B", benchmark_drop_move>()) +NONIUS_BENCHMARK("m/flex/GC", benchmark_drop_move>()) +NONIUS_BENCHMARK("m/flex/NO", benchmark_drop_move>()) +NONIUS_BENCHMARK("m/flex/UN", benchmark_drop_move>()) +NONIUS_BENCHMARK("m/flex/F/5B", benchmark_drop_move, push_front_fn>()) + +NONIUS_BENCHMARK("t/flex/5B", benchmark_drop_mut>()) +NONIUS_BENCHMARK("t/flex/GC", benchmark_drop_mut>()) +NONIUS_BENCHMARK("t/flex/NO", benchmark_drop_mut>()) +NONIUS_BENCHMARK("t/flex/UN", benchmark_drop_mut>()) +NONIUS_BENCHMARK("t/flex/F/5B", benchmark_drop_mut, push_front_fn>()) -- cgit 1.4.1