NAME Bencher::Scenario::Scalar::Util::Numeric - Benchmark Scalar::Util::Numeric vs Scalar::Util::Numeric::PP VERSION This document describes version 0.021 of Bencher::Scenario::Scalar::Util::Numeric (from Perl distribution Bencher-Scenario-Scalar-Util-Numeric), released on 2023-01-17. SYNOPSIS To run benchmark with default option: % bencher -m Scalar::Util::Numeric To run module startup overhead benchmark: % bencher --module-startup -m Scalar::Util::Numeric 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. Scalar::Util::Numeric::PP 0.04 Scalar::Util::Numeric 0.40 BENCHMARK PARTICIPANTS * isint-int-pp (perl_code) [pp, func:isint] Function call template: Scalar::Util::Numeric::PP::isint(1) * isint-str-pp (perl_code) [pp, func:isint] Function call template: Scalar::Util::Numeric::PP::isint('a') * isint-float-pp (perl_code) [pp, func:isint] Function call template: Scalar::Util::Numeric::PP::isint(1.23) * isfloat-int-pp (perl_code) [pp, func:isfloat] Function call template: Scalar::Util::Numeric::PP::isfloat(1) * isfloat-str-pp (perl_code) [pp, func:isfloat] Function call template: Scalar::Util::Numeric::PP::isfloat('a') * isfloat-float-pp (perl_code) [pp, func:isfloat] Function call template: Scalar::Util::Numeric::PP::isfloat(1.23) * isnum-int-pp (perl_code) [pp, func:isnum] Function call template: Scalar::Util::Numeric::PP::isnum(1) * isnum-str-pp (perl_code) [pp, func:isnum] Function call template: Scalar::Util::Numeric::PP::isnum('a') * isnum-float-pp (perl_code) [pp, func:isnum] Function call template: Scalar::Util::Numeric::PP::isnum(1.23) * isint-int-xs (perl_code) [xs, func:isint] Function call template: Scalar::Util::Numeric::isint(1) * isint-str-xs (perl_code) [xs, func:isint] Function call template: Scalar::Util::Numeric::isint('a') * isint-float-xs (perl_code) [xs, func:isint] Function call template: Scalar::Util::Numeric::isint(1.23) * isfloat-int-xs (perl_code) [xs, func:isfloat] Function call template: Scalar::Util::Numeric::isfloat(1) * isfloat-str-xs (perl_code) [xs, func:isfloat] Function call template: Scalar::Util::Numeric::isfloat('a') * isfloat-float-xs (perl_code) [xs, func:isfloat] Function call template: Scalar::Util::Numeric::isfloat(1.23) * isnum-int-xs (perl_code) [xs, func:isnum] Function call template: Scalar::Util::Numeric::isnum(1) * isnum-str-xs (perl_code) [xs, func:isnum] Function call template: Scalar::Util::Numeric::isnum('a') * isnum-float-xs (perl_code) [xs, func:isnum] Function call template: Scalar::Util::Numeric::isnum(1.23) 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 Scalar::Util::Numeric"): #table1# +------------------+------------------+-----------+-----------+-----------------------+-----------------------+---------+---------+ | participant | p_tags | rate (/s) | time (μs) | pct_faster_vs_slowest | pct_slower_vs_fastest | errors | samples | +------------------+------------------+-----------+-----------+-----------------------+-----------------------+---------+---------+ | isnum-float-pp | pp, func:isnum | 490000 | 2 | 0.00% | 4111.51% | 3.3e-09 | 20 | | isnum-str-pp | pp, func:isnum | 615800 | 1.624 | 25.70% | 3250.31% | 2.2e-11 | 20 | | isfloat-int-pp | pp, func:isfloat | 860000 | 1.2 | 75.96% | 2293.38% | 1.6e-09 | 22 | | isfloat-float-pp | pp, func:isfloat | 1030000 | 0.971 | 110.29% | 1902.76% | 3.9e-10 | 23 | | isfloat-str-pp | pp, func:isfloat | 1087000 | 0.9202 | 121.86% | 1798.31% | 2.2e-11 | 20 | | isint-float-pp | pp, func:isint | 1297000 | 0.7712 | 164.70% | 1491.08% | 4.6e-11 | 20 | | isnum-int-pp | pp, func:isnum | 1577000 | 0.6342 | 221.91% | 1208.27% | 2.3e-11 | 20 | | isint-int-pp | pp, func:isint | 2200000 | 0.45 | 352.58% | 830.55% | 8.3e-10 | 20 | | isint-float-xs | xs, func:isint | 2734000 | 0.3658 | 458.12% | 654.58% | 2.2e-11 | 20 | | isnum-float-xs | xs, func:isnum | 2735000 | 0.3656 | 458.41% | 654.20% | 2.1e-11 | 20 | | isfloat-float-xs | xs, func:isfloat | 2738000 | 0.3653 | 458.86% | 653.59% | 2.9e-11 | 20 | | isint-str-pp | pp, func:isint | 2980000 | 0.336 | 508.04% | 592.64% | 1.1e-10 | 20 | | isint-str-xs | xs, func:isint | 17000000 | 0.059 | 3383.67% | 20.89% | 2.1e-10 | 20 | | isnum-str-xs | xs, func:isnum | 18000000 | 0.057 | 3491.02% | 17.28% | 2.1e-10 | 20 | | isfloat-str-xs | xs, func:isfloat | 18000000 | 0.054 | 3667.33% | 11.79% | 1.2e-10 | 20 | | isnum-int-xs | xs, func:isnum | 19000000 | 0.052 | 3805.01% | 7.85% | 2.1e-10 | 20 | | isfloat-int-xs | xs, func:isfloat | 19000000 | 0.052 | 3845.40% | 6.74% | 2.1e-10 | 20 | | isint-int-xs | xs, func:isint | 21000000 | 0.048 | 4111.51% | 0.00% | 3.4e-10 | 20 | +------------------+------------------+-----------+-----------+-----------------------+-----------------------+---------+---------+ Formatted as Benchmark.pm result: Rate i pp, func:isnum i pp, func:isnum i pp, func:isfloat i pp, func:isfloat i pp, func:isfloat i pp, func:isint i pp, func:isnum i pp, func:isint i xs, func:isint i xs, func:isnum i xs, func:isfloat i pp, func:isint i xs, func:isint i xs, func:isnum i xs, func:isfloat i xs, func:isnum i xs, func:isfloat i xs, func:isint i pp, func:isnum 490000/s -- -18% -40% -51% -53% -61% -68% -77% -81% -81% -81% -83% -97% -97% -97% -97% -97% -97% i pp, func:isnum 615800/s 23% -- -26% -40% -43% -52% -60% -72% -77% -77% -77% -79% -96% -96% -96% -96% -96% -97% i pp, func:isfloat 860000/s 66% 35% -- -19% -23% -35% -47% -62% -69% -69% -69% -72% -95% -95% -95% -95% -95% -96% i pp, func:isfloat 1030000/s 105% 67% 23% -- -5% -20% -34% -53% -62% -62% -62% -65% -93% -94% -94% -94% -94% -95% i pp, func:isfloat 1087000/s 117% 76% 30% 5% -- -16% -31% -51% -60% -60% -60% -63% -93% -93% -94% -94% -94% -94% i pp, func:isint 1297000/s 159% 110% 55% 25% 19% -- -17% -41% -52% -52% -52% -56% -92% -92% -92% -93% -93% -93% i pp, func:isnum 1577000/s 215% 156% 89% 53% 45% 21% -- -29% -42% -42% -42% -47% -90% -91% -91% -91% -91% -92% i pp, func:isint 2200000/s 344% 260% 166% 115% 104% 71% 40% -- -18% -18% -18% -25% -86% -87% -88% -88% -88% -89% i xs, func:isint 2734000/s 446% 343% 228% 165% 151% 110% 73% 23% -- 0% 0% -8% -83% -84% -85% -85% -85% -86% i xs, func:isnum 2735000/s 447% 344% 228% 165% 151% 110% 73% 23% 0% -- 0% -8% -83% -84% -85% -85% -85% -86% i xs, func:isfloat 2738000/s 447% 344% 228% 165% 151% 111% 73% 23% 0% 0% -- -8% -83% -84% -85% -85% -85% -86% i pp, func:isint 2980000/s 495% 383% 257% 188% 173% 129% 88% 33% 8% 8% 8% -- -82% -83% -83% -84% -84% -85% i xs, func:isint 17000000/s 3289% 2652% 1933% 1545% 1459% 1207% 974% 662% 520% 519% 519% 469% -- -3% -8% -11% -11% -18% i xs, func:isnum 18000000/s 3408% 2749% 2005% 1603% 1514% 1252% 1012% 689% 541% 541% 540% 489% 3% -- -5% -8% -8% -15% i xs, func:isfloat 18000000/s 3603% 2907% 2122% 1698% 1604% 1328% 1074% 733% 577% 577% 576% 522% 9% 5% -- -3% -3% -11% i xs, func:isnum 19000000/s 3746% 3023% 2207% 1767% 1669% 1383% 1119% 765% 603% 603% 602% 546% 13% 9% 3% -- 0% -7% i xs, func:isfloat 19000000/s 3746% 3023% 2207% 1767% 1669% 1383% 1119% 765% 603% 603% 602% 546% 13% 9% 3% 0% -- -7% i xs, func:isint 21000000/s 4066% 3283% 2400% 1922% 1817% 1506% 1221% 837% 662% 661% 661% 600% 22% 18% 12% 8% 8% -- Legends: i pp, func:isfloat: p_tags=pp, func:isfloat participant=isfloat-str-pp i pp, func:isint: p_tags=pp, func:isint participant=isint-str-pp i pp, func:isnum: p_tags=pp, func:isnum participant=isnum-int-pp i xs, func:isfloat: p_tags=xs, func:isfloat participant=isfloat-int-xs i xs, func:isint: p_tags=xs, func:isint participant=isint-int-xs i xs, func:isnum: p_tags=xs, func:isnum participant=isnum-int-xs Benchmark module startup overhead ("bencher -m Scalar::Util::Numeric --module-startup"): #table2# +---------------------------+-----------+-------------------+-----------------------+-----------------------+---------+---------+ | participant | time (ms) | mod_overhead_time | pct_faster_vs_slowest | pct_slower_vs_fastest | errors | samples | +---------------------------+-----------+-------------------+-----------------------+-----------------------+---------+---------+ | Scalar::Util::Numeric | 11 | 4.4 | 0.00% | 63.80% | 6.1e-05 | 21 | | Scalar::Util::Numeric::PP | 9.8 | 3.2 | 11.43% | 47.01% | 2.9e-05 | 20 | | perl -e1 (baseline) | 6.6 | 0 | 63.80% | 0.00% | 3.6e-05 | 21 | +---------------------------+-----------+-------------------+-----------------------+-----------------------+---------+---------+ Formatted as Benchmark.pm result: Rate SU:N SUN:P perl -e1 (baseline) SU:N 90.9/s -- -10% -40% SUN:P 102.0/s 12% -- -32% perl -e1 (baseline) 151.5/s 66% 48% -- Legends: SU:N: mod_overhead_time=4.4 participant=Scalar::Util::Numeric SUN:P: mod_overhead_time=3.2 participant=Scalar::Util::Numeric::PP 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-Scalar-Util-Numeric>. SOURCE Source repository is at <https://github.com/perlancar/perl-Bencher-Scenario-Scalar-Util-Numeric> . 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 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-Scal ar-Util-Numeric> 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.