ref: fff86746c7d0a817d504a54a0db417107a44fe85
parent: 2282a527e0baad565075bdeb574b5b0b69f6f1d4
author: Sigrid Solveig Haflínudóttir <[email protected]>
date: Wed Dec 18 21:14:30 EST 2024
add bench.lsp
--- a/meson.build
+++ b/meson.build
@@ -218,7 +218,8 @@
tests_dir = join_paths(meson.current_source_dir(), 'test')
test('argv.lsp', flisp, args: ['argv.lsp'], workdir: tests_dir)
-test('hash.lsp', flisp, args: ['hashtest.lsp'], workdir: tests_dir)
+test('bench.lsp', flisp, args: ['bench.lsp'], workdir: tests_dir)
+test('hashtest.lsp', flisp, args: ['hashtest.lsp'], workdir: tests_dir)
test('mp.lsp', flisp, args: ['mp.lsp'], workdir: tests_dir)
test('perf.lsp', flisp, args: ['perf.lsp'], workdir: tests_dir, timeout: -1)
test('tme.lsp', flisp, args: ['tme.lsp'], workdir: tests_dir)
--- /dev/null
+++ b/test/bench.lsp
@@ -1,0 +1,36 @@
+(load "test.lsp")
+
+;; each benchmark is repeated N times to accomodate
+;; for the performance increase of current systems
+(define N 100)
+
+;; "Performance and Evaluation of Lisp Systems" (1985), Richard P. Gabriel
+(princ "tak: ")
+(define (tak x y z)
+ (if (not (< y x))
+ z
+ (tak (tak (- x 1) y z)
+ (tak (- y 1) z x)
+ (tak (- z 1) x y))))
+(time (dotimes (n N) (assert (equal? 7 (tak 18 12 6)))))
+
+;; same as tak, but:
+;; (not (< → (>=
+;; (- ... 1 → (1-
+;; this will show how extra calls (no inlining) make things slow
+(princ "tak_: ")
+(define (tak_ x y z)
+ (if (>= y x)
+ z
+ (tak_ (tak_ (1- x) y z)
+ (tak_ (1- y) z x)
+ (tak_ (1- z) x y))))
+(time (dotimes (n N) (assert (equal? 7 (tak_ 18 12 6)))))
+
+;; q2 - http://lispology.com/show?314T
+(princ "q2: ")
+(define (q2 x y)
+ (if (or (< x 1) (< y 1)) 1
+ (+ (q2 (- x (q2 (- x 1) y)) y)
+ (q2 x (- y (q2 x (- y 1)))))))
+(time (dotimes (n N) (assert (equal? 31 (q2 7 8)))))
--- a/test/mkfile
+++ b/test/mkfile
@@ -1,3 +1,3 @@
test:QV:
- for(t in unittest.lsp argv.lsp hashtest.lsp torus.lsp tme.lsp mp.lsp perf.lsp torture.scm)
+ for(t in unittest.lsp argv.lsp bench.lsp hashtest.lsp torus.lsp tme.lsp mp.lsp perf.lsp torture.scm)
../$O.out $t