1
0
mirror of git://git.sv.gnu.org/coreutils.git synced 2026-04-21 11:16:16 +02:00
This commit is contained in:
Jim Meyering
1997-12-06 13:42:21 +00:00
parent 6ee3c1a91a
commit 7209272d72
3 changed files with 168 additions and 0 deletions

33
tests/sort-time/Makefile Normal file
View File

@@ -0,0 +1,33 @@
N = 1000000
dot30 = ..............................
dot31 = $(dot30).
safe_redirect_prologue = rm -f $@ $@-tmp
safe_redirect = $@-tmp && mv $@-tmp $@
time = /p/bin/time --verbose
all: t30 t31
t3%: in-3%
@$(safe_redirect_prologue)
$(time) sort $< > $(safe_redirect)
rand-digits: rand-gen
@$(safe_redirect_prologue)
./$< --integer $(N) |tr -d '\012' > $(safe_redirect)
in-30: rand-digits
@$(safe_redirect_prologue)
perl -pe 's/($(dot30))/$$1\n/g' $< > $(safe_redirect)
in-31: rand-digits
@$(safe_redirect_prologue)
perl -pe 's/($(dot31))/$$1\n/g' $< > $(safe_redirect)
clean:
rm -f t30 t31 in-30 in-31
realclean: clean
rm -f rand-digits

12
tests/sort-time/README Normal file
View File

@@ -0,0 +1,12 @@
determine whether it's worthwhile to add a --line-length=N option to sort.
Add the option and perform this test:
Test method:
==============
for n in 80 200 400 800 3000; do
sort a file with $n-char lines using the default of N=30
sort the same file with --line-length=$n
compare run times
done
do this on at least SunOS, Linux, Solaris

123
tests/sort-time/rand-gen Executable file
View File

@@ -0,0 +1,123 @@
#! /p/bin/perl -w
# Print n pairs of floating point values.
# Each value is in the range [0,1).
# Usage: rand n
# Use only the basename from the path to this executable in error messages.
($program_name = $0) =~ s|.*/||;
require 'newgetopt.pl';
$MAXINT = 0x7fffffff;
undef $opt_help;
undef $opt_verbose;
undef $opt_integer;
&usage if (&NGetOpt(('seed=i', 'range=s', 'help', 'items-per-line=i',
'format=s', 'integer', 'verbose')) == 0);
&usage if (defined ($opt_help));
&usage if (scalar (@ARGV) != 1 || $ARGV[0] !~ /^[0-9]+$/);
$n = $ARGV[0];
if (!defined ($opt_seed))
{
$opt_seed = time;
print STDERR "seed= $opt_seed\n" if (defined ($opt_verbose));
}
srand ($opt_seed);
# FIXME: make sure this number is positive.
$opt_items_per_line = 1 if (!defined ($opt_items_per_line));
if (defined ($opt_integer))
{
$opt_format = "%d" if (!defined ($opt_format));
if (defined ($opt_range))
{
# FIXME: allow FP endpoints even though --integer specified?
if ($opt_range =~ /^([0-9]+),([0-9]+)$/)
{
$lo = $1;
$hi = $2;
}
else
{
print STDERR ("bad argument `$opt_range' to --range option\n");
exit 2;
}
}
else
{
$lo = 0;
$hi = $MAXINT;
}
# Increase by one because we'll have to truncate to get integers.
$hi += 1;
}
else
{
$opt_format = "%.15g" if (!defined ($opt_format));
if (defined ($opt_range))
{
if ($opt_range =~ /^(-?[0-9.]+),(-?[0-9.]+)$/)
{
$lo = $1;
$hi = $2;
}
else
{
print STDERR ("bad argument `$opt_range' to --range option\n");
exit 2;
}
}
else
{
$lo = 0.0;
$hi = 1.0;
}
}
# FIXME: warn if lo > hi.
$range = $hi - $lo;
if ($opt_items_per_line == 1)
{
for ($i=0; $i < $n; $i++)
{
printf $opt_format, $lo + rand($range);
print "\n";
}
}
else
{
$separator = ' ';
for ($i=0; $i < $n; $i++)
{
for ($j=0; $j < $opt_items_per_line; $j++)
{
printf $opt_format, $lo + rand($range);
print $j == $opt_items_per_line - 1 ? "\n" : $separator;
}
}
}
exit 0;
sub usage
{
print STDERR <<EOF;
Usage: $program_name [OPTIONS] n
--help
--seed=n
--integer
--items-per-line=n
--range=i,j e.g. 3,9 or 1.5,33.9
--format='%3d'
--verbose (report the seed if it gets default value)
EOF
exit 2;
}