File: sort

package info (click to toggle)
libmath-gsl-perl 0.45-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 192,156 kB
  • sloc: ansic: 895,524; perl: 24,682; makefile: 12
file content (25 lines) | stat: -rwxr-xr-x 819 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
#!/usr/bin/perl -w
use strict;
use Math::GSL::Sort qw/:all/;
use Math::GSL::RNG  qw/:all/;
use Benchmark       qw/:all/;
use Data::Dumper;

my $count  = shift || 1000;
my $length = shift || 5000;
my $rng    = Math::GSL::RNG->new;
my @data1   = map { (-1)**$_ * $rng->get        } (1..$length);
my @data2   = map { (-1)**$_ * int(rand(2**30)) } (1..$length);
my @stuff;

print "Benchmarking for Math::GSL::RNG data\n";
timethese($count, {
            'perl sort     ' => sub { @stuff = sort { $a <=> $b } @data1 },
            'Math::GSL sort' => sub { @stuff = gsl_sort(\@data1,1,$#data1+1) },
});

print "Benchmarking for rand() data\n";
timethese($count, {
            'perl sort     ' => sub { @stuff = sort { $a <=> $b } @data2 },
            'Math::GSL sort' => sub { @stuff = gsl_sort(\@data2,1,$#data2+1) },
});