2007-05-15 12:29:47 -04:00
|
|
|
#!/usr/bin/env ikarus --r6rs-script
|
|
|
|
|
|
|
|
(import (ikarus)
|
2007-05-20 13:11:33 -04:00
|
|
|
(tests reader)
|
2007-05-15 12:29:47 -04:00
|
|
|
(tests bytevectors))
|
|
|
|
|
2007-05-21 23:09:45 -04:00
|
|
|
(define (test-exact-integer-sqrt)
|
|
|
|
(define (f i j inc)
|
|
|
|
(when (< i j)
|
|
|
|
(let-values ([(s r) (exact-integer-sqrt i)])
|
|
|
|
(unless (and (= (+ (* s s) r) i)
|
|
|
|
(< i (* (+ s 1) (+ s 1))))
|
|
|
|
(error 'exact-integer-sqrt "wrong result for ~s" i))
|
|
|
|
(f (+ i inc) j inc))))
|
|
|
|
(f 0 10000 1)
|
|
|
|
(f 0 536870911 10000)
|
|
|
|
(f 0 536870911000 536870911)
|
|
|
|
(printf "[exact-integer-sqrt] Happy Happy Joy Joy\n"))
|
|
|
|
|
2007-05-20 13:11:33 -04:00
|
|
|
(test-reader)
|
2007-05-15 12:29:47 -04:00
|
|
|
(test-bytevectors)
|
2007-05-21 23:09:45 -04:00
|
|
|
(test-exact-integer-sqrt)
|
2007-05-15 12:29:47 -04:00
|
|
|
(printf "Happy Happy Joy Joy\n")
|