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

GHC ghc-devs at haskell.org
Mon Dec 8 15:36:32 UTC 2014


#9872: Runing type functions is too slow
-------------------------------------+-------------------------------------
              Reporter:  simonpj     |            Owner:
                  Type:  bug         |           Status:  new
              Priority:  normal      |        Milestone:
             Component:  Compiler    |          Version:  7.8.3
            Resolution:              |         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 simonpj):

 Replying to [comment:3 goldfire]:
 > This all begs a question I've wondered several times: Flattening in the
 solver is great when we have bits of a type that are unknown, like `F
 (Int, a)`. But, it seems like an awful lot of work to do when a type is
 fully known, such as `F Bool`. In the latter case, is there a reason we
 don't use `normaliseType`? It would seem to me that this all would get
 more efficient if we just called `normaliseType` as an early step in the
 process, say in `flattenFamApp`.

 Reasonable question.  But if we had
 {{{
    Eq (F (P Q R)
          (G (H (F (G (H a Int))))))
 }}}
 there's a risk of trying to normalise at the outer level, and then at
 every inner level, which would not be very clever.  I'll think about this
 a bit more.

 Simon

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


More information about the ghc-tickets mailing list