725
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
1 |
abstract class Token
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
2 |
case object T_SEMI extends Token
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
3 |
case object T_LPAREN extends Token
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
4 |
case object T_RPAREN extends Token
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
5 |
case class T_ID(s: String) extends Token
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
6 |
case class T_OP(s: String) extends Token
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
7 |
case class T_NUM(n: Int) extends Token
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
8 |
case class T_KWD(s: String) extends Token
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
9 |
case class T_STR(s: String) extends Token
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
10 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
11 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
12 |
// Loops program
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
13 |
//===============
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
14 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
15 |
/*
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
16 |
start := 1000;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
17 |
x := start;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
18 |
y := start;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
19 |
z := start;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
20 |
while 0 < x do {
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
21 |
while 0 < y do {
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
22 |
while 0 < z do { z := z - 1 };
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
23 |
z := start;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
24 |
y := y - 1
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
25 |
};
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
26 |
y := start;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
27 |
x := x - 1
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
28 |
}
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
29 |
*/
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
30 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
31 |
val loops =
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
32 |
List(T_ID("start"), T_OP(":="), T_NUM(1000), T_SEMI, T_ID("x"), T_OP(":="),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
33 |
T_ID("start"), T_SEMI, T_ID("y"), T_OP(":="), T_ID("start"), T_SEMI,
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
34 |
T_ID("z"), T_OP(":="), T_ID("start"), T_SEMI, T_KWD("while"), T_NUM(0),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
35 |
T_OP("<"), T_ID("x"), T_KWD("do"), T_LPAREN, T_KWD("while"), T_NUM(0),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
36 |
T_OP("<"), T_ID("y"), T_KWD("do"), T_LPAREN, T_KWD("while"), T_NUM(0),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
37 |
T_OP("<"), T_ID("z"), T_KWD("do"), T_LPAREN, T_ID("z"), T_OP(":="),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
38 |
T_ID("z"), T_OP("-"), T_NUM(1), T_RPAREN, T_SEMI, T_ID("z"), T_OP(":="),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
39 |
T_ID("start"), T_SEMI, T_ID("y"), T_OP(":="), T_ID("y"), T_OP("-"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
40 |
T_NUM(1), T_RPAREN, T_SEMI, T_ID("y"), T_OP(":="), T_ID("start"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
41 |
T_SEMI, T_ID("x"), T_OP(":="), T_ID("x"), T_OP("-"), T_NUM(1), T_RPAREN)
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
42 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
43 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
44 |
// Fib program
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
45 |
//=============
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
46 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
47 |
/*
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
48 |
write "Fib";
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
49 |
read n;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
50 |
minus1 := 0;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
51 |
minus2 := 1;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
52 |
while n > 0 do {
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
53 |
temp := minus2;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
54 |
minus2 := minus1 + minus2;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
55 |
minus1 := temp;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
56 |
n := n - 1
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
57 |
};
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
58 |
write "Result";
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
59 |
write minus2
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
60 |
*/
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
61 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
62 |
val fib =
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
63 |
List(T_KWD("write"), T_STR("Fib"), T_SEMI, T_KWD("read"), T_ID("n"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
64 |
T_SEMI, T_ID("minus1"), T_OP(":="), T_NUM(0), T_SEMI, T_ID("minus2"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
65 |
T_OP(":="), T_NUM(1), T_SEMI, T_KWD("while"), T_ID("n"), T_OP(">"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
66 |
T_NUM(0), T_KWD("do"), T_LPAREN, T_ID("temp"), T_OP(":="),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
67 |
T_ID("minus2"), T_SEMI, T_ID("minus2"), T_OP(":="), T_ID("minus1"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
68 |
T_OP("+"), T_ID("minus2"), T_SEMI, T_ID("minus1"), T_OP(":="),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
69 |
T_ID("temp"), T_SEMI, T_ID("n"), T_OP(":="), T_ID("n"), T_OP("-"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
70 |
T_NUM(1), T_RPAREN, T_SEMI, T_KWD("write"), T_STR("Result"), T_SEMI,
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
71 |
T_KWD("write"), T_ID("minus2"))
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
72 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
73 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
74 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
75 |
// Factors program
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
76 |
//=================
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
77 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
78 |
/*
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
79 |
write "Input n please";
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
80 |
read n;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
81 |
write "The factors of n are";
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
82 |
f := 2;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
83 |
while n != 1 do {
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
84 |
while (n / f) * f == n do {
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
85 |
write f;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
86 |
n := n / f
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
87 |
};
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
88 |
f := f + 1
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
89 |
}
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
90 |
*/
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
91 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
92 |
val factors =
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
93 |
List(T_KWD("write"), T_STR("Input n please"), T_SEMI, T_KWD("read"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
94 |
T_ID("n"), T_SEMI, T_KWD("write"), T_STR("The factors of n are"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
95 |
T_SEMI, T_ID("f"), T_OP(":="), T_NUM(2), T_SEMI, T_KWD("while"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
96 |
T_ID("n"), T_OP("!="), T_NUM(1), T_KWD("do"), T_LPAREN,
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
97 |
T_KWD("while"), T_ID("n"), T_OP("/"), T_ID("f"), T_OP("*"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
98 |
T_ID("f"), T_OP("=="), T_ID("n"), T_KWD("do"), T_LPAREN,
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
99 |
T_KWD("write"), T_ID("f"), T_SEMI, T_ID("n"), T_OP(":="),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
100 |
T_ID("n"), T_OP("/"), T_ID("f"), T_RPAREN, T_SEMI, T_ID("f"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
101 |
T_OP(":="), T_ID("f"), T_OP("+"), T_NUM(1), T_RPAREN)
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
102 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
103 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
104 |
// Primes program
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
105 |
//================
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
106 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
107 |
/*
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
108 |
end := 100;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
109 |
n := 2;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
110 |
while (n < end) do {
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
111 |
f := 2;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
112 |
tmp := 0;
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
113 |
while ((f < n / 2 + 1) && (tmp == 0)) do {
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
114 |
if ((n / f) * f == n) then { tmp := 1 } else { skip };
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
115 |
f := f + 1
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
116 |
};
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
117 |
if (tmp == 0) then { write(n) } else { skip };
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
118 |
n := n + 1
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
119 |
}
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
120 |
*/
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
121 |
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
122 |
val primes =
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
123 |
List(T_ID("end"), T_OP(":="), T_NUM(100), T_SEMI, T_ID("n"), T_OP(":="),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
124 |
T_NUM(2), T_SEMI, T_KWD("while"), T_ID("n"), T_OP("<"), T_ID("end"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
125 |
T_KWD("do"), T_LPAREN, T_ID("f"), T_OP(":="), T_NUM(2), T_SEMI,
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
126 |
T_ID("tmp"), T_OP(":="), T_NUM(0), T_SEMI, T_KWD("while"), T_ID("f"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
127 |
T_OP("<"), T_ID("n"), T_OP("/"), T_NUM(2), T_OP("+"), T_NUM(1),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
128 |
T_OP("&&"), T_ID("tmp"), T_OP("=="), T_NUM(0), T_KWD("do"), T_LPAREN,
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
129 |
T_KWD("if"), T_ID("n"), T_OP("/"), T_ID("f"), T_OP("*"), T_ID("f"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
130 |
T_OP("=="), T_ID("n"), T_KWD("then"), T_LPAREN, T_ID("tmp"), T_OP(":="),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
131 |
T_NUM(1), T_RPAREN, T_KWD("else"), T_LPAREN, T_KWD("skip"), T_RPAREN,
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
132 |
T_SEMI, T_ID("f"), T_OP(":="), T_ID("f"), T_OP("+"), T_NUM(1),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
133 |
T_RPAREN, T_SEMI, T_KWD("if"), T_ID("tmp"), T_OP("=="), T_NUM(0),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
134 |
T_KWD("then"), T_LPAREN, T_KWD("write"), T_ID("n"), T_RPAREN,
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
135 |
T_KWD("else"), T_LPAREN, T_KWD("skip"), T_RPAREN, T_SEMI, T_ID("n"),
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
136 |
T_OP(":="), T_ID("n"), T_OP("+"), T_NUM(1), T_RPAREN)
|