[GHC] #9872: Runing type functions is too slow

GHC ghc-devs at haskell.org
Sat Dec 20 02:49:36 UTC 2014


#9872: Runing type functions is too slow
-------------------------------------+-------------------------------------
              Reporter:  simonpj     |            Owner:
                  Type:  bug         |           Status:  closed
              Priority:  normal      |        Milestone:
             Component:  Compiler    |          Version:  7.8.3
            Resolution:  fixed       |         Keywords:
      Operating System:              |     Architecture:  Unknown/Multiple
  Unknown/Multiple                   |       Difficulty:  Unknown
       Type of failure:              |       Blocked By:
  None/Unknown                       |  Related Tickets:
             Test Case:              |
              Blocking:              |
Differential Revisions:              |
-------------------------------------+-------------------------------------

Comment (by goldfire):

 In thinking about this issue, the Right Way to get type families to be
 faster is to optimize them properly. By this, I mean taking the type
 family definitions and performing an optimization pass on them during
 type-checking/desugaring. We've essentially just implemented a tiny
 interpreter inside of !TcFlatten, and the whole thing could be more
 principled in approach.

 I'm not making a concrete proposal, just musing on the fact that we have
 here a classic problem -- how to write a fast interpreter for a given
 programming language. It just happens to be the language of type families.
 I suppose there is a body of research and experience on this very issue,
 and if we want to be serious about fast compilation times in the presence
 of heavy type-level computation, it would do well to use that body of
 knowledge.

 In any case, I'm done dwelling on performance for a while, but I'm quite
 pleased with my end result.

--
Ticket URL: <http://ghc.haskell.org/trac/ghc/ticket/9872#comment:25>
GHC <http://www.haskell.org/ghc/>
The Glasgow Haskell Compiler


More information about the ghc-tickets mailing list