123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198 |
- ;INSERTCODE
- ;------------------------------------------------------------------------------
- (define (time* thunk)
- (let* ((start (receive (u s) (cpu-time) (+ u s)))
- (start-real (current-milliseconds)))
- (let ((result (thunk)))
- (let* ((end (receive (u s) (cpu-time) (+ u s)))
- (end-real (current-milliseconds)))
- (let ((cpu (- end start))
- (real (- end-real start-real)))
- (display "cpu time: ")
- (display cpu)
- (display " real time: ")
- (display real)
- (newline)
- result)))))
- (define (run-bench name count ok? run)
- (let loop ((i count) (result '(undefined)))
- (if (< 0 i)
- (loop (- i 1) (run))
- result)))
- (define (run-benchmark name count ok? run-maker . args)
- (newline)
- (let* ((run (apply run-maker args))
- (result (time* (lambda () (run-bench name count ok? run)))))
- (if (not (ok? result))
- (begin
- (display "*** wrong result ***")
- (newline)
- (display "*** got: ")
- (write result)
- (newline))))
- (exit 0))
- (define (fatal-error . args)
- (for-each display args)
- (newline)
- (exit 1))
- (define (call-with-output-file/truncate filename proc)
- (call-with-output-file filename proc))
- ;------------------------------------------------------------------------------
- ; Macros...
- (define-macro (def-macro form . body)
- `(define-macro ,form (let () ,@body)))
- (if-fixflo
- (begin
- ; Specialize fixnum and flonum arithmetic.
- ;; This code should be used when f64vectors are available.
- ;(def-macro (FLOATvector-const . lst) `',(list->f64vector lst))
- ;(def-macro (FLOATvector? x) `(f64vector? ,x))
- ;(def-macro (FLOATvector . lst) `(f64vector ,@lst))
- ;(def-macro (FLOATmake-vector n . init) `(make-f64vector ,n ,@init))
- ;(def-macro (FLOATvector-ref v i) `(f64vector-ref ,v ,i))
- ;(def-macro (FLOATvector-set! v i x) `(f64vector-set! ,v ,i ,x))
- ;(def-macro (FLOATvector-length v) `(f64vector-length ,v))
- ;
- ;(def-macro (nuc-const . lst)
- ; `',(list->vector
- ; (map (lambda (x)
- ; (if (vector? x)
- ; (list->f64vector (vector->list x))
- ; x))
- ; lst)))
- (def-macro (FLOATvector-const . lst) `',(list->vector lst))
- (def-macro (FLOATvector? x) `(vector? ,x))
- (def-macro (FLOATvector . lst) `(vector ,@lst))
- (def-macro (FLOATmake-vector n . init) `(make-vector ,n ,@init))
- (def-macro (FLOATvector-ref v i) `(vector-ref ,v ,i))
- (def-macro (FLOATvector-set! v i x) `(vector-set! ,v ,i ,x))
- (def-macro (FLOATvector-length v) `(vector-length ,v))
- (def-macro (nuc-const . lst)
- `',(list->vector lst))
- (def-macro (FLOAT+ . lst) `(fp+ ,@lst))
- (def-macro (FLOAT- . lst) (if (= (length lst) 1) `(fpneg ,@lst) `(fp- ,@lst)))
- (def-macro (FLOAT* . lst) `(fp* ,@lst))
- (def-macro (FLOAT/ . lst) (if (= (length lst) 1) `(fp/ 1.0 ,@lst) `(fp/ ,@lst)))
- (def-macro (FLOAT= . lst) `(fp= ,@lst))
- (def-macro (FLOAT< . lst) `(fp< ,@lst))
- (def-macro (FLOAT<= . lst) `(fp<= ,@lst))
- (def-macro (FLOAT> . lst) `(fp> ,@lst))
- (def-macro (FLOAT>= . lst) `(fp>= ,@lst))
- (def-macro (FLOATnegative? . lst) `(fp< ,@lst 0.0))
- (def-macro (FLOATpositive? . lst) `(fp> ,@lst 0.0))
- (def-macro (FLOATzero? . lst) `(fp= ,@lst 0.0))
- (def-macro (FLOATabs . lst) `(abs ,@lst))
- (def-macro (FLOATsin . lst) `(sin ,@lst))
- (def-macro (FLOATcos . lst) `(cos ,@lst))
- (def-macro (FLOATatan . lst) `(atan ,@lst))
- (def-macro (FLOATsqrt . lst) `(sqrt ,@lst))
- (def-macro (FLOATmin . lst) `(fpmin ,@lst))
- (def-macro (FLOATmax . lst) `(fpmax ,@lst))
- (def-macro (FLOATround . lst) `(round ,@lst))
- (def-macro (FLOATinexact->exact . lst) `(inexact->exact ,@lst))
- (define (GENERIC+ x y) (+ x y))
- (define (GENERIC- x y) (- x y))
- (define (GENERIC* x y) (* x y))
- (define (GENERIC/ x y) (/ x y))
- (define (GENERICquotient x y) (quotient x y))
- (define (GENERICremainder x y) (remainder x y))
- (define (GENERICmodulo x y) (modulo x y))
- (define (GENERIC= x y) (= x y))
- (define (GENERIC< x y) (< x y))
- (define (GENERIC<= x y) (<= x y))
- (define (GENERIC> x y) (> x y))
- (define (GENERIC>= x y) (>= x y))
- (define (GENERICexpt x y) (expt x y))
- (def-macro (+ . lst) `(fx+ ,@lst))
- (def-macro (- . lst) (if (= (length lst) 1) `(fxneg ,@lst) `(fx- ,@lst)))
- (def-macro (* . lst) `(fx* ,@lst))
- (def-macro (quotient . lst) `(fx/ ,@lst))
- (def-macro (modulo . lst) `(fxmod ,@lst))
- ;(def-macro (remainder . lst) `(remainder ,@lst))
- (def-macro (= . lst) `(fx= ,@lst))
- (def-macro (< . lst) `(fx< ,@lst))
- (def-macro (<= . lst) `(fx<= ,@lst))
- (def-macro (> . lst) `(fx> ,@lst))
- (def-macro (>= . lst) `(fx>= ,@lst))
- (def-macro (negative? . lst) `(fx< ,@lst 0))
- (def-macro (positive? . lst) `(fx> ,@lst 0))
- (def-macro (zero? . lst) `(fx= ,@lst 0))
- (def-macro (odd? . lst) `(fx= (fxmod ,@lst 2) 1))
- (def-macro (even? . lst) `(fx= (fxmod ,@lst 2) 0))
- (def-macro (bitwise-or . lst) `(bitwise-ior ,@lst))
- ;(def-macro (bitwise-and . lst) `(bitwise-and ,@lst))
- ;(def-macro (bitwise-not . lst) `(bitwise-not ,@lst))
- )
- (begin
- ; Don't specialize fixnum and flonum arithmetic.
- (def-macro (FLOATvector-const . lst) `',(list->vector lst))
- (def-macro (FLOATvector? x) `(vector? ,x))
- (def-macro (FLOATvector . lst) `(vector ,@lst))
- (def-macro (FLOATmake-vector n . init) `(make-vector ,n ,@init))
- (def-macro (FLOATvector-ref v i) `(vector-ref ,v ,i))
- (def-macro (FLOATvector-set! v i x) `(vector-set! ,v ,i ,x))
- (def-macro (FLOATvector-length v) `(vector-length ,v))
- (def-macro (nuc-const . lst)
- `',(list->vector lst))
- (def-macro (FLOAT+ . lst) `(+ ,@lst))
- (def-macro (FLOAT- . lst) `(- ,@lst))
- (def-macro (FLOAT* . lst) `(* ,@lst))
- (def-macro (FLOAT/ . lst) `(/ ,@lst))
- (def-macro (FLOAT= . lst) `(= ,@lst))
- (def-macro (FLOAT< . lst) `(< ,@lst))
- (def-macro (FLOAT<= . lst) `(<= ,@lst))
- (def-macro (FLOAT> . lst) `(> ,@lst))
- (def-macro (FLOAT>= . lst) `(>= ,@lst))
- (def-macro (FLOATnegative? . lst) `(negative? ,@lst))
- (def-macro (FLOATpositive? . lst) `(positive? ,@lst))
- (def-macro (FLOATzero? . lst) `(zero? ,@lst))
- (def-macro (FLOATabs . lst) `(abs ,@lst))
- (def-macro (FLOATsin . lst) `(sin ,@lst))
- (def-macro (FLOATcos . lst) `(cos ,@lst))
- (def-macro (FLOATatan . lst) `(atan ,@lst))
- (def-macro (FLOATsqrt . lst) `(sqrt ,@lst))
- (def-macro (FLOATmin . lst) `(min ,@lst))
- (def-macro (FLOATmax . lst) `(max ,@lst))
- (def-macro (FLOATround . lst) `(round ,@lst))
- (def-macro (FLOATinexact->exact . lst) `(inexact->exact ,@lst))
- (def-macro (GENERIC+ . lst) `(+ ,@lst))
- (def-macro (GENERIC- . lst) `(- ,@lst))
- (def-macro (GENERIC* . lst) `(* ,@lst))
- (def-macro (GENERIC/ . lst) `(/ ,@lst))
- (def-macro (GENERICquotient . lst) `(quotient ,@lst))
- (def-macro (GENERICremainder . lst) `(remainder ,@lst))
- (def-macro (GENERICmodulo . lst) `(modulo ,@lst))
- (def-macro (GENERIC= . lst) `(= ,@lst))
- (def-macro (GENERIC< . lst) `(< ,@lst))
- (def-macro (GENERIC<= . lst) `(<= ,@lst))
- (def-macro (GENERIC> . lst) `(> ,@lst))
- (def-macro (GENERIC>= . lst) `(>= ,@lst))
- (def-macro (GENERICexpt . lst) `(expt ,@lst))
- )
- )
- ;------------------------------------------------------------------------------
|