-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbrainstorm.ml
100 lines (67 loc) · 1.02 KB
/
brainstorm.ml
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
mul3 :: Int -> Int -> Int -> Int
mul3 a b c =
a * b * c
mul3 a =
\b -> (\c -> a * b * c)
.mul3 .params a
.lambda .params b
.lambda .params c
.loads a
.loads b
.imul
.loads c
.imul
.mul3 [a: Int]
.lambda [b: Int] .captures [a]
.lambda [c: Int] .captures [a. b]
.iload a
.iload b
.imul
.iload c
.imul
.def mul3 [a: Int]
.def $0 [a, b, c]
a * b * c
.def $1 [a, b]
.partial $0 [a, b]
.partial $1 [a]
mul a b =
a * b
main () =
mul 3 5
.def mul [a: Int]
.def $0 [a, b]
a * b
.partial $0 [a]
.def main
.iconst 3
.call mul
.iconst 5
.apply
# capturing
foo :: Int -> Int -> Int
foo a =
print a
\b ->
print b
b
.def foo [a: Int]
.load %a
.call print
.lambda $0 [b: Int]
.load b
.ret
.ret
foo :: Int -> Int -> Int
foo a =
print a
\b ->
print b
a * b
.def foo [a: Int]
.load %a
.call print
.lambda $0 [b: Int]
.load b
.ret
.ret