[Haskell-cafe] Haskell vs GC'd imperative languages, threading,
parallelizeability (is that a word? :-D )
Spencer Janssen
sjanssen at cse.unl.edu
Fri Aug 10 16:51:24 EDT 2007
On Friday 10 August 2007 03:51:49 Hugh Perkins wrote:
> Well, managed to shave 25% of C# execution time by writing my own bit
> array. For now, I will concede that, under the conditions of the shoot,
> bitarrays in c# are slower than bitarrays in Haskell. I'll let you know if
> I get any new ideas on this.
>
>
> Getting back to the original problem, which is: threading. Donald, one of
> the things that is very interesting about Haskell is it's potential for
> automatic threading, ie you write a trivial algorithm that looks like it
> runs in a single thread, and the runtime splits it across multiple cores
> automatically.
>
> It's fairly safe to say that maps, foldrs, foldls, and their derivatives
> are safe to parallelize? (For example, hand-waving argument, a foldr of
> (/) on [1,5,7,435,46,2] can be split into a foldr on [1,5,7] and a foldr on
> [435,46,2], then their results combined).
Yes, the semantics of Haskell allow us to run pretty much any operation in
parallel. However, the major problem is that lists are a fundamentally
sequential data structure. It's quite expensive to chop up parts of a list
to eg. send them to a parallel map function. I think the upcoming NDP arrays
have a much better chance here.
> To what extent is the technology you are using in your algorithm
> parallizable? (I actually cant tell, it's a genuine question). In the
> case that it is parallelizable, to what extent is it trivial for a runtime
> to know this? (Again, I dont have enough information to tell)
The program doesn't have much chance for parallelism as written. It uses the
imperative ST monad and destructive update extensively.
Spencer Janssen
More information about the Haskell-Cafe
mailing list