Beefy Boxes and Bandwidth Generously Provided by pair Networks
Come for the quick hacks, stay for the epiphanies.
 
PerlMonks  

Re^12: Date Array Convolution

by BrowserUk (Patriarch)
on Nov 09, 2011 at 00:12 UTC ( [id://936911]=note: print w/replies, xml ) Need Help??


in reply to Re^11: Date Array Convolution
in thread Date Array Convolution

real 3m21.523s ... real 1m24.273s

Nice, and subtle :)

Try this:

#! perl -slw use strict; use Data::Dump qw[ pp ]; sub dhm2int { my( $d, $h, $m ) = unpack '(A2)*', $_[0]; return ( ( $d - 1 ) * 24 + $h ) * 60 + $m; } sub int2dhm { sprintf "%02d%02d%02d", int($_[0]/1440)+1, int($_[0]/60)%24, $_[0] +%60; } my $tally = chr(255) x ( 31*24*60 ); while( <> ) { chomp; my( $sd, $ed, $v ) = split; my( $s, $e ) = map dhm2int( $_ ), $sd, $ed; while( int( $s / 1440 ) != int( $e / 1440 ) ) { my $newe = ( int( $s / 1440 ) +1 ) * 1440 -1; vec( $tally, $_, 8 ) > $v and vec( $tally, $_, 8 ) = $v for $s .. $newe; $s = $newe +1; } vec( $tally, $_, 8 ) > $v and vec( $tally, $_, 8 ) = $v for $s .. $e; } my @res; my $i = 0; while( $i < length( $tally ) ) { ++$i until vec( $tally, $i, 8 ) != 255; my $val = vec( $tally, $i, 8 ); my $start = $i++; ++$i while $i % 1440 and vec( $tally, $i, 8 ) == $val; my $end = $i - 1; push @res, [ int2dhm( $start ), int2dhm( $end ), $val ]; } pp \@res;

With the rise and rise of 'Social' network sites: 'Computers are making people easier to use everyday'
Examine what is said, not who speaks -- Silence betokens consent -- Love the truth but pardon error.
"Science is about questioning the status quo. Questioning authority".
In the absence of evidence, opinion is indistinguishable from prejudice.

Replies are listed 'Best First'.
Re^13: Date Array Convolution
by choroba (Cardinal) on Nov 09, 2011 at 10:22 UTC
    Same result, your time being now pretty comparable to mine: 1m43.735s. :-)

      This is just for grins, but a thought came to me over my morning tea. How does this fare?:

      #! perl -slw use strict; use Data::Dump qw[ pp ]; sub dhm2int { my( $d, $h, $m ) = unpack '(A2)*', $_[0]; return ( ( $d - 1 ) * 24 + $h ) * 60 + $m; } sub int2dhm { sprintf "%02d%02d%02d", int($_[0]/1440)+1, int($_[0]/60)%24, $_[0] +%60; } my @data = sort{ $b->[2] <=> $a->[2] } map[ split ], <>; my $tally = chr(255) x ( 31*24*60 ); for my $d ( @data ) { my $s = dhm2int( $d->[0] ); my $e = dhm2int( $d->[1] ); substr( $tally, $s, $e-$s+1, chr( $d->[2] ) x ( $e - $s + 1 ) ); } my @res; my $i = 0; while( $i < length( $tally ) ) { ++$i until vec( $tally, $i, 8 ) != 255; my $val = vec( $tally, $i, 8 ); my $start = $i++; ++$i while $i % 1440 and vec( $tally, $i, 8 ) == $val; my $end = $i - 1; push @res, [ int2dhm( $start ), int2dhm( $end ), $val ]; } pp \@res;

      With the rise and rise of 'Social' network sites: 'Computers are making people easier to use everyday'
      Examine what is said, not who speaks -- Silence betokens consent -- Love the truth but pardon error.
      "Science is about questioning the status quo. Questioning authority".
      In the absence of evidence, opinion is indistinguishable from prejudice.
        Heh, less than 2 seconds. Sorting according to value - very clever!

Log In?
Username:
Password:

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://936911]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this?Last hourOther CB clients
Other Users?
Others rifling through the Monastery: (5)
As of 2024-04-23 17:12 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found