aboutsummaryrefslogtreecommitdiff
path: root/src/test/bench
diff options
context:
space:
mode:
authorGraydon Hoare <[email protected]>2010-06-23 21:03:09 -0700
committerGraydon Hoare <[email protected]>2010-06-23 21:03:09 -0700
commitd6b7c96c3eb29b9244ece0c046d3f372ff432d04 (patch)
treeb425187e232966063ffc2f0d14c04a55d8f004ef /src/test/bench
parentInitial git commit. (diff)
downloadrust-d6b7c96c3eb29b9244ece0c046d3f372ff432d04.tar.xz
rust-d6b7c96c3eb29b9244ece0c046d3f372ff432d04.zip
Populate tree.
Diffstat (limited to 'src/test/bench')
-rw-r--r--src/test/bench/shootout/ackermann.rs25
-rw-r--r--src/test/bench/shootout/binary-trees.rs15
-rw-r--r--src/test/bench/shootout/fibo.rs22
3 files changed, 62 insertions, 0 deletions
diff --git a/src/test/bench/shootout/ackermann.rs b/src/test/bench/shootout/ackermann.rs
new file mode 100644
index 00000000..27b4c3c0
--- /dev/null
+++ b/src/test/bench/shootout/ackermann.rs
@@ -0,0 +1,25 @@
+// -*- rust -*-
+
+fn ack(int m, int n) -> int {
+ if (m == 0) {
+ ret n+1;
+ } else {
+ if (n == 0) {
+ ret ack(m-1, 1);
+ } else {
+ ret ack(m-1, ack(m, n-1));
+ }
+ }
+}
+
+fn main() {
+ check (ack(0,0) == 1);
+ check (ack(3,2) == 29);
+ check (ack(3,4) == 125);
+
+ // This takes a while; but a comparison may amuse: on win32 at least, the
+ // posted C version of the 'benchmark' running ack(4,1) overruns its stack
+ // segment and crashes. We just grow our stack (to 4mb) as we go.
+
+ // check (ack(4,1) == 65533);
+} \ No newline at end of file
diff --git a/src/test/bench/shootout/binary-trees.rs b/src/test/bench/shootout/binary-trees.rs
new file mode 100644
index 00000000..bb3ab602
--- /dev/null
+++ b/src/test/bench/shootout/binary-trees.rs
@@ -0,0 +1,15 @@
+type tree = tag(nil(), node(@tree, @tree, int));
+
+fn item_check(&tree t) -> int {
+ alt (t) {
+ case (nil()) {
+ ret 0;
+ }
+ case (node(@tree left, @tree right, int item)) {
+ ret item + item_check(left) - item_check(right);
+ }
+ }
+}
+
+fn main() {
+} \ No newline at end of file
diff --git a/src/test/bench/shootout/fibo.rs b/src/test/bench/shootout/fibo.rs
new file mode 100644
index 00000000..9045f381
--- /dev/null
+++ b/src/test/bench/shootout/fibo.rs
@@ -0,0 +1,22 @@
+// -*- rust -*-
+
+fn fib(int n) -> int {
+ // Several of the posted 'benchmark' versions of this compute the
+ // wrong Fibonacci numbers, of course.
+ if (n == 0) {
+ ret 0;
+ } else {
+ if (n <= 2) {
+ ret 1;
+ } else {
+ ret fib(n-1) + fib(n-2);
+ }
+ }
+}
+
+fn main() {
+ check (fib(8) == 21);
+ check (fib(15) == 610);
+ log fib(8);
+ log fib(15);
+}