494
|
1 |
|
|
2 |
def urbanmain() = {
|
|
3 |
|
|
4 |
import M5a._
|
392
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
5 |
|
463
|
6 |
|
494
|
7 |
import scala.concurrent._
|
|
8 |
import scala.concurrent.duration._
|
|
9 |
import ExecutionContext.Implicits.global
|
|
10 |
import scala.language.postfixOps
|
463
|
11 |
|
494
|
12 |
lazy val f = Future {
|
463
|
13 |
|
494
|
14 |
assert(run("[-]", Map(0 -> 100)) == Map(0 -> 0))
|
|
15 |
assert(run("[->+<]", Map(0 -> 10)) == Map(0 -> 0, 1 -> 10))
|
|
16 |
assert(run("[>>+>>+<<<<-]", Map(0 -> 42)) == Map(0 -> 0, 2 -> 42, 4 -> 42))
|
424
|
17 |
|
392
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
18 |
|
494
|
19 |
val hw_urban = """+++++[->++++++++++<]>--<+++[->>++++++++++
|
392
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
20 |
<<]>>++<<----------[+>.>.<+<]"""
|
494
|
21 |
assert(run(hw_urban) == Map(0 -> 0, 1 -> 58, 2 -> 32))
|
392
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
22 |
|
494
|
23 |
val hw_urban1 = """++++++++[>++++[>++>+++>+++>+<<<<-]>+>+>->>+[<]<-]>>.>---.
|
392
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
24 |
+++++++..+++.>>.<-.<.+++.------.--------.>>+.>++."""
|
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff
changeset
|
25 |
|
494
|
26 |
assert(run(hw_urban1) == Map(0 -> 0, 5 -> 33, 1 -> 0, 6 -> 10, 2 -> 72, 3 -> 100, 4 -> 87))
|
463
|
27 |
|
494
|
28 |
}
|
|
29 |
|
|
30 |
Await.result(f, 32 second)
|
463
|
31 |
}
|