Mercurial > hg > Members > atton > delta_monad
annotate delta.hs @ 83:6635a513f81a
Add example for DeltaM
author | Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp> |
---|---|
date | Sun, 04 Jan 2015 17:20:33 +0900 |
parents | 1339772b2e36 |
children | 8c7bd8bf8092 |
rev | line source |
---|---|
17
279ebcf670c4
Define Similar as Applicative
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
16
diff
changeset
|
1 import Control.Applicative |
83
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
2 import Control.Monad.Writer |
18
c77397d0677f
Try define Similar as Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
17
diff
changeset
|
3 import Data.Numbers.Primes -- $ cabal install primes |
c77397d0677f
Try define Similar as Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
17
diff
changeset
|
4 |
58 | 5 -- delta definition |
6 | |
57
dfcd72dc697e
ReDefine Delta used non-empty-list for infinite changes
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
53
diff
changeset
|
7 data Delta a = Mono a | Delta a (Delta a) deriving Show |
17
279ebcf670c4
Define Similar as Applicative
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
16
diff
changeset
|
8 |
73
0ad0ae7a3cbe
Proving monad-law-1
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
69
diff
changeset
|
9 instance (Eq a) => Eq (Delta a) where |
0ad0ae7a3cbe
Proving monad-law-1
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
69
diff
changeset
|
10 (Mono x) == (Mono y) = x == y |
0ad0ae7a3cbe
Proving monad-law-1
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
69
diff
changeset
|
11 (Mono _) == (Delta _ _) = False |
0ad0ae7a3cbe
Proving monad-law-1
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
69
diff
changeset
|
12 (Delta x xs) == (Delta y ys) = (x == y) && (xs == ys) |
0ad0ae7a3cbe
Proving monad-law-1
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
69
diff
changeset
|
13 |
58 | 14 -- basic functions |
15 | |
52
69a01cc80075
Define Delta for Infinite changes in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
51
diff
changeset
|
16 deltaAppend :: Delta a -> Delta a -> Delta a |
57
dfcd72dc697e
ReDefine Delta used non-empty-list for infinite changes
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
53
diff
changeset
|
17 deltaAppend (Mono x) d = Delta x d |
dfcd72dc697e
ReDefine Delta used non-empty-list for infinite changes
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
53
diff
changeset
|
18 deltaAppend (Delta x d) ds = Delta x (deltaAppend d ds) |
47
1aefea69f71b
Implement bubble sort by delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
46
diff
changeset
|
19 |
69
295e8ed39c0c
Change headDelta definition. return non-delta value
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
59
diff
changeset
|
20 headDelta :: Delta a -> a |
295e8ed39c0c
Change headDelta definition. return non-delta value
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
59
diff
changeset
|
21 headDelta (Mono x) = x |
295e8ed39c0c
Change headDelta definition. return non-delta value
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
59
diff
changeset
|
22 headDelta (Delta x _) = x |
14
116131b196bb
Define fmap and mu
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
13
diff
changeset
|
23 |
52
69a01cc80075
Define Delta for Infinite changes in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
51
diff
changeset
|
24 tailDelta :: Delta a -> Delta a |
57
dfcd72dc697e
ReDefine Delta used non-empty-list for infinite changes
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
53
diff
changeset
|
25 tailDelta d@(Mono _) = d |
dfcd72dc697e
ReDefine Delta used non-empty-list for infinite changes
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
53
diff
changeset
|
26 tailDelta (Delta _ ds) = ds |
18
c77397d0677f
Try define Similar as Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
17
diff
changeset
|
27 |
58 | 28 -- instance definitions |
29 | |
43
90b171e3a73e
Rename to Delta from Similar
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
23
diff
changeset
|
30 instance Functor Delta where |
57
dfcd72dc697e
ReDefine Delta used non-empty-list for infinite changes
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
53
diff
changeset
|
31 fmap f (Mono x) = Mono (f x) |
dfcd72dc697e
ReDefine Delta used non-empty-list for infinite changes
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
53
diff
changeset
|
32 fmap f (Delta x d) = Delta (f x) (fmap f d) |
18
c77397d0677f
Try define Similar as Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
17
diff
changeset
|
33 |
43
90b171e3a73e
Rename to Delta from Similar
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
23
diff
changeset
|
34 instance Applicative Delta where |
57
dfcd72dc697e
ReDefine Delta used non-empty-list for infinite changes
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
53
diff
changeset
|
35 pure f = Mono f |
dfcd72dc697e
ReDefine Delta used non-empty-list for infinite changes
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
53
diff
changeset
|
36 (Mono f) <*> (Mono x) = Mono (f x) |
dfcd72dc697e
ReDefine Delta used non-empty-list for infinite changes
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
53
diff
changeset
|
37 df@(Mono f) <*> (Delta x d) = Delta (f x) (df <*> d) |
dfcd72dc697e
ReDefine Delta used non-empty-list for infinite changes
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
53
diff
changeset
|
38 (Delta f df) <*> d@(Mono x) = Delta (f x) (df <*> d) |
dfcd72dc697e
ReDefine Delta used non-empty-list for infinite changes
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
53
diff
changeset
|
39 (Delta f df) <*> (Delta x d) = Delta (f x) (df <*> d) |
52
69a01cc80075
Define Delta for Infinite changes in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
51
diff
changeset
|
40 |
59
46b15f368905
Define bind and mu for Infinite Delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
58
diff
changeset
|
41 bind :: (Delta a) -> (a -> Delta b) -> (Delta b) |
46b15f368905
Define bind and mu for Infinite Delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
58
diff
changeset
|
42 bind (Mono x) f = f x |
69
295e8ed39c0c
Change headDelta definition. return non-delta value
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
59
diff
changeset
|
43 bind (Delta x d) f = Delta (headDelta (f x)) (bind d (tailDelta . f)) |
59
46b15f368905
Define bind and mu for Infinite Delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
58
diff
changeset
|
44 |
46b15f368905
Define bind and mu for Infinite Delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
58
diff
changeset
|
45 mu :: (Delta (Delta a)) -> (Delta a) |
46b15f368905
Define bind and mu for Infinite Delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
58
diff
changeset
|
46 mu d = bind d id |
46b15f368905
Define bind and mu for Infinite Delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
58
diff
changeset
|
47 |
43
90b171e3a73e
Rename to Delta from Similar
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
23
diff
changeset
|
48 instance Monad Delta where |
57
dfcd72dc697e
ReDefine Delta used non-empty-list for infinite changes
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
53
diff
changeset
|
49 return x = Mono x |
59
46b15f368905
Define bind and mu for Infinite Delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
58
diff
changeset
|
50 d >>= f = mu $ fmap f d |
46b15f368905
Define bind and mu for Infinite Delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
58
diff
changeset
|
51 |
58 | 52 -- utils |
18
c77397d0677f
Try define Similar as Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
17
diff
changeset
|
53 |
43
90b171e3a73e
Rename to Delta from Similar
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
23
diff
changeset
|
54 returnS :: (Show s) => s -> Delta s |
57
dfcd72dc697e
ReDefine Delta used non-empty-list for infinite changes
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
53
diff
changeset
|
55 returnS x = Mono x |
0
7a82a5e50499
Initial commit. define to Functor for Similer
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
56 |
43
90b171e3a73e
Rename to Delta from Similar
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
23
diff
changeset
|
57 returnSS :: (Show s) => s -> s -> Delta s |
52
69a01cc80075
Define Delta for Infinite changes in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
51
diff
changeset
|
58 returnSS x y = (returnS x) `deltaAppend` (returnS y) |
69a01cc80075
Define Delta for Infinite changes in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
51
diff
changeset
|
59 |
58 | 60 deltaFromList :: [a] -> Delta a |
61 deltaFromList = (foldl1 deltaAppend) . (fmap return) | |
62 | |
23
b4d3960af901
Define similar constructor for different element
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
22
diff
changeset
|
63 |
16
4b315cf0edb9
Improve mu definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
15
diff
changeset
|
64 -- samples |
3
3c5fbce357af
Define >>= for Similer
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
2
diff
changeset
|
65 |
43
90b171e3a73e
Rename to Delta from Similar
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
23
diff
changeset
|
66 generator :: Int -> Delta [Int] |
21
af8754322ed4
Define Similar sample
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
20
diff
changeset
|
67 generator x = let intList = [1..x] in |
22
f0400c4c953f
Imporve Similar definition. delete "Single" constructor
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
21
diff
changeset
|
68 returnS intList |
6 | 69 |
43
90b171e3a73e
Rename to Delta from Similar
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
23
diff
changeset
|
70 primeFilter :: [Int] -> Delta [Int] |
21
af8754322ed4
Define Similar sample
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
20
diff
changeset
|
71 primeFilter xs = let primeList = filter isPrime xs |
23
b4d3960af901
Define similar constructor for different element
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
22
diff
changeset
|
72 refactorList = filter even xs in |
b4d3960af901
Define similar constructor for different element
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
22
diff
changeset
|
73 returnSS primeList refactorList |
11
e8a5df54480e
Define sample for Monad style
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
10
diff
changeset
|
74 |
43
90b171e3a73e
Rename to Delta from Similar
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
23
diff
changeset
|
75 count :: [Int] -> Delta Int |
21
af8754322ed4
Define Similar sample
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
20
diff
changeset
|
76 count xs = let primeCount = length xs in |
22
f0400c4c953f
Imporve Similar definition. delete "Single" constructor
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
21
diff
changeset
|
77 returnS primeCount |
15 | 78 |
43
90b171e3a73e
Rename to Delta from Similar
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
23
diff
changeset
|
79 primeCount :: Int -> Delta Int |
21
af8754322ed4
Define Similar sample
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
20
diff
changeset
|
80 primeCount x = generator x >>= primeFilter >>= count |
46
cb5c190aa45d
Define bubble sort
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
45
diff
changeset
|
81 |
cb5c190aa45d
Define bubble sort
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
45
diff
changeset
|
82 bubbleSort :: [Int] -> Delta [Int] |
48
820af7cc8485
Wrote >>= style bubble sort
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
47
diff
changeset
|
83 bubbleSort [] = returnS [] |
49
d654fdecdcd0
Wrote bubble sort with modified calculate
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
48
diff
changeset
|
84 bubbleSort xs = bubbleSort remainValue >>= (\xs -> returnSS (sortedValueL : xs) |
d654fdecdcd0
Wrote bubble sort with modified calculate
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
48
diff
changeset
|
85 (sortedValueR ++ xs)) |
46
cb5c190aa45d
Define bubble sort
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
45
diff
changeset
|
86 where |
51 | 87 maximumValue = maximum xs |
88 sortedValueL = maximumValue | |
89 sortedValueR = replicate (length $ filter (== maximumValue) xs) maximumValue | |
90 remainValue = filter (/= maximumValue) xs | |
82
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
91 |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
92 -- DeltaM Definition (Delta with Monad) |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
93 |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
94 data DeltaM m a = DeltaM (Delta (m a)) deriving (Show) |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
95 |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
96 |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
97 -- DeltaM utils |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
98 |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
99 headDeltaM :: DeltaM m a -> m a |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
100 headDeltaM (DeltaM (Mono x)) = x |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
101 headDeltaM (DeltaM (Delta x _ )) = x |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
102 |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
103 tailDeltaM :: DeltaM m a -> DeltaM m a |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
104 tailDeltaM d@(DeltaM (Mono _)) = d |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
105 tailDeltaM (DeltaM (Delta _ d)) = DeltaM d |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
106 |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
107 appendDeltaM :: DeltaM m a -> DeltaM m a -> DeltaM m a |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
108 appendDeltaM (DeltaM d) (DeltaM dd) = DeltaM (deltaAppend d dd) |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
109 |
83
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
110 checkOut :: Int -> DeltaM m a -> m a |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
111 checkOut 0 (DeltaM (Mono x)) = x |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
112 checkOut 0 (DeltaM (Delta x _)) = x |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
113 checkOut n (DeltaM (Mono x)) = x |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
114 checkOut n (DeltaM (Delta _ d)) = checkOut (n-1) (DeltaM d) |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
115 |
82
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
116 |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
117 -- DeltaM instance definitions |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
118 |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
119 instance (Functor m) => Functor (DeltaM m) where |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
120 fmap f (DeltaM d) = DeltaM $ fmap (fmap f) d |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
121 |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
122 instance (Applicative m) => Applicative (DeltaM m) where |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
123 pure f = DeltaM $ Mono $ pure f |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
124 (DeltaM (Mono f)) <*> (DeltaM (Mono x)) = DeltaM $ Mono $ f <*> x |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
125 df@(DeltaM (Mono f)) <*> (DeltaM (Delta x d)) = appendDeltaM (DeltaM $ Mono $ f <*> x) (df <*> (DeltaM d)) |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
126 (DeltaM (Delta f df)) <*> dx@(DeltaM (Mono x)) = appendDeltaM (DeltaM $ Mono $ f <*> x) ((DeltaM df) <*> dx) |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
127 (DeltaM (Delta f df)) <*> (DeltaM (Delta x dx)) = appendDeltaM (DeltaM $ Mono $ f <*> x) ((DeltaM df) <*> (DeltaM dx)) |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
128 |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
129 instance (Monad m) => Monad (DeltaM m) where |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
130 return x = DeltaM $ Mono $ return x |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
131 (DeltaM (Mono x)) >>= f = DeltaM $ Mono $ (x >>= headDeltaM . f) |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
132 (DeltaM (Delta x d)) >>= f = appendDeltaM ((DeltaM $ Mono x) >>= f) |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
133 ((DeltaM d) >>= tailDeltaM . f) |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
134 |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
135 |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
136 -- DeltaM examples |
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
137 |
83
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
138 -- DeltaM example utils |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
139 type DeltaLog = Writer [String] |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
140 |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
141 returnW :: (Show a) => a -> DeltaLog a |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
142 returnW x = do tell $ [show x] |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
143 return x |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
144 |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
145 dmap :: (m a -> b) -> DeltaM m a -> Delta b |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
146 dmap f (DeltaM (Mono mx)) = (Mono $ f mx) |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
147 dmap f (DeltaM (Delta x d)) = Delta (f x) (dmap f (DeltaM d)) |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
148 |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
149 |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
150 -- example : prime filter |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
151 -- usage : runWriter $ checkOut 0 $ primeCountM 30 -- run specific version |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
152 -- : dmap runWriter $ primeCountM 30 -- run all version |
82
1339772b2e36
Define DeltaM. Delta with Monad
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
73
diff
changeset
|
153 |
83
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
154 generatorM :: Int -> DeltaM DeltaLog [Int] |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
155 generatorM x = let intList = returnW [1..x] in |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
156 DeltaM $ deltaFromList $ [intList, intList] |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
157 |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
158 primeFilterM :: [Int] -> DeltaM DeltaLog [Int] |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
159 primeFilterM xs = let primeList = filter isPrime xs |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
160 refactorList = filter even xs in |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
161 DeltaM $ deltaFromList $ fmap returnW [primeList, refactorList] |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
162 |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
163 |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
164 countM :: [Int] -> DeltaM DeltaLog Int |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
165 countM xs = let primeCount = length xs in |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
166 DeltaM $ deltaFromList $ fmap returnW [primeCount, primeCount] |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
167 |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
168 primeCountM :: Int -> DeltaM DeltaLog Int |
6635a513f81a
Add example for DeltaM
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
82
diff
changeset
|
169 primeCountM x = generatorM x >>= primeFilterM >>= countM |