[Haskell-cafe] Optimizing 'sequence'

Gracjan Polak gracjanpolak at gmail.com
Mon Jul 21 14:54:09 EDT 2008


Hi all,

On the other day I noticed that we could optimize 'sequence' more.
I needed it for my monadic parser. Below is my small experiment.
Sequence from standard library needs 2.3s to finish (and additional
stack space), my version uses only 0.65s and default stack.

Is my version better or am I missing something obvious?

-- standard
sequence1       :: Monad m => [m a] -> m [a]
sequence1 ms = foldr k (return []) ms
            where
              k m m' = do { x <- m; xs <- m'; return (x:xs) }

-- accumulator version
sequence2       :: Monad m => [m a] -> m [a]
sequence2 ms = sequence' [] ms
    where
        sequence' vs [] = return (reverse vs)
        sequence' vs (m:ms) = m >>= (\v -> sequence' (v:vs) ms)

main = do
    let l = map return [1..1000000]
    w <- sequence1 l
    print (sum w)
    return ()

gracjan at home:~/some_faster> time ./Some1 +RTS -K100M
500000500000

real    0m2.318s
user    0m2.284s
sys     0m0.032s


gracjan at home:~/some_faster> time ./Some2
500000500000

real    0m0.652s
user    0m0.592s
sys     0m0.052s

--
Gracjan




More information about the Haskell-Cafe mailing list