C:\test>826456 -N=4000
4000: Took 1.367 seconds
C:\test>826456-a -N=400
400: Took 0.025 seconds
C:\test>826456-a -N=800
800: Took 0.988 seconds
C:\test>826456-a -N=1600
1600: Took 13.999 seconds
C:\test>826456-a -N=3200
3200: Took 119.228 seconds
C:\test>826456-a -N=4000
4000: Took 234.037 seconds
####
C:\test>perl -V
Summary of my perl5 (revision 5 version 10 subversion 1) configuration:
Platform:
osname=MSWin32, osvers=5.2, archname=MSWin32-x64-multi-thread
uname=''
config_args='undef'
hint=recommended, useposix=true, d_sigaction=undef
useithreads=define, usemultiplicity=define
useperlio=define, d_sfio=undef, uselargefiles=define, usesocks=undef
use64bitint=define, use64bitall=undef, uselongdouble=undef
usemymalloc=n, bincompat5005=undef
Compiler:
cc='cl', ccflags ='-nologo -GF -W3 -MD -Zi -DNDEBUG -Ox -GL -Wp64 -fp:precise -DWIN32 -D_CON
optimize='-MD -Zi -DNDEBUG -Ox -GL -Wp64 -fp:precise',
cppflags='-DWIN32'
ccversion='15.0.21022', gccversion='', gccosandvers=''
intsize=4, longsize=4, ptrsize=8, doublesize=8, byteorder=12345678
d_longlong=undef, longlongsize=8, d_longdbl=define, longdblsize=8
ivtype='__int64', ivsize=8, nvtype='double', nvsize=8, Off_t='__int64', lseeksize=8
alignbytes=8, prototype=define
Linker and Libraries:
ld='link', ldflags ='-nologo -nodefaultlib -debug -opt:ref,icf -ltcg -libpath:"C:\Perl64\li
libpth=\lib
libs= oldnames.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.li
perllibs= oldnames.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi3
libc=msvcrt.lib, so=dll, useshrplib=true, libperl=perl510.lib
gnulibc_version=''
Dynamic Linking:
dlsrc=dl_win32.xs, dlext=dll, d_dlsymun=undef, ccdlflags=' '
cccdlflags=' ', lddlflags='-dll -nologo -nodefaultlib -debug -opt:ref,icf -ltcg -libpath:"C
Characteristics of this binary (from libperl):
Compile-time options: MULTIPLICITY PERL_DONT_CREATE_GVSV
PERL_IMPLICIT_CONTEXT PERL_IMPLICIT_SYS
PERL_MALLOC_WRAP PL_OP_SLAB_ALLOC USE_64_BIT_INT
USE_ITHREADS USE_LARGE_FILES USE_PERLIO
USE_SITECUSTOMIZE
Locally applied patches:
ActivePerl Build 1006 [291086]
32728 64-bit fix for Time::Local
Built under MSWin32
Compiled at Aug 24 2009 13:45:20
@INC:
C:/Perl64/site/lib
C:/Perl64/lib
.
C:\test>perl -Mautobox -E"say $autobox::VERSION"
2.55
C:\test>perl -Mautobox::Core -E"say $autobox::Core::VERSION"
0.6
####
C:\test>type 826456.pl
#! perl -slw
use strict;
use Time::HiRes qw[ time ];
use List::Util qw[ min ];
use Data::Dump qw[ pp ];
srand 1;
our $N //= 4000;
my $start = time();
my %pvalues = map{ $_ => rand() } 1 .. $N;
#my %pvalues = (
# 1=> 0.5453980,
# 2=> 0.4902384,
# 3=> 0.8167950,
# 4=> 0.2821822,
# 5=> 0.4693030,
# 6=> 0.6491767,
# 7=> 0.9802138,
# 8=> 0.1155778,
# 9=> 0.9585124,
# 10=> 0.4069490
#);
my @orderedKeys = sort {
$pvalues{ $b } <=> $pvalues{ $a }
} keys %pvalues;
my $d = my $n = values %pvalues;
$pvalues{ $_ } *= $n / $d-- for @orderedKeys;
$pvalues{ $orderedKeys[ $_ ] } =
min( @pvalues{ @orderedKeys[ 0 .. $_ ] } )
for 1 .. $n-1;
$pvalues{ $_ } = min( $pvalues{ $_ }, 1 ) for keys %pvalues;
printf "$N: Took %.3f seconds\n", time() - $start;
#pp \%pvalues;
C:\test>type 826456-a.pl
#! perl -slw
use strict;
use autobox::Core;
use Time::HiRes qw[ time ];
use List::Util qw[ min ];
use Data::Dump qw[ pp ];
srand 1;
our $N //= 4000;
my $start = time();
my %pvalues = @{ [ 1 .. $N ]->map( sub{ $_[0] => rand() } ) };
#my %pvalues = (
# 1=> 0.5453980,
# 2=> 0.4902384,
# 3=> 0.8167950,
# 4=> 0.2821822,
# 5=> 0.4693030,
# 6=> 0.6491767,
# 7=> 0.9802138,
# 8=> 0.1155778,
# 9=> 0.9585124,
# 10=> 0.4069490
#);
my @orderedKeys = @{ %pvalues->keys->sort(
sub{ $pvalues{ $_[1] } <=> $pvalues{ $_[0] } }
)
};
my $d = my $n = @{ %pvalues->keys };
@orderedKeys->map(
sub{
$pvalues{ $_[0] } *= $n / $d--;
}
);
[ 1 .. $n-1 ]->map(
sub{
$pvalues{ $orderedKeys[ $_[0] ] } =
min( @pvalues{ @orderedKeys[ 0 .. $_[0] ] } );
}
);
%pvalues->keys->map(
sub{ $pvalues{ $_[0] } = min( $pvalues{ $_[0] }, 1 ) }
);
printf "$N: Took %.3f seconds\n", time() - $start;
#pp \%pvalues;
__END__
C:\test>826456 -N=4000
4000: Took 1.367 seconds
C:\test>826456-a -N=400
400: Took 0.025 seconds
C:\test>826456-a -N=800
800: Took 0.988 seconds
C:\test>826456-a -N=1600
1600: Took 13.999 seconds
C:\test>826456-a -N=3200
3200: Took 119.228 seconds
C:\test>826456-a -N=4000
4000: Took 234.037 seconds