NAME Bencher::Scenario::Sort::BySpec - Benchmark Sort::BySpec (e.g. against Sort::ByExample, etc) VERSION This document describes version 0.041 of Bencher::Scenario::Sort::BySpec (from Perl distribution Bencher-Scenario-Sort-BySpec), released on 2023-01-17. SYNOPSIS To run benchmark with default option: % bencher -m Sort::BySpec To run module startup overhead benchmark: % bencher --module-startup -m Sort::BySpec For more options (dump scenario, list/include/exclude/add participants, list/include/exclude/add datasets, etc), see bencher or run "bencher --help". DESCRIPTION Packaging a benchmark script as a Bencher scenario makes it convenient to include/exclude/add participants/datasets (either via CLI or Perl code), send the result to a central repository, among others . See Bencher and bencher (CLI) for more details. BENCHMARKED MODULES Version numbers shown below are the versions used when running the sample benchmark. Sort::ByExample 0.007 Sort::BySpec 0.040 BENCHMARK PARTICIPANTS * gen_sorter-sbe (perl_code) [gen_sorter, sbe] Code template: Sort::ByExample::sbe(<spec>) * gen_sorter-sbs (perl_code) [gen_sorter, sbs] Code template: Sort::BySpec::sort_by_spec(spec => <spec>) * sort-sbe (perl_code) [sort, sbe] Code template: state $sorter = Sort::ByExample::sbe(<spec>); [$sorter->(@{<list>})] * sort-sbs (perl_code) [sort, sbs] Code template: state $sorter = Sort::BySpec::sort_by_spec(spec => <spec>); [$sorter->(@{<list>})] BENCHMARK DATASETS * eg-num5-list10 * eg-num5-list100 * eg-num5-list1000 SAMPLE BENCHMARK RESULTS Run on: perl: *v5.34.0*, CPU: *Intel(R) Core(TM) i5-7200U CPU @ 2.50GHz (2 cores)*, OS: *GNU/Linux Ubuntu version 20.04*, OS kernel: *Linux version 5.4.0-91-generic*. Benchmark with default options ("bencher -m Sort::BySpec"): #table1# +----------------+------------------+-----------------+-----------+-----------+-----------------------+-----------------------+---------+---------+ | participant | dataset | p_tags | rate (/s) | time (ms) | pct_faster_vs_slowest | pct_slower_vs_fastest | errors | samples | +----------------+------------------+-----------------+-----------+-----------+-----------------------+-----------------------+---------+---------+ | sort-sbs | eg-num5-list1000 | sort, sbs | 250 | 4 | 0.00% | 112867.98% | 6.2e-06 | 20 | | sort-sbe | eg-num5-list1000 | sort, sbe | 2590 | 0.386 | 930.03% | 10867.49% | 2.1e-07 | 20 | | sort-sbs | eg-num5-list100 | sort, sbs | 2620 | 0.382 | 942.00% | 10741.48% | 2.1e-07 | 21 | | sort-sbe | eg-num5-list100 | sort, sbe | 24300 | 0.0411 | 9578.23% | 1067.24% | 1.3e-08 | 22 | | sort-sbs | eg-num5-list10 | sort, sbs | 34600 | 0.0289 | 13652.82% | 721.42% | 1.3e-08 | 20 | | sort-sbe | eg-num5-list10 | sort, sbe | 121000 | 0.00826 | 48030.83% | 134.71% | 3.3e-09 | 20 | | gen_sorter-sbe | eg-num5-list1000 | gen_sorter, sbe | 220000 | 0.0046 | 85838.15% | 31.45% | 6.7e-09 | 20 | | gen_sorter-sbe | eg-num5-list10 | gen_sorter, sbe | 220000 | 0.0046 | 87069.76% | 29.60% | 6.5e-09 | 21 | | gen_sorter-sbe | eg-num5-list100 | gen_sorter, sbe | 220000 | 0.0045 | 87927.99% | 28.33% | 5e-09 | 20 | | gen_sorter-sbs | eg-num5-list100 | gen_sorter, sbs | 283000 | 0.00353 | 112526.73% | 0.30% | 1.7e-09 | 20 | | gen_sorter-sbs | eg-num5-list10 | gen_sorter, sbs | 283860 | 0.0035229 | 112801.80% | 0.06% | 1.5e-11 | 20 | | gen_sorter-sbs | eg-num5-list1000 | gen_sorter, sbs | 284030 | 0.0035208 | 112867.98% | 0.00% | 1.5e-11 | 24 | +----------------+------------------+-----------------+-----------+-----------+-----------------------+-----------------------+---------+---------+ Formatted as Benchmark.pm result: Rate s sort, sbs eg-num5-list1000 s sort, sbe eg-num5-list1000 s sort, sbs eg-num5-list100 s sort, sbe eg-num5-list100 s sort, sbs eg-num5-list10 s sort, sbe eg-num5-list10 g_s gen_sorter, sbe eg-num5-list1000 g_s gen_sorter, sbe eg-num5-list10 g_s gen_sorter, sbe eg-num5-list100 g_s gen_sorter, sbs eg-num5-list100 g_s gen_sorter, sbs eg-num5-list10 g_s gen_sorter, sbs eg-num5-list1000 s sort, sbs eg-num5-list1000 250/s -- -90% -90% -98% -99% -99% -99% -99% -99% -99% -99% -99% s sort, sbe eg-num5-list1000 2590/s 936% -- -1% -89% -92% -97% -98% -98% -98% -99% -99% -99% s sort, sbs eg-num5-list100 2620/s 947% 1% -- -89% -92% -97% -98% -98% -98% -99% -99% -99% s sort, sbe eg-num5-list100 24300/s 9632% 839% 829% -- -29% -79% -88% -88% -89% -91% -91% -91% s sort, sbs eg-num5-list10 34600/s 13740% 1235% 1221% 42% -- -71% -84% -84% -84% -87% -87% -87% s sort, sbe eg-num5-list10 121000/s 48326% 4573% 4524% 397% 249% -- -44% -44% -45% -57% -57% -57% g_s gen_sorter, sbe eg-num5-list1000 220000/s 86856% 8291% 8204% 793% 528% 79% -- 0% -2% -23% -23% -23% g_s gen_sorter, sbe eg-num5-list10 220000/s 86856% 8291% 8204% 793% 528% 79% 0% -- -2% -23% -23% -23% g_s gen_sorter, sbe eg-num5-list100 220000/s 88788% 8477% 8388% 813% 542% 83% 2% 2% -- -21% -21% -21% g_s gen_sorter, sbs eg-num5-list100 283000/s 113214% 10834% 10721% 1064% 718% 133% 30% 30% 27% -- 0% 0% g_s gen_sorter, sbs eg-num5-list10 283860/s 113442% 10856% 10743% 1066% 720% 134% 30% 30% 27% 0% -- 0% g_s gen_sorter, sbs eg-num5-list1000 284030/s 113510% 10863% 10749% 1067% 720% 134% 30% 30% 27% 0% 0% -- Legends: g_s gen_sorter, sbe eg-num5-list10: dataset=eg-num5-list10 p_tags=gen_sorter, sbe participant=gen_sorter-sbe g_s gen_sorter, sbe eg-num5-list100: dataset=eg-num5-list100 p_tags=gen_sorter, sbe participant=gen_sorter-sbe g_s gen_sorter, sbe eg-num5-list1000: dataset=eg-num5-list1000 p_tags=gen_sorter, sbe participant=gen_sorter-sbe g_s gen_sorter, sbs eg-num5-list10: dataset=eg-num5-list10 p_tags=gen_sorter, sbs participant=gen_sorter-sbs g_s gen_sorter, sbs eg-num5-list100: dataset=eg-num5-list100 p_tags=gen_sorter, sbs participant=gen_sorter-sbs g_s gen_sorter, sbs eg-num5-list1000: dataset=eg-num5-list1000 p_tags=gen_sorter, sbs participant=gen_sorter-sbs s sort, sbe eg-num5-list10: dataset=eg-num5-list10 p_tags=sort, sbe participant=sort-sbe s sort, sbe eg-num5-list100: dataset=eg-num5-list100 p_tags=sort, sbe participant=sort-sbe s sort, sbe eg-num5-list1000: dataset=eg-num5-list1000 p_tags=sort, sbe participant=sort-sbe s sort, sbs eg-num5-list10: dataset=eg-num5-list10 p_tags=sort, sbs participant=sort-sbs s sort, sbs eg-num5-list100: dataset=eg-num5-list100 p_tags=sort, sbs participant=sort-sbs s sort, sbs eg-num5-list1000: dataset=eg-num5-list1000 p_tags=sort, sbs participant=sort-sbs Benchmark module startup overhead ("bencher -m Sort::BySpec --module-startup"): #table2# +---------------------+-----------+-------------------+-----------------------+-----------------------+---------+---------+ | participant | time (ms) | mod_overhead_time | pct_faster_vs_slowest | pct_slower_vs_fastest | errors | samples | +---------------------+-----------+-------------------+-----------------------+-----------------------+---------+---------+ | Sort::ByExample | 19 | 12 | 0.00% | 192.74% | 5.5e-05 | 22 | | Sort::BySpec | 9.8 | 2.8 | 96.39% | 49.07% | 7.2e-05 | 20 | | perl -e1 (baseline) | 7 | 0 | 192.74% | 0.00% | 7e-05 | 21 | +---------------------+-----------+-------------------+-----------------------+-----------------------+---------+---------+ Formatted as Benchmark.pm result: Rate Sort::ByExample Sort::BySpec perl -e1 (baseline) Sort::ByExample 52.6/s -- -48% -63% Sort::BySpec 102.0/s 93% -- -28% perl -e1 (baseline) 142.9/s 171% 40% -- Legends: Sort::ByExample: mod_overhead_time=12 participant=Sort::ByExample Sort::BySpec: mod_overhead_time=2.8 participant=Sort::BySpec perl -e1 (baseline): mod_overhead_time=0 participant=perl -e1 (baseline) To display as an interactive HTML table on a browser, you can add option "--format html+datatables". HOMEPAGE Please visit the project's homepage at <https://metacpan.org/release/Bencher-Scenario-Sort-BySpec>. SOURCE Source repository is at <https://github.com/perlancar/perl-Bencher-Scenario-Sort-BySpec>. AUTHOR perlancar <perlancar@cpan.org> CONTRIBUTING To contribute, you can send patches by email/via RT, or send pull requests on GitHub. Most of the time, you don't need to build the distribution yourself. You can simply modify the code, then test via: % prove -l If you want to build the distribution (e.g. to try to install it locally on your system), you can install Dist::Zilla, Dist::Zilla::PluginBundle::Author::PERLANCAR, Pod::Weaver::PluginBundle::Author::PERLANCAR, and sometimes one or two other Dist::Zilla- and/or Pod::Weaver plugins. Any additional steps required beyond that are considered a bug and can be reported to me. COPYRIGHT AND LICENSE This software is copyright (c) 2023, 2017, 2016, 2015 by perlancar <perlancar@cpan.org>. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself. BUGS Please report any bugs or feature requests on the bugtracker website <https://rt.cpan.org/Public/Dist/Display.html?Name=Bencher-Scenario-Sort -BySpec> When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature.