Beefy Boxes and Bandwidth Generously Provided by pair Networks
Think about Loose Coupling
 
PerlMonks  

Re^2: Functional shuffle

by Roy Johnson (Monsignor)
on Apr 01, 2005 at 23:39 UTC ( [id://444323]=note: print w/replies, xml ) Need Help??


in reply to Re: Functional shuffle
in thread Functional shuffle

I pronounce if functional enough, when you use splice. Clearly, splice could be written as a separate function. (I could probably do that.) I would further golf #2 into
sub functional_FY { return @_ ? ( splice( @_, rand @_, 1 ), &functional_FY ) : @_; }
which is, I think, something of an improvement as well. Splicing the only element out of an array is certainly valid.

Update: A functional splice, though, shouldn't have side-effects. It would either retrieve the values, or return the array without them. Or you could make one that sticks them on the front, maybe. I pronounce it a good start.


Caution: Contents may have been coded under pressure.

Replies are listed 'Best First'.
Re^3: Functional shuffle
by bart (Canon) on Apr 02, 2005 at 11:56 UTC
    A functional splice, though, shouldn't have side-effects.
    Then use a slice instead. No, that's not Perl keyword, instead, it's a pattern you implement using array indexes.

    Since we need the same random index more than once, I stuff it into a temporary variable. I don't think you consider those very "functional", but what the heck...

    sub quite_functional_FY { my $i = int rand @_; return @_ ? ($_[$i], quite_functional_FY(@_[0 .. $i-1, $i+1 .. $#_ +])) : (); }

    I think you can get a faster implementation by avoiding the recursion for lists that don't need shuffling: lists of one item (or less: 0).

    sub quite_functional_FY { my $i = int rand @_; return @_ > 1 ? ($_[$i], quite_functional_FY(@_[0 .. $i-1, $i+1 .. + $#_])) : @_; }

      Yes, of course. What was I thinking? This is almost twice as fast as the "cut" approach I proposed, and clearer to boot. Ode to bart

      the lowliest monk

      I think I'd gotten stuck in the mindset that functional programming requires streams, but there's no reason you couldn't use slices. Variables are not strictly functional, per se, but it's trivial to have an auxiliary function that does the same thing, so I don't object to them.

      I see there's some confusion about what qualifies as functional. That's probably my fault for not specifying. I punted, because I don't think I had it well-defined in my own mind. But I think I have a better idea now:

      In the purest sense, a functional program is one in which nothing is modified — all new values are modified copies of something else. In keeping with that, the only variables are parameters to the functions.

      Most functional languages allow for some practical exceptions to avoid cumbersome jumping through hoops, as in the case of your temp variable. I like your solution a lot.


      Caution: Contents may have been coded under pressure.
Re^3: Functional shuffle
by kelan (Deacon) on Apr 02, 2005 at 14:04 UTC

    I'd probably make that

    sub functional_FY { return @_ ? ( splice( @_, rand @_, 1 ), &functional_FY ) : (); }
    so that the intention is clearer. Or does that mess up the callstack that &-style calling uses?

Log In?
Username:
Password:

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

How do I use this?Last hourOther CB clients
Other Users?
Others avoiding work at the Monastery: (3)
As of 2024-04-19 19:14 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found