The London Perl and Raku Workshop takes place on 26th Oct 2024. If your company depends on Perl, please consider sponsoring and/or attending.

NAME

Bencher::Scenario::DateModules::Creation - Benchmark date creation

VERSION

This document describes version 0.004 of Bencher::Scenario::DateModules::Creation (from Perl distribution Bencher-Scenarios-DateModules), released on 2017-08-27.

SYNOPSIS

To run benchmark with default option:

 % bencher -m DateModules::Creation

To run module startup overhead benchmark:

 % bencher --module-startup -m DateModules::Creation

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.

DateTime 1.36

DateTime::Tiny 1.06

Time::Moment 0.38

Time::Local 1.2300

Time::Piece 1.31

BENCHMARK PARTICIPANTS

  • DateTime->new(ymd) (perl_code)

    Function call template:

     DateTime->new(year=>2016, month=>4, day=>19)
  • DateTime->now (perl_code)

    Function call template:

     DateTime->now
  • DateTime::Tiny->new(ymd) (perl_code)

    Function call template:

     DateTime::Tiny->new(year=>2016, month=>4, day=>19)
  • DateTime::Tiny->now (perl_code)

    Function call template:

     DateTime::Tiny->now
  • Time::Moment->new(ymd) (perl_code)

    Function call template:

     Time::Moment->new(year=>2016, month=>4, day=>19)
  • Time::Moment->now (perl_code)

    Function call template:

     Time::Moment->now
  • Time::Local::timelocal (perl_code)

    Function call template:

     Time::Local::timelocal(0, 0, 0, 19, 4-1, 2016-1900)
  • Time::Piece::localtime (perl_code)

    Function call template:

     Time::Piece::localtime()

SAMPLE BENCHMARK RESULTS

Run on: perl: v5.24.0, CPU: Intel(R) Core(TM) M-5Y71 CPU @ 1.20GHz (2 cores), OS: GNU/Linux LinuxMint version 17.3, OS kernel: Linux version 3.19.0-32-generic.

Benchmark with default options (bencher -m DateModules::Creation):

 #table1#
 +--------------------------+-----------+-----------+------------+------------------+---------+---------+
 | participant              | rate (/s) | time (μs) | vs_slowest | result_size (kB) |  errors | samples |
 +--------------------------+-----------+-----------+------------+------------------+---------+---------+
 | DateTime->new(ymd)       |     24000 |   42      |        1   |         22       | 1.1e-07 |      24 |
 | DateTime->now            |     24000 |   42      |        1   |         22       | 9.3e-08 |      33 |
 | Time::Local::timelocal   |    100000 |    9.8    |        4.3 |          0.055   |   1e-08 |      20 |
 | Time::Piece::localtime   |    190000 |    5.2    |        8.1 |          0.44    | 1.3e-08 |      25 |
 | DateTime::Tiny->now      |    306000 |    3.27   |       12.9 |          0.625   | 1.6e-09 |      22 |
 | Time::Moment->now        |    860000 |    1.2    |       37   |          0.088   | 1.2e-09 |      20 |
 | DateTime::Tiny->new(ymd) |   1400000 |    0.712  |       59.3 |          0.369   | 2.1e-10 |      20 |
 | Time::Moment->new(ymd)   |   2942000 |    0.3399 |      124.2 |          0.08789 | 1.1e-11 |      20 |
 +--------------------------+-----------+-----------+------------+------------------+---------+---------+

Benchmark module startup overhead (bencher -m DateModules::Creation --module-startup):

 #table2#
 +---------------------+------------------------------+--------------------+----------------+-----------+------------------------+------------+---------+---------+
 | participant         | proc_private_dirty_size (MB) | proc_rss_size (MB) | proc_size (MB) | time (ms) | mod_overhead_time (ms) | vs_slowest |  errors | samples |
 +---------------------+------------------------------+--------------------+----------------+-----------+------------------------+------------+---------+---------+
 | DateTime            | 11                           | 15                 | 44             |      59   |                   54.8 |        1   | 8.7e-05 |      20 |
 | Time::Piece         | 1.4                          | 4.7                | 19             |      17   |                   12.8 |        3.5 | 1.8e-05 |      20 |
 | Time::Local         | 1.4                          | 4.8                | 19             |      12   |                    7.8 |        4.8 |   8e-05 |      20 |
 | Time::Moment        | 1                            | 4.5                | 16             |      10   |                    5.8 |        5.9 | 1.8e-05 |      20 |
 | DateTime::Tiny      | 1                            | 4.4                | 16             |       8.3 |                    4.1 |        7.1 | 5.3e-05 |      20 |
 | perl -e1 (baseline) | 11                           | 15                 | 44             |       4.2 |                    0   |       14   | 7.8e-06 |      20 |
 +---------------------+------------------------------+--------------------+----------------+-----------+------------------------+------------+---------+---------+

To display as an interactive HTML table on a browser, you can add option --format html+datatables.

BENCHMARK NOTES

Time::Moment is the fastest. It also produces a very compact object (second only to Time::Local, which produces ints). In comparison, DateTime is relatively crazy big.

DateTime::Tiny is an alternative for DateTime if you want smaller startup overhead and dependencies. It also creates date objects faster. But the object is still relatively large (a hash of date element fields).

HOMEPAGE

Please visit the project's homepage at https://metacpan.org/release/Bencher-Scenarios-DateModules.

SOURCE

Source repository is at https://github.com/perlancar/perl-Bencher-Scenarios-DateModules.

BUGS

Please report any bugs or feature requests on the bugtracker website https://rt.cpan.org/Public/Dist/Display.html?Name=Bencher-Scenarios-DateModules

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.

AUTHOR

perlancar <perlancar@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2017 by 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.