[Haskell-cafe] New GHC fails to specialize imported function

14 views
Skip to first unread message

William Yager

unread,
Jul 30, 2015, 11:12:32 PM7/30/15
to haskel...@haskell.org
Hello all, 

I just installed the new Haskell platform for OS X.

It seems to have caused a major performance regression for a program I'm working on, making it well over 25x slower.

The culprit appears to be that the new GHC (7.10.2) fails to specialize an imported function. If I manually add a SPECIALIZE pragma, performance goes back to around what it used to be. 

The code in question is located at https://github.com/wyager/HNet .

As it stands, the code takes about 30 seconds to run on my machine. With the previous haskell-platform, it only took about .9 seconds. 

If I modify Operations.hs and uncomment the SPECIALIZE pragma, runtime goes down to about 1.1 seconds (still slower for some reason, but not awful).

To test, compile with -O2 (as the program makes heavy use of Data.Vector, which requires -fspec-constr for performance).



Additionally, my experience doesn't seem to match https://downloads.haskell.org/~ghc/7.8.4/docs/html/users_guide/pragmas.html#specialize-pragma in that if I add an INLINABLE pragma at the site of (••)'s definition and then try to SPECIALIZE it in a different file after importing, GHC tells me "Warning: SPECIALISE pragma on INLINE function probably won't fire: ‘••’". 

Cheers,
Will

Richard Eisenberg

unread,
Jul 31, 2015, 8:17:03 AM7/31/15
to William Yager, haskel...@haskell.org
This sounds terrible. Please post a bug report at https://ghc.haskell.org/trac/ghc/wiki/ReportABug

Thanks!
Richard

_______________________________________________
Haskell-Cafe mailing list
Haskel...@haskell.org
http://mail.haskell.org/cgi-bin/mailman/listinfo/haskell-cafe

Reply all
Reply to author
Forward
0 new messages