X-Git-Url: http://lambda.jimpryor.net/git/gitweb.cgi?p=lambda.git;a=blobdiff_plain;f=manipulating_trees_with_monads.mdwn;h=ba990d10b63229290fa195be8cf24c967a084593;hp=3b43c9a51938a55e014d86462e449ca6d0d76f3a;hb=b95d7b2ff99ed407766dd37253d5d728b41b64e0;hpb=22b8f082095efe49f44171ffa67246a58e298402 diff --git a/manipulating_trees_with_monads.mdwn b/manipulating_trees_with_monads.mdwn index 3b43c9a5..ba990d10 100644 --- a/manipulating_trees_with_monads.mdwn +++ b/manipulating_trees_with_monads.mdwn @@ -13,7 +13,7 @@ From an engineering standpoint, we'll build a tree transformer that deals in monads. We can modify the behavior of the system by swapping one monad for another. We've already seen how adding a monad can add a layer of funtionality without disturbing the underlying system, for -instance, in the way that the reader monad allowed us to add a layer +instance, in the way that the Reader monad allowed us to add a layer of intensionality to an extensional grammar, but we have not yet seen the utility of replacing one monad with other. @@ -84,11 +84,11 @@ supplying the appropriate `int -> int` operation in place of `double`: Note that what `tree_map` does is take some unchanging contextual information---what to do to each leaf---and supplies that information to each subpart of the computation. In other words, `tree_map` has the -behavior of a reader monad. Let's make that explicit. +behavior of a Reader monad. Let's make that explicit. In general, we're on a journey of making our `tree_map` function more and more flexible. So the next step---combining the tree transformer with -a reader monad---is to have the `tree_map` function return a (monadized) +a Reader monad---is to have the `tree_map` function return a (monadized) tree that is ready to accept any `int -> int` function and produce the updated tree. @@ -190,7 +190,7 @@ result: Now that we have a tree transformer that accepts a *reader* monad as a parameter, we can see what it would take to swap in a different monad. -For instance, we can use a state monad to count the number of leaves in +For instance, we can use a State monad to count the number of leaves in the tree. type 'a state = int -> 'a * int;; @@ -238,7 +238,7 @@ One more revealing example before getting down to business: replacing Unlike the previous cases, instead of turning a tree into a function from some input to a result, this transformer replaces each `int` with -a list of `int`'s. We might also have done this with a Reader Monad, though then our environments would need to be of type `int -> int list`. Experiment with what happens if you supply the `tree_monadize` based on the List Monad an operation like `fun -> [ i; [2*i; 3*i] ]`. Use small trees for your experiment. +a list of `int`'s. We might also have done this with a Reader monad, though then our environments would need to be of type `int -> int list`. Experiment with what happens if you supply the `tree_monadize` based on the List monad an operation like `fun -> [ i; [2*i; 3*i] ]`. Use small trees for your experiment.