2007-06-13 10:49:54 -04:00
|
|
|
;;; SUMFP -- Compute sum of integers from 0 to 10000 using floating point
|
|
|
|
(library (r6rs-benchmarks sumfp)
|
|
|
|
(export main)
|
|
|
|
(import (r6rs) (r6rs arithmetic flonums) (r6rs-benchmarks))
|
|
|
|
|
|
|
|
|
|
|
|
(define (run n)
|
|
|
|
(let loop ((i n) (sum 0.))
|
|
|
|
(if (fl<? i 0.)
|
2007-06-15 01:59:49 -04:00
|
|
|
sum
|
|
|
|
(loop (fl- i 1.) (fl+ i sum)))))
|
2007-06-13 10:49:54 -04:00
|
|
|
|
|
|
|
(define (main . args)
|
|
|
|
(run-benchmark
|
|
|
|
"sumfp"
|
|
|
|
sumfp-iters
|
|
|
|
(lambda (result) (equal? result 50005000.))
|
|
|
|
(lambda (n) (lambda () (run n)))
|
|
|
|
10000.)))
|