[Haskell-cafe] Restricted type classes
wren ng thornton
wren at freegeek.org
Fri Sep 10 17:32:53 EDT 2010
On 9/10/10 12:47 AM, David Menendez wrote:
> It seems like you could use a similar argument to show that fmap id /= id.
>
> Specifically, xs and map id xs are equivalent lists, but they occupy
> different locations in memory. By replacing xs with map id xs, you can
> come arbitrarily close to doubling a program's memory requirements.
> (You can also use pointer comparison to distinguish them, but I assume
> that doesn't count.)
That doesn't really follow. The Haskell values and types do not capture
heap transformations, so those don't count for the same reason that
pointer equality doesn't count.
The fmap id = id law only needs to apply at each use site, not
necessarily when doing whole-program analysis. Given any list xs, it is
indeed true that the result of (fmap id xs) is equal to the result of
(id xs). They even take up the same amount of space after full
evaluation. The only difference is that the latter avoids some extra
allocation and garbage collection and preserves sharing, none of which
is captured by the type system. Indeed, that's why we'd like to know the
laws hold, so that we can rewrite occurences of (fmap id) with id; just
as we'd like to replace (fmap f . fmap g) by fmap(f.g) since it improves
time performance by only performing a single traversal. Time is also not
captured by the type system. Technically we could rewrite programs in
the other direction and introduce new fmaps, we just have no reason to
do so.
However, in the example I gave, the actual values (E (f a) a) and (E (f
a) (f a)) are not equal even when ignoring time, space, and sharing.
They may be *isomorphic* because they have the same observable behavior
within the language (assuming no polymorphic seq or heap-size
reflection), but they are not *equal*. Your comments about increasing
total-program allocation just points out that (fmap id) and id are not
*identical*--- which we know already. But even if they cannot be
identical, they must be equal if the fmap instance is lawfully a
functor. The notions of being identical, equal, isomorphic, and
equivalent are all quite different. I was only using the size of their
heap representation as evidence for the non-equality of these two terms
in spite of their isomorphism.
--
Live well,
~wren
More information about the Haskell-Cafe
mailing list