newtypes always turn into no code.   The UNPACK is therefore asking to unpack the Integer inside a Day, and that we can’t do because Integer has more than one data constructor.  Ditto Pico.  So just drop the UNPACKS. Keep the ! though, to keep it strict

 

S

 

From: haskell-cafe-bounces@haskell.org [mailto:haskell-cafe-bounces@haskell.org] On Behalf Of Eugene Kirpichov
Sent: 28 October 2011 10:41
To: Haskell Cafe
Subject: [Haskell-cafe] When does the UNPACK pragma work?

 

Hi,

I'm trying to speed up Data.Time (the time package) 'cause my program is spending a very substantial fraction of time manipulating dates.

I decided to start with strictifying and unpacking the date/time types, as there's no point in having them be lazy and I indeed had a lot of allocation in date/time arithmetic in my performance profile.

data UTCTime = UTCTime {
    utctDay :: {-# UNPACK #-} !Day,
    utctDayTime :: {-# UNPACK #-} !DiffTime
}

 

(unpacks and strictness mine)

 

newtype Day = ModifiedJulianDay {toModifiedJulianDay :: Integer} 

newtype DiffTime = MkDiffTime Pico

 

And Pico is also essentially a newtype for Integer.

 

So, I'm getting warnings on this definition of UTCTime. 

QUESTION: Is it the case that I can only UNPACK primitive fields, and not even their newtypes?

 

Data\Time\Clock\UTC.hs:30:16:

    Warning: Ignoring unusable UNPACK pragma on the

             first argument of `UTCTime'

    In the definition of data constructor `UTCTime'

    In the data type declaration for `UTCTime'

 

Data\Time\Clock\UTC.hs:30:16:

    Warning: Ignoring unusable UNPACK pragma on the

             second argument of `UTCTime'

    In the definition of data constructor `UTCTime'

    In the data type declaration for `UTCTime'

 

 

 

--
Eugene Kirpichov
Principal Engineer, Mirantis Inc. http://www.mirantis.com/
Editor, http://fprog.ru/