Mercurial > repos > icfp2014
annotate code/mike00.lm @ 17:c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
author | Michael Pavone <pavone@retrodev.com> |
---|---|
date | Fri, 25 Jul 2014 21:40:49 -0700 |
parents | 89aa6d3165ee |
children | 8ff2349f36c6 |
rev | line source |
---|---|
14
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
1 #{ |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
2 length <- :lst { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
3 len <- [] |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
4 while: { not: (lst isInteger?)} do: { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
5 lst <- lst tail |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
6 len <- len + 1 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
7 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
8 len |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
9 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
10 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
11 reverse <- :lst { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
12 new <- [] |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
13 while: { not: (lst isInteger?)} do: { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
14 new <- (lst value) | new |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
15 lst <- lst tail |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
16 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
17 new |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
18 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
19 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
20 split:at <- :lst :pos { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
21 first <- [] |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
22 i <- 0 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
23 while: { i < pos } do: { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
24 first <- (lst value) | first |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
25 lst <- lst tail |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
26 i <- i + 1 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
27 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
28 #[(reverse: first) lst] |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
29 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
30 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
31 map <- :lst fun { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
32 new <- [] |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
33 while: { not: (lst isInteger?) } do: { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
34 new <- (fun: (lst value)) | new |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
35 lst <- lst tail |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
36 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
37 reverse: new |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
38 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
39 |
17
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
40 makeTree:size <- :lst :size { |
14
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
41 ret <- 0 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
42 sub <- 0 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
43 half <- size / 2 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
44 if: size = 2 { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
45 ret <- #[(lst value) ((lst tail) value)] |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
46 } else: { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
47 if: size = 1 { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
48 ret <- lst |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
49 } else: { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
50 sub <- split: lst at: half |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
51 ret <- #[ |
17
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
52 (makeTree: (sub value) size: half) |
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
53 (makeTree: (sub tail) size: size-half) |
14
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
54 ] |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
55 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
56 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
57 ret |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
58 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
59 |
17
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
60 makeTree <- :lst { |
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
61 size <- lst length |
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
62 #[size (makeTree: lst size: size)] |
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
63 } |
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
64 |
14
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
65 get:fromTree:size <- :idx :tree :size { |
17
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
66 print: #[1 tree size] |
14
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
67 ret <- 0 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
68 half <- size / 2 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
69 if: size <= 2 { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
70 if: idx = 0 { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
71 ret <- tree value |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
72 } else: { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
73 ret <- tree tail |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
74 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
75 } else: { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
76 if: idx < half { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
77 ret <- get: idx fromTree: (tree value) size: half |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
78 } else: { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
79 ret <- get: idx-half fromTree: (tree tail) size: size-half |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
80 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
81 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
82 ret |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
83 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
84 |
17
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
85 get:fromTree <- :idx :tree { |
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
86 size <- tree value |
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
87 print: #[0 size] |
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
88 get: idx fromTree: (tree tail) size: size |
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
89 } |
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
90 |
14
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
91 height <- 0 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
92 width <- 0 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
93 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
94 main <- { |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
95 /* map <- initWorld value |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
96 height <- map length |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
97 width <- (map value) length |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
98 */ |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
99 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
100 lst <- [1 2 3 4 5 6 7 8 9] |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
101 print: (length: lst) |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
102 print: (map: lst :el { el + 1 }) |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
103 print: (split: lst at: (length: lst) / 2) |
17
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
104 tree <- makeTree: lst |
14
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
105 print: tree |
17
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
106 print: (get: 0 fromTree: tree) |
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
107 print: (get: 6 fromTree: tree) |
c33dce59ce3d
Store tree size in outer node so it does not need to be manually passed in
Michael Pavone <pavone@retrodev.com>
parents:
16
diff
changeset
|
108 print: (get: 8 fromTree: tree) |
14
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
109 } |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
110 |
ce68c8a607ee
Added a new file for experimenting with some helper functions
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
111 } |