[Haskell-cafe] Could someone teach me why we use Data.Monoid?
Andrew Coppin
andrewcoppin at btinternet.com
Fri Nov 13 11:52:34 EST 2009
Stephen Tetley wrote:
> 2009/11/13 Rafael Gustavo da Cunha Pereira Pinto <RafaelGCPP.Linux at gmail.com>:
>
>> Monoid is the category of all types that have a empty value and an append
>> operation.
>>
>>
>
> Or more generally a neutral element and an associative operation:
>
> The multiplication monoid (1,*)
>
> 9*1*1*1 = 9
>
> 1 is neutral but you might be hard pressed to consider it _empty_.
>
This is the thing. If we had a class specifically for containers, that
could be useful. If we had a class specifically for algebras, that could
be useful. But a class that represents "any possible thing that can
technically be considered a monoid" seems so absurdly general as to be
almost useless. If you don't know what an operator *does*, being able to
abstract over it isn't especially helpful...
...in my humble opinion. (Which, obviously, nobody else will agree with.)
More information about the Haskell-Cafe
mailing list