forked from kanaka/mal
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathperf.mal
41 lines (36 loc) · 1.17 KB
/
perf.mal
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
;; Mesure performances.
(load-file "../lib/load-file-once.mal")
(load-file-once "../lib/trivial.mal") ; gensym inc
;; Evaluate an expression, but report the time spent
(defmacro! time
(fn* (exp)
(let* [start (gensym)
ret (gensym)]
`(let* (~start (time-ms)
~ret ~exp)
(do
(println "Elapsed time:" (- (time-ms) ~start) "msecs")
~ret)))))
;; Count evaluations of a function during a given time frame.
(def! run-fn-for
(let* [
run-fn-for* (fn* [fn max-ms acc-ms last-iters]
(let* [start (time-ms)
_ (fn)
elapsed (- (time-ms) start)
iters (inc last-iters)
new-acc-ms (+ acc-ms elapsed)]
;; (do (prn "new-acc-ms:" new-acc-ms "iters:" iters))
(if (>= new-acc-ms max-ms)
last-iters
(run-fn-for* fn max-ms new-acc-ms iters))))
]
(fn* [fn max-secs]
;; fn : function without parameters
;; max-secs : number (seconds)
;; return : number (iterations)
(do
;; Warm it up first
(run-fn-for* fn 1000 0 0)
;; Now do the test
(run-fn-for* fn (* 1000 max-secs) 0 0)))))