clearly the massive differences between
tin2 and
tin3 must at least alert you that something is wrong with the benchmark...
Frankly I have no idea what goes on once you start eval-ing strings in the Benchmark module, but from the presented examples, something seems suspicious.
Here is a benchmark by me
use Benchmark qw(cmpthese);
my @arr = map {rand} 0..900000;
my @output = map {rand} 0..300000;;
Benchmark::cmpthese(10,{
tin1 => sub {
$output[int($_/3)] += $arr[$_] for 0..@arr-1;
},
tin2 => sub {
$output[$_] = $arr[3*$_] + $arr[3*$_+1] + $arr[3*$_+2]
for 0..@arr/3;
},
tin3=> sub {
my $b = 0;
for (0..@arr /3) {
$output[$_] = $arr[$b] + $arr[$b+1] + $arr[$b +2];
$b += 3;
}
}
});
With result
$ perl ../../../perlmonks/bench-trip.pl
Rate tin1 tin2 tin3
tin1 1.81/s -- -41% -46%
tin2 3.08/s 70% -- -9%
tin3 3.39/s 87% 10% --
Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
Read Where should I post X? if you're not absolutely sure you're posting in the right place.
Please read these before you post! —
Posts may use any of the Perl Monks Approved HTML tags:
- a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
| |
For: |
|
Use: |
| & | | & |
| < | | < |
| > | | > |
| [ | | [ |
| ] | | ] |
Link using PerlMonks shortcuts! What shortcuts can I use for linking?
See Writeup Formatting Tips and other pages linked from there for more info.