[GHC] #14880: GHC panic: updateRole

GHC ghc-devs at haskell.org
Thu Jul 26 14:46:12 UTC 2018


#14880: GHC panic: updateRole
-------------------------------------+-------------------------------------
        Reporter:  RyanGlScott       |                Owner:  goldfire
            Type:  bug               |               Status:  new
        Priority:  normal            |            Milestone:
       Component:  Compiler (Type    |              Version:  8.2.2
  checker)                           |
      Resolution:                    |             Keywords:  TypeInType
Operating System:  Unknown/Multiple  |         Architecture:
 Type of failure:  Compile-time      |  Unknown/Multiple
  crash or panic                     |            Test Case:
      Blocked By:                    |             Blocking:
 Related Tickets:  #15076            |  Differential Rev(s):  Phab:D4769
       Wiki Page:                    |
-------------------------------------+-------------------------------------

Comment (by tdammers):

 Replying to [comment:58 simonpj]:
 > > the "unions" approach: unions . map singleton
 >
 > That is essentially `foldr (union . singleton) empty`, which is really
 very close to `foldr insert empty`.
 >
 > What if you do a balanced tree of binary `union` operations?  I suppose
 something like
 > {{{
 > bigSet :: Int -> Int -> IntSet
 > bigSet m n
 >   | m==n = singleton n
 >   | otherwise = bigSet m mid `union` bigSet (mid+1) n
 >   where
 >     mid = (n+m)/2
 > }}}

 Did exactly that, benchmark code attached. Results:

 {{{
 ./intmapbench insert    1.32s user 0.05s system 99% cpu 1.370 total
 ./intmapbench union     1.01s user 0.01s system 99% cpu 1.029 total
 ./intmapbench balanced  0.24s user 0.01s system 98% cpu 0.260 total
 }}}

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


More information about the ghc-tickets mailing list