baxy77bax has asked for the wisdom of the Perl Monks concerning the following question:
quick question , is there a faster alternative for the push and shift function on the following code:
the reason i'm asking is because if i just iterate through file IN like :my @a =(); my @b =(); while(<IN>){ chomp; $cnt++; /\d+\t(\d+)/; if (@a<7){ push(@a,$1); } push(@b,$1) if $1 > 3; if (@b>7){ shift(@a); shift(@b); } print $a[0] - $b[-1] . "\n" }
it takes me 10 min and if a complicate it with 2 push and shift functions, plus regex, the runtime increases to 150 minwhile(<IN>){ $cnt++ }
cheers
baxy
Update:
ok so more details , though i think they are irrelevant:
file size: 70GB file format : tsv 1 34 2 6 3 78 simple while-loop time: real 10m51.378s user 9m22.610s sys 0m13.120s while loop with regex + push and shift + one subtraction(i forgot to m +ention that) real 157m13.245s user 152m8.520s sys 1m26.660s
|
---|
Replies are listed 'Best First'. | |
---|---|
Re: Faster push and shift
by moritz (Cardinal) on Feb 16, 2012 at 10:05 UTC | |
Re: Faster push and shift
by BrowserUk (Patriarch) on Feb 16, 2012 at 12:43 UTC | |
by rovf (Priest) on Feb 16, 2012 at 14:05 UTC | |
by choroba (Cardinal) on Feb 16, 2012 at 14:18 UTC | |
by rovf (Priest) on Feb 16, 2012 at 15:08 UTC | |
by locked_user sundialsvc4 (Abbot) on Feb 16, 2012 at 13:57 UTC | |
by BrowserUk (Patriarch) on Feb 16, 2012 at 14:49 UTC | |
Re: Faster push and shift
by rovf (Priest) on Feb 16, 2012 at 11:24 UTC | |
by BrowserUk (Patriarch) on Feb 16, 2012 at 12:07 UTC | |
by rovf (Priest) on Feb 16, 2012 at 12:29 UTC | |
by locked_user sundialsvc4 (Abbot) on Feb 16, 2012 at 13:53 UTC | |
Re: Faster push and shift
by RichardK (Parson) on Feb 16, 2012 at 13:05 UTC |