[Haskell-cafe] Comments from OCaml Hacker Brian Hurt

Wouter Swierstra wss at Cs.Nott.AC.UK
Thu Jan 15 11:44:45 EST 2009


At the risk of painting my own bikeshed...

> If you're learning Haskell, which communicates the idea more clearly:
>
> * Appendable
>
> or
>
> * Monoid

Would you call function composition (on endofunctions) "appending"?  
The join of a monad? A semi-colon (as in sequencing two imperative  
statements)? How do you append two numbers? Addition, multiplication,  
or something else entirely?

All these operations are monoidal, i.e., are associative and have both  
left and right identities. If that's exactly what they have in common,  
why invent a new name? "Appendable" may carry some intuition, but it  
is not precise and sometimes quite misleading.

> I guess the bottom line question is: who is Haskell for?  Category
> theorists, programmers, or both?  I'd love it to be for both, but I've
> got to admit that Brian has a point that it is trending to the first  
> in
> some areas.


One of my grievances about Haskell is the occasional disregard for  
existing terminology. "Stream Fusion" is about lazy lists/co-lists,  
not streams; "type families" mean something entirely different to type  
theorists. This kind of misnomer is even more confusing than a name  
that doesn't mean anything (at least, until you learn more category  
theory).

   Wouter



This message has been checked for viruses but the contents of an attachment
may still contain software viruses, which could damage your computer system:
you are advised to perform your own checks. Email communications with the
University of Nottingham may be monitored as permitted by UK legislation.



More information about the Haskell-Cafe mailing list