forked from panesofglass/StateMonad
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMumble002.lhs
59 lines (41 loc) · 1.34 KB
/
Mumble002.lhs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
Non-monadic tree labeling:
> data Tr a = Lf a | Br (Tr a) (Tr a)
> deriving Show
> tr1 = Br (Lf 'a') (Br (Br (Lf 'b') (Lf 'a')) (Lf 'd'))
> type Lt a = (Tr (S, a))
> type S = Int
> label :: Tr a -> Lt a
> label tr = snd (lab tr 0)
> where
> lab :: Tr a -> S -> (S, Lt a)
> lab (Lf contents) n = ((n+1), (Lf (n, contents)))
> lab (Br l r) n0 = let (n1, l') = lab l n0
> (n2, r') = lab r n1
> in (n2, Br l' r')
Monadic tree labeling:
> newtype Labeled anytype = Labeled (S -> (S, anytype))
> instance Monad Labeled where
> return contents = Labeled (\st -> (st, contents))
> Labeled fst0 >>= fany1 =
> Labeled $ \st0 ->
> let (st1, any1) = fst0 st0
> Labeled fst1 = fany1 any1
> in fst1 st1
> mlabel :: Tr anytype -> Lt anytype
> mlabel tr = let Labeled mt = mkm tr
> in snd (mt 0)
> mkm :: Tr anytype -> Labeled (Lt anytype)
> mkm (Lf x)
> = updateState >>= \n -> return $ Lf (n,x)
Alternative: do n <- updateState
return $ Lf (n,x)
> mkm (Br l r)
> = mkm l >>= \l' ->
> mkm r >>= \r' ->
> return $ (Br l' r')
Alternative: do l' <- mkm l
r' <- mkm r
return $ (Br l' r')
> updateState :: Labeled S
> updateState = Labeled (\n -> ((n+1),n))
> main = print $ mlabel tr1