Moritz:

Looks like you're raising the same concern as in here: https://ghc.haskell.org/trac/ghc/ticket/13124

Long story short: You cannot encode -0.0 directly. You have to represent it as an expression, multiplying `-1` with `fromRational 0`.

Similar concerns apply to NaN and Infinity as well, though those cannot be written as literals to start with, so it isn't a big issue there.

-Levent.

On Sun, Sep 17, 2017 at 7:02 AM, Moritz Angermann <moritz.angermann@gmail.com> wrote:
Hi *,

I just ran into the following case:

> fromRat (-0 :: Rational) :: Double
0.0

> -0 :: Rational
0 % 1

How do I encode negative zero as a rational? The question come
up as `CmmFloat` is defined as `CmmFloat  Rational Width` in
compiler/cmm/CmmExpr.hs. And my code generator thus turned
(Int, Rational) into a floating point expression, and when trying
to turn it into a `double` value, I ended up getting bad negative
zeros.

This makes me believe I can’t actually encode `-0` as a Rational,
and such `CmmFloat` will never contain `-0`?

Cheers,
 Moritz
_______________________________________________
ghc-devs mailing list
ghc-devs@haskell.org
http://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-devs