#!/usr/bin/perl use strict; use warnings; use Carp qw(carp croak); use Data::Dumper; use Benchmark; my %loaded; for (qw/ Digest::MD5 /) { eval "use $_"; unless ($@) { $loaded{$_} = $_->VERSION; } } print "Benchmarking...\n"; for my $key (sort keys %loaded) { print "$key\t$loaded{$key}\n"; } my $code = <<'EOM'; [b]bold [i]italic[/i] test[/b] [code]some [perl] code[/code] [url=http://foo.example.org/]a link![/url] EOM sub Dmd5 { my $pb = Digest::MD5->new; # Uncomment the three lines below to speed things up # use Memoize; # memoize('Digest::MD5::add'); # memoize('Digest::MD5::hexdigest'); return $pb; } my ($pb); if ($loaded{'Digest::MD5'}) { $pb = Dmd5(); my $rendered1 = $pb->add($code); } timethese($ARGV[0] || -1, { $loaded{'Digest::MD5'} ? ( 'Digest::MD5::new' => \&Dmd5, 'Digest::MD5' => sub { my $out = $pb->hexdigest }, ) : (), }); #Benchmarking... #Digest::MD5 2.55 #Benchmark: running Digest::MD5, Digest::MD5::new for at least 1 CPU s +econds... #Digest::MD5: -1 wallclock secs ( 1.11 usr + 0.00 sys = 1.11 CPU) @ +138871.96/s (n=154009) #Digest::MD5::new: 1 wallclock secs ( 1.11 usr + 0.00 sys = 1.11 CP +U) @ 69872.97/s (n=77559) # #Benchmarking with Memoize... #Digest::MD5 2.55 #Benchmark: running Digest::MD5, Digest::MD5::new for at least 1 CPU s +econds... #Digest::MD5: 1 wallclock secs ( 1.12 usr + 0.00 sys = 1.12 CPU) @ +61895.11/s (n=69632) #Digest::MD5::new: 1 wallclock secs ( 1.06 usr + 0.03 sys = 1.09 CP +U) @ 5227.61/s (n=5719)
In reply to Re: Could SHA encode faster than MD5?
by $h4X4_|=73}{
in thread Could SHA encode faster than MD5?
by bbs2web
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |