[Haskell-cafe] flip fix and iterate
Jules Bean
jules at jellybean.co.uk
Tue Mar 20 07:38:24 EDT 2007
Matthew Brecknell wrote:
> There is the question of whether it's preferable to use the "let" form
> or the "fix" form for embedding a recursive function in the middle of a
> do-block. I don't know if there's any consensus on this question, but it
> seems to me to be about whether one prefers to read a function top-down
> or bottom-up. I think I'm about 80/20 top-down/bottom-up. When I read a
> "let", I know (due to laziness) that it doesn't have any effect until
> the bindings are used, so I usually find myself scanning forward to find
> those uses. When I read "fix \f -> ...", I see exactly how the
> (anonymous) function is used, just before I get to its definition. So
> fix helps me to see things in a mostly top-down fashion.
>
If you're merely talking about top-down or bottom-up then there is also
'where' rather than 'let'.
So the question becomes:
1. recursive definition first (let)
2. recursive definition last (where)
3. recursion inline (explicit use of fix)
1+2 have the virtue of separating the local recursive function from the
'main' function. On the other hand, 3 has the virtue of keeping them
together :) Which you prefer is quite subjective, and context dependent.
They potentially have slightly different scoping implications, too.
A lot of discussion about haskell code revolves around whether or not a
given construction is 'clear'; this has something to do with haskell's
almost unparallelled ability to abstract, I suppose. Ultimately,
something is clear once you are used to the abstraction, but obfuscated
if you're not, so it becomes rather subjective.
Jules
More information about the Haskell-Cafe
mailing list