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.