NAME
Bencher::Scenario::Data::Cmp - Benchmark Data::Cmp against similar solutions
VERSION
This document describes version 0.002 of Bencher::Scenario::Data::Cmp (from Perl distribution Bencher-Scenario-Data-Cmp), released on 2022-03-19.
SYNOPSIS
To run benchmark with default option:
% bencher -m Data::Cmp
To run module startup overhead benchmark:
% bencher --module-startup -m Data::Cmp
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.
Data::Cmp 0.007
Data::Cmp::Numeric 0.007
Data::Cmp::StrOrNumeric 0.007
JSON::PP 4.06
Data::Compare 1.27
BENCHMARK PARTICIPANTS
Data::Cmp::cmp_data (perl_code)
Function call template:
Data::Cmp::cmp_data(<data1>, <data2>)
Data::Cmp::Numeric::cmp_data (perl_code)
Function call template:
Data::Cmp::Numeric::cmp_data(<data1>, <data2>)
Data::Cmp::StrOrNumeric::cmp_data (perl_code)
Function call template:
Data::Cmp::StrOrNumeric::cmp_data(<data1>, <data2>)
JSON::PP (perl_code)
Code template:
JSON::PP::encode_json(<data1>) eq JSON::PP::encode_json(<data2>)
Data::Compare::Compare (perl_code)
Function call template:
Data::Compare::Compare(<data1>, <data2>)
BENCHMARK DATASETS
empty arrays
small arrays
1k array of ints
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 Data::Cmp
):
#table1#
+-----------------------------------+------------------+-----------+------------+-----------------------+-----------------------+---------+---------+
| participant | dataset | rate (/s) | time (ms) | pct_faster_vs_slowest | pct_slower_vs_fastest | errors | samples |
+-----------------------------------+------------------+-----------+------------+-----------------------+-----------------------+---------+---------+
| Data::Compare::Compare | 1k array of ints | 410 | 2.4 | 0.00% | 114055.54% | 5.2e-06 | 21 |
| JSON::PP | 1k array of ints | 525 | 1.91 | 26.97% | 89810.83% | 4.3e-07 | 20 |
| Data::Cmp::StrOrNumeric::cmp_data | 1k array of ints | 1120 | 0.892 | 171.26% | 41983.64% | 2.1e-07 | 20 |
| Data::Cmp::Numeric::cmp_data | 1k array of ints | 1470 | 0.682 | 254.94% | 32062.07% | 2.5e-07 | 22 |
| Data::Cmp::cmp_data | 1k array of ints | 1480 | 0.676 | 257.77% | 31807.86% | 2.1e-07 | 20 |
| Data::Compare::Compare | small arrays | 45000 | 0.022 | 10722.71% | 954.78% | 2.7e-08 | 20 |
| JSON::PP | small arrays | 65344.2 | 0.0153036 | 15713.54% | 621.88% | 0 | 20 |
| Data::Cmp::StrOrNumeric::cmp_data | small arrays | 137000 | 0.00732 | 32945.76% | 245.45% | 3.1e-09 | 23 |
| Data::Cmp::Numeric::cmp_data | small arrays | 150669 | 0.00663705 | 36362.51% | 213.08% | 0 | 20 |
| Data::Cmp::cmp_data | small arrays | 150000 | 0.0066 | 36518.71% | 211.74% | 1e-08 | 20 |
| Data::Compare::Compare | empty arrays | 200000 | 0.005 | 48614.60% | 134.34% | 6.7e-09 | 20 |
| JSON::PP | empty arrays | 223767 | 0.00446893 | 54052.50% | 110.80% | 0 | 20 |
| Data::Cmp::cmp_data | empty arrays | 460000 | 0.0022 | 110640.32% | 3.08% | 3.3e-09 | 20 |
| Data::Cmp::Numeric::cmp_data | empty arrays | 466000 | 0.00214 | 112756.31% | 1.15% | 8.3e-10 | 20 |
| Data::Cmp::StrOrNumeric::cmp_data | empty arrays | 470000 | 0.0021 | 114055.54% | 0.00% | 3.3e-09 | 20 |
+-----------------------------------+------------------+-----------+------------+-----------------------+-----------------------+---------+---------+
Formatted as Benchmark.pm result:
Rate DC:C 1k array of ints J:P 1k array of ints DCS:c_d 1k array of ints DCN:c_d 1k array of ints DC:c_d 1k array of ints DC:C small arrays J:P small arrays DCS:c_d small arrays DCN:c_d small arrays DC:c_d small arrays DC:C empty arrays J:P empty arrays DC:c_d empty arrays DCN:c_d empty arrays DCS:c_d empty arrays
DC:C 1k array of ints 410/s -- -20% -62% -71% -71% -99% -99% -99% -99% -99% -99% -99% -99% -99% -99%
J:P 1k array of ints 525/s 25% -- -53% -64% -64% -98% -99% -99% -99% -99% -99% -99% -99% -99% -99%
DCS:c_d 1k array of ints 1120/s 169% 114% -- -23% -24% -97% -98% -99% -99% -99% -99% -99% -99% -99% -99%
DCN:c_d 1k array of ints 1470/s 251% 180% 30% -- 0% -96% -97% -98% -99% -99% -99% -99% -99% -99% -99%
DC:c_d 1k array of ints 1480/s 255% 182% 31% 0% -- -96% -97% -98% -99% -99% -99% -99% -99% -99% -99%
DC:C small arrays 45000/s 10809% 8581% 3954% 3000% 2972% -- -30% -66% -69% -70% -77% -79% -90% -90% -90%
J:P small arrays 65344.2/s 15582% 12380% 5728% 4356% 4317% 43% -- -52% -56% -56% -67% -70% -85% -86% -86%
DCS:c_d small arrays 137000/s 32686% 25992% 12085% 9216% 9134% 200% 109% -- -9% -9% -31% -38% -69% -70% -71%
DCN:c_d small arrays 150669/s 36060% 28677% 13339% 10175% 10085% 231% 130% 10% -- 0% -24% -32% -66% -67% -68%
DC:c_d small arrays 150000/s 36263% 28839% 13415% 10233% 10142% 233% 131% 10% 0% -- -24% -32% -66% -67% -68%
DC:C empty arrays 200000/s 47900% 38100% 17740% 13540% 13420% 339% 206% 46% 32% 32% -- -10% -56% -57% -58%
J:P empty arrays 223767/s 53604% 42639% 19860% 15160% 15026% 392% 242% 63% 48% 47% 11% -- -50% -52% -53%
DC:c_d empty arrays 460000/s 108990% 86718% 40445% 30900% 30627% 899% 595% 232% 201% 200% 127% 103% -- -2% -4%
DCN:c_d empty arrays 466000/s 112049% 89152% 41582% 31769% 31488% 928% 615% 242% 210% 208% 133% 108% 2% -- -1%
DCS:c_d empty arrays 470000/s 114185% 90852% 42376% 32376% 32090% 947% 628% 248% 216% 214% 138% 112% 4% 1% --
Legends:
DC:C 1k array of ints: dataset=1k array of ints participant=Data::Compare::Compare
DC:C empty arrays: dataset=empty arrays participant=Data::Compare::Compare
DC:C small arrays: dataset=small arrays participant=Data::Compare::Compare
DC:c_d 1k array of ints: dataset=1k array of ints participant=Data::Cmp::cmp_data
DC:c_d empty arrays: dataset=empty arrays participant=Data::Cmp::cmp_data
DC:c_d small arrays: dataset=small arrays participant=Data::Cmp::cmp_data
DCN:c_d 1k array of ints: dataset=1k array of ints participant=Data::Cmp::Numeric::cmp_data
DCN:c_d empty arrays: dataset=empty arrays participant=Data::Cmp::Numeric::cmp_data
DCN:c_d small arrays: dataset=small arrays participant=Data::Cmp::Numeric::cmp_data
DCS:c_d 1k array of ints: dataset=1k array of ints participant=Data::Cmp::StrOrNumeric::cmp_data
DCS:c_d empty arrays: dataset=empty arrays participant=Data::Cmp::StrOrNumeric::cmp_data
DCS:c_d small arrays: dataset=small arrays participant=Data::Cmp::StrOrNumeric::cmp_data
J:P 1k array of ints: dataset=1k array of ints participant=JSON::PP
J:P empty arrays: dataset=empty arrays participant=JSON::PP
J:P small arrays: dataset=small arrays participant=JSON::PP
Benchmark module startup overhead (bencher -m Data::Cmp --module-startup
):
#table2#
+-------------------------+-----------+-------------------+-----------------------+-----------------------+---------+---------+
| participant | time (ms) | mod_overhead_time | pct_faster_vs_slowest | pct_slower_vs_fastest | errors | samples |
+-------------------------+-----------+-------------------+-----------------------+-----------------------+---------+---------+
| Data::Compare | 28.3 | 22.3 | 0.00% | 370.57% | 2.1e-05 | 20 |
| JSON::PP | 20.1 | 14.1 | 40.59% | 234.71% | 6.2e-06 | 20 |
| Data::Cmp::StrOrNumeric | 10 | 4 | 183.55% | 65.96% | 1e-05 | 20 |
| Data::Cmp | 9.94 | 3.94 | 184.68% | 65.30% | 9.4e-06 | 20 |
| Data::Cmp::Numeric | 9.93 | 3.93 | 184.92% | 65.16% | 5.1e-06 | 20 |
| perl -e1 (baseline) | 6 | 0 | 370.57% | 0.00% | 6.8e-06 | 21 |
+-------------------------+-----------+-------------------+-----------------------+-----------------------+---------+---------+
Formatted as Benchmark.pm result:
Rate Data::Compare JSON::PP Data::Cmp::StrOrNumeric Data::Cmp Data::Cmp::Numeric perl -e1 (baseline)
Data::Compare 35.3/s -- -28% -64% -64% -64% -78%
JSON::PP 49.8/s 40% -- -50% -50% -50% -70%
Data::Cmp::StrOrNumeric 100.0/s 183% 101% -- 0% 0% -40%
Data::Cmp 100.6/s 184% 102% 0% -- 0% -39%
Data::Cmp::Numeric 100.7/s 184% 102% 0% 0% -- -39%
perl -e1 (baseline) 166.7/s 371% 235% 66% 65% 65% --
Legends:
Data::Cmp: mod_overhead_time=3.94 participant=Data::Cmp
Data::Cmp::Numeric: mod_overhead_time=3.93 participant=Data::Cmp::Numeric
Data::Cmp::StrOrNumeric: mod_overhead_time=4 participant=Data::Cmp::StrOrNumeric
Data::Compare: mod_overhead_time=22.3 participant=Data::Compare
JSON::PP: mod_overhead_time=14.1 participant=JSON::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
.
BENCHMARK NOTES
HOMEPAGE
Please visit the project's homepage at https://metacpan.org/release/Bencher-Scenario-Data-Cmp.
SOURCE
Source repository is at https://github.com/perlancar/perl-Bencher-Scenario-Data-Cmp.
SEE ALSO
Bencher::Scenario::Scalar::Cmp
Bencher::Scenario::Serializers
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, and sometimes one or two other Dist::Zilla plugin and/or Pod::Weaver::Plugin. Any additional steps required beyond that are considered a bug and can be reported to me.
COPYRIGHT AND LICENSE
This software is copyright (c) 2022 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-Data-Cmp
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.