[Haskell-cafe] Reflections on the ICFP 2009 programming contest

Rafael Gustavo da Cunha Pereira Pinto RafaelGCPP.Linux at gmail.com
Mon Jun 29 15:07:42 EDT 2009


I spent too much time reading the files, until today, when Minh Tuh pointed
me the right direction on reading the floats...

Anyway, I will still keep trying until Xmas :-)



On Mon, Jun 29, 2009 at 15:40, Justin Bailey <jgbailey at gmail.com> wrote:

> Anyone have thoughts to share? I'd love to read others' experiences
> but there isn't much coming up with searches or on redditt ...
>
> I was happiest with the VM I implemented. Sadly, I wasn't able to
> solve any of the scenarios, but my VM ran damn fast. That didn't seem
> to matter so much this year as it did two years ago - I think I am
> still scarred by Endo's DNA ..
>
> Anyways, for those who care, the heart of my VM implementation was a
> monadic fold over the program, with a mutable array representing the
> machine's memory, all inside ''runSTUArray.'' I used a simple data
> type to represent the machine:
>
> data Machine = Machine { instrs :: [OpCode]
>                       , dataMem :: UArray Int Val
>                       , outputs :: UArray Int Val
>                       , status :: !Int
>                       , inputs :: IntMap Val }
>
> where ''dataMem'' holds the data memory area. To execute a program, I
> folded over the ''instrs'' list and updated memory as I went:
>
> exec :: Machine -> Input -> Machine
> exec m@(Machine { instrs = instrs }) inps =
>    let m' = m { inputs = readInputs inps }
>        newMem = runSTUArray $ do
>            mem' <- thaw (dataMem m)
>            foldM (step m') mem' (zip instrs [0..])
>
> I considered ''unsafeThaw'' in the above, but performance didn't hurt
> me much and it seemed safer. Since I was recording all output I was
> worried that would break referential integrity. In any case, when the
> fold was finished I just assigned ''newMem'' to the new machine and
> moved to the next iteration.
>
> ''step'' takes the mutable array and updates it while the program
> executes. I won't show the whole body, as it just a separate
> definition for each opcode, just the type:
>
>  step :: Machine -> STUArray s Int Val -> (OpCode, Addr) -> ST s
> (STUArray s Int Val)
>
> The only downside to this approach was the machine had three mutuable
> states: memory, output, and status. runSTUArray only wants to return a
> single array so inside step I had to hold all values in one array. Not
> a big deal but a little ugly.
>
> I kept a diary of my experience over the weekend at
> http://icfp2009.codeslower.com. I started out with such optimism ...
> Stil, I'm glad to have done it. Lots of fun! My thanks to the
> organizers!
> _______________________________________________
> Haskell-Cafe mailing list
> Haskell-Cafe at haskell.org
> http://www.haskell.org/mailman/listinfo/haskell-cafe
>



-- 
Rafael Gustavo da Cunha Pereira Pinto
Electronic Engineer, MSc.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://www.haskell.org/pipermail/haskell-cafe/attachments/20090629/10ee15a5/attachment.html


More information about the Haskell-Cafe mailing list