[Haskell-cafe] Data.IArray rant

Ivan Lazar Miljenovic ivan.miljenovic at gmail.com
Sat Sep 3 06:20:42 CEST 2011


On 3 September 2011 12:53, Evan Laforge <qdunkan at gmail.com> wrote:
>
>> To an extent, I wonder how much of this has been that arrays were
>> considered to be bad in Haskell, so no-one used them and no-one
>> bothered to try and improve the API much (and instead went and created
>> Vector, etc.).
>
> Right, so we have arrays with nicer APIs, it's just that IArray has
> been kind of left behind.  I don't think arrays are bad in haskell, if
> that were true all those array libraries wouldn't be so popular!  They
> might not be quite the go-to type as in other languages, but they
> still have their uses.

By "bad" I was referring to the API, not the data structure itself.

>> Any particular reason you used Data.Graph rather than fgl, etc.?
>
> Well... it's built-in... I needed something simple... so I just hit
> the ghc stdlib doc and searched for "graph".  Is this another "left
> behind" module?  And if so... well, maybe it's in the same situation
> as IArray.

Pretty much; most people don't even think much of FGL.  I _really_
should get around to expanding and improving Edward Kmett's graph
library so that it covers more of a variety of common graph types and
operations, but I've been busy on specialised graph libraries that I
need lately.

> Right, it's hard to dislike the underlying data structure, arrays are
> about as simple as you can get :)  My guess was the same as yours,
> i.e. that it's been sort of neglected but it's a bootlib and H98 so
> nothing can happen to it quickly.
>
> I can't realistically suggest a course of action here, other than
> "gosh someone should update these modules" to which everyone is likely
> to say "yes, it would be nice if you did that" :)  Or maybe in 10
> years vector will be mature and standard and the old Array stuff can
> be deprecated and removed.  So that's why this was more of a little
> rant than actual constructive comment.

Maybe as a stop-gap some more useful/constructive
examples/documentation on how to use Data.Array.IArray compared to
vector, etc.?  That said, apart from Data.Graph I don't know of many
uses of it nowadays, as everyone seems to have migrated to vector for
1-Dimensional and hmatrix/repa for multi-dimensional.

-- 
Ivan Lazar Miljenovic
Ivan.Miljenovic at gmail.com
IvanMiljenovic.wordpress.com



More information about the Haskell-Cafe mailing list