Beefy Boxes and Bandwidth Generously Provided by pair Networks
Perl-Sensitive Sunglasses
 
PerlMonks  

Re: assigning the maximum of two numbers

by revdiablo (Prior)
on Nov 02, 2005 at 23:16 UTC ( [id://505176]=note: print w/replies, xml ) Need Help??


in reply to assigning the maximum of two numbers

Change the benchmark code a bit:

use List::Util qw(max); sub assignmax { (sort { $b<=>$a } @_)[0]; } sub assignmax5 { (sort @_)[-1]; } sub assignmax2 { $_[0] > $_[1] ? $_[0] : $_[1]; } sub assignmax3 { max(@_); } sub assignmax4 { my $a; for (@_) { $a = $_ if $_ > $a; } $a; } @r = map {int rand 1000}(0..1); use Benchmark qw(cmpthese); cmpthese -1,{ 'sort' => sub {assignmax(@r)}, 'sort2' => sub {assignmax5(@r)}, 'ternary' => sub {assignmax2(@r)}, 'List' => sub {assignmax3(@r)}, 'loop' => sub {assignmax4(@r)}, };

And the results look quite different:

Rate loop sort2 sort List ternary loop 105412/s -- -27% -27% -61% -72% sort2 143479/s 36% -- -1% -47% -62% sort 144807/s 37% 1% -- -46% -62% List 270490/s 157% 89% 87% -- -29% ternary 381869/s 262% 166% 164% 41% --

Log In?
Username:
Password:

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://505176]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this?Last hourOther CB clients
Other Users?
Others contemplating the Monastery: (5)
As of 2024-04-24 09:33 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found