[Haskell] Silent error
Benoit T
benoit.triquet at gmail.com
Mon Jan 21 02:26:34 CET 2013
On Mon, Jan 21, 2013 at 01:17:17AM +0200, miphis at meta.ua wrote:
> The program looks like this:
>
> --***********************
> factorial :: Int->Int
> factorial n = product [1..n]
>
> main = do
> print $ factorial 50
> --***********************
>
> And that yields "0" (no errors). Is it a bug or feature? :)
Int is fixed-size (*) and is expected to use modular arithmetics (**)
therefore there is no notion of overflow, it just computes modulo
maxBound::Int
You must have been using a 32-bit haskell, that uses full-word Int, such
as HUGS, and it turns out that using 32-bit signed integers, you
eventually get -2**31 (this happens for n==32) and then multiplying by
any even integer yields 0 (34!==0).
GHC uses 31-bit or 63-bit Int (on 32- or 64-bit arch) and does not
encounter this case before factorial 50 (however the answer is also not
what you may have been expecting because it still doesn't fit).
cheers
*: this is specified in the standard
**: this does not seem to be specified in the standard
--
Benoit Triquet <benoit.triquet at gmail.com>
.''`.
: :' : We are debian.org. Lower your prices, surrender your code.
`. `' We will add your hardware and software distinctiveness to
`- our own. Resistance is futile.
More information about the Haskell
mailing list