[Haskell-cafe] Very crazy

Andrew Coppin andrewcoppin at btinternet.com
Tue Sep 25 05:45:15 EDT 2007


Neil Mitchell wrote:
> Hi
>
> A nice auxiliary would help:
>
> showEqn :: Int -> [Double] -> String
> showEqn i vs = ...
>     where
>           (add,ans) = (init vs, last vs)
>
> Then you can half the complexity. There are probably a few useful
> functions that aren't in the standard libraries (consperse, joinWith
> etc) that you could make use of.
>   

OK, I'll give that a go...

(Actually, at present it's an "augmented matrix", represented as 
[[Double]]. I'm thinking by making it a matrix and seperate vector, I 
could reduce the runtime quite significantly by making it much faster to 
get hold of the RHS.)

BTW, one *extremely* common function that I've never seen mentioned 
anywhere is this one:

  map2 :: (a -> b) -> [[a]] -> [[b]]
  map2 f = map (map f)

I cannot understand why this isn't already in the standard libraries...

> You seem to be doing take 8 on the double - what if the double prints
> out more information than this as the result of show?
> 1000000000000000000 could end up a bit smaller.
>   

The contents of the matrix are random numbers between 0 and 100. The 
problems happen if one of the numbers turns out to be something like 
"3.5847368473587e-27" or something. Then it will look many thousands of 
times BIGGER! ;-)

Still, since Haskell seems to be devoid of any more advanced way of 
formatting numbers beyond low-level character jiggling...



More information about the Haskell-Cafe mailing list