Int vs Word performance?

Claus Reinke claus.reinke at talk21.com
Fri Feb 27 08:20:33 EST 2009


>> A while ago, I needed lots of fairly small positive numbers,
>> together with a small number of flags for each, so I thought
>> I'd switch from Int to Word, and map the flags to bits.
> 
> Since there are few guarantees about the size of a Word (or Int), surely
> it would be better to choose a definitely sized basic type, e.g. Word8
> or Word16?  

Good point in principle, and I would indeed prefer a specific size.
Unfortunately, I found just the opposite of this

> I vaguely recall that ghc used to generate better code for
> definitely sized WordN than the generic unguaranteed-size Word.

to be true (although I don't recall whether I checked with IntN or
WordN, and I don't have a small example for this issue): Even
just replacing Int with Int32 on a system where that should be
the same was liable to reduce performance..

Given Don's point about SPECIALI[ZS]E, and the lack of
specialisations for IntN/WordN, that might explain it?

Claus

PS. perhaps on newer 64 bit machines, explicitly selecting
    32 bits can offer savings? I'd certainly expect selecting
    64 bits on a 32 bit machine to lead to slowdowns.



More information about the Glasgow-haskell-users mailing list