in reply to Re: Re: Re: transliterate
in thread transliterate

Okay, I tried a bunch of different things. Two sets of the same tests, one for 3 seconds, the other 6.
use Benchmark; timethese(-3, { aa => sub { $string = "blah+blah+blah"; $string =~ tr/+/ /; }, bb => sub { $string = "blah+blah+blah"; $string =~ s/\+/ /g; }, cc => sub { $string = "blah+blah+blah+blah+blah+blah"; $string =~ tr/+/ /; }, dd => sub { $string = "blah+blah+blah+blah+blah+blah"; $string =~ s/\+/ /g; }, ee => sub { $string = "blah"; $string =~ tr/+/ /; }, ff => sub { $string = "blah"; $string =~ s/\+/ /g; }, }); print "\n"; timethese(-6, { aa => sub { $string = "blah+blah+blah"; $string =~ tr/+/ /; }, bb => sub { $string = "blah+blah+blah"; $string =~ s/\+/ /g; }, cc => sub { $string = "blah+blah+blah+blah+blah+blah"; $string =~ tr/+/ /; }, dd => sub { $string = "blah+blah+blah+blah+blah+blah"; $string =~ s/\+/ /g; }, ee => sub { $string = "blah"; $string =~ tr/+/ /; }, ff => sub { $string = "blah"; $string =~ s/\+/ /g; }, });
The preceding output the following:
Benchmark: running aa, bb, cc, dd, ee, ff, each for at least 3 CPU sec +onds... aa: 6 wallclock secs ( 2.91 usr + 0.10 sys = 3.01 CPU) @ 42 +9021.93/s (n=1291356) bb: 8 wallclock secs ( 2.95 usr + 0.05 sys = 3.00 CPU) @ 20 +8165.00/s (n=624495) cc: 8 wallclock secs ( 2.90 usr + 0.10 sys = 3.00 CPU) @ 40 +4326.00/s (n=1212978) dd: 7 wallclock secs ( 2.88 usr + 0.12 sys = 3.00 CPU) @ 13 +4898.33/s (n=404695) ee: 8 wallclock secs ( 3.21 usr + 0.02 sys = 3.23 CPU) @ 50 +7243.96/s (n=1638398) ff: 6 wallclock secs ( 3.05 usr + -0.04 sys = 3.01 CPU) @ 60 +3128.24/s (n=1815416) Benchmark: running aa, bb, cc, dd, ee, ff, each for at least 6 CPU sec +onds... aa: 11 wallclock secs ( 5.87 usr + 0.14 sys = 6.01 CPU) @ 45 +1358.24/s (n=2712663) bb: 11 wallclock secs ( 5.99 usr + 0.01 sys = 6.00 CPU) @ 22 +2497.00/s (n=1334982) cc: 12 wallclock secs ( 6.12 usr + 0.01 sys = 6.13 CPU) @ 45 +0148.29/s (n=2759409) dd: 11 wallclock secs ( 6.39 usr + 0.02 sys = 6.41 CPU) @ 14 +9619.66/s (n=959062) ee: 12 wallclock secs ( 5.97 usr + 0.03 sys = 6.00 CPU) @ 52 +0242.00/s (n=3121452) ff: 7 wallclock secs ( 6.01 usr + 0.00 sys = 6.01 CPU) @ 60 +7347.25/s (n=3650157)
So by the looks of the runs per second statistic that tr is indeed faster than s///. What dondelelcaro mentioned about v5.005003 having a slower version of tr could be relevant though, as that is what I'm running.

Amel - f.k.a. - kel