[Haskell-beginners] Re: Is Haskell for me?

Nicolas Pouillard nicolas.pouillard at gmail.com
Sat Nov 21 09:10:05 EST 2009


Excerpts from Ben Lippmeier's message of Sat Nov 21 12:56:09 +0100 2009:
> 
> On 21/11/2009, at 21:13 , Nicolas Pouillard wrote:
> 
> > Excerpts from Ben Lippmeier's message of Sat Nov 21 07:38:09 +0100 2009:
> >> 
> >> On 21/11/2009, at 15:36 , Jon Harrop wrote:
> >> 
> >>> The long-standing bug in GHC's garbage collector that makes writing a single 
> >>> boxed value into an array O(n) instead of O(1), because the GC dirties and 
> >>> retraverses the entire array, makes it impossible to write efficient Haskell 
> >>> code to solve many basic problems.
> >> 
> >> Are you talking about http://hackage.haskell.org/trac/ghc/ticket/650 ?
> >> 
> >> The way I read that ticket is that writing a boxed value to a mutable array is still O(1), but the garbage collector traverses the whole array during
> >> scanning. That could certainly slow down GC cycles, but how does it make array update O(n)?
> > 
> > He means in worst case. Writing once, will cause O(n) during the next GC. Of
> > course if you do a lot of updates between two GCs their is no extra penalty.
> > So if you make 'k' updates between 2 GCs it costs you k*O(1)+O(n) which is
> > still O(n) but practically nicer than k*O(n).
> > 

> Hmm. I'd be careful about conflating algorithmic complexity with memory management issues. By the above reasoning, if I were to run any program using
> arrays on a system with a two space garbage collector (which copies all live objects during each GC) I could say the worst case algorithmic complexity was
> O(n). That doesn't sound right.

> I could take this further and say that in a virtual memory system, there is a chance that the whole heap gets copied to the disk and back between each
> array update. I might again say this has O(n) complexity, but it wouldn't be very helpful...

Your algorithm is O(1) but the current run-time system can take a time closer to O(n). This could be the case with a two spaces GC or with swapping.

-- 
Nicolas Pouillard
http://nicolaspouillard.fr


More information about the Beginners mailing list