* Added flfinite?, flinfinite?, and flnan?

* Fixed a bug that caused all nans to print as -nan.0
This commit is contained in:
Abdulaziz Ghuloum 2007-09-10 22:10:19 -04:00
parent a366a5f20f
commit fa63e8723c
4 changed files with 45 additions and 10 deletions

Binary file not shown.

View File

@ -10,14 +10,15 @@
inexact->exact exact $flonum-rational? $flonum-integer? $flzero?
$flnegative? flpositive? flabs fixnum->flonum
flsin flcos fltan flasin flacos flatan
flinteger?)
flinteger? flonum-bytes flnan? flfinite? flinfinite?)
(import
(ikarus system $bytevectors)
(only (ikarus system $fx) $fxzero? $fxlogand)
(except (ikarus system $flonums) $flonum-signed-biased-exponent
$flonum-rational? $flonum-integer?)
(except (ikarus) inexact->exact exact flpositive? flabs
fixnum->flonum flsin flcos fltan flasin flacos flatan
flinteger?))
flinteger? flonum-parts flonum-bytes flnan? flfinite? flinfinite?))
(define (flonum-bytes f)
(unless (flonum? f)
@ -45,6 +46,16 @@
(fxsll b2 16)
(fxsll (fxlogand b1 #b1111) 24))
(expt 2 24))))))
(define ($zero-m? f)
(and ($fxzero? ($flonum-u8-ref f 7))
($fxzero? ($flonum-u8-ref f 6))
($fxzero? ($flonum-u8-ref f 5))
($fxzero? ($flonum-u8-ref f 4))
($fxzero? ($flonum-u8-ref f 3))
($fxzero? ($flonum-u8-ref f 2))
($fxzero? ($fxlogand ($flonum-u8-ref f 1) #b1111))))
(define ($flonum-signed-biased-exponent x)
(let ([b0 ($flonum-u8-ref x 0)]
@ -81,6 +92,25 @@
($flonum-integer? x)
(error 'flinteger? "~s is not a flonum" x)))
(define (flinfinite? x)
(if (flonum? x)
(let ([be (fxlogand ($flonum-signed-biased-exponent x) (sub1 (fxsll 1 11)))])
(and (fx= be 2047) ;;; nans and infs
($zero-m? x)))
(error 'flinfinite? "~s is not a flonum" x)))
(define (flnan? x)
(if (flonum? x)
(let ([be (fxlogand ($flonum-signed-biased-exponent x) (sub1 (fxsll 1 11)))])
(and (fx= be 2047) ;;; nans and infs
(not ($zero-m? x))))
(error 'flnan? "~s is not a flonum" x)))
(define (flfinite? x)
(if (flonum? x)
(let ([be (fxlogand ($flonum-signed-biased-exponent x) (sub1 (fxsll 1 11)))])
(not (fx= be 2047)))
(error 'flfinite? "~s is not a flonum" x)))
(define ($flzero? x)
(let ([be (fxlogand ($flonum-signed-biased-exponent x) (sub1 (fxsll 1 11)))])
@ -1995,7 +2025,6 @@
(import
(ikarus system $bytevectors)
(ikarus system $flonums)
(only (ikarus flonums) flonum-parts)
(except (ikarus) flonum->string string->flonum ))
(module (flonum->string)
@ -2130,7 +2159,8 @@
[(= be 2047)
(if (= m 0)
(if pos? "+inf.0" "-inf.0")
(if pos? "+nan.0" "-nan.0"))]
;;; Gee! nans have no sign!
"+nan.0")]
[else (error 'flonum->string "cannot happen")]))))
(define (string->flonum x)

View File

@ -503,10 +503,15 @@
[ratnum? i]
[integer? i r]
[flinteger? i]
[flfinite? i]
[flinfinite? i]
[flnan? i]
[exact? i r]
[inexact? i r]
[rational? i r]
[flonum? i]
[flonum-parts i]
[flonum-bytes i]
[positive? i r]
[negative? i r]
[even? i r]

View File

@ -322,21 +322,21 @@
[fleven? S fl]
[flexp S fl]
[flexpt S fl]
[flfinite? S fl]
[flfinite? C fl]
[flfloor S fl]
[flinfinite? S fl]
[flinteger? S fl]
[flinfinite? C fl]
[flinteger? C fl]
[fllog S fl]
[flmax C fl]
[flmin C fl]
[flmod S fl]
[flmod0 S fl]
[flnan? S fl]
[flnegative? S fl]
[flnan? C fl]
[flnegative? C fl]
[flnumerator S fl]
[flodd? S fl]
[flonum? C fl]
[flpositive? S fl]
[flpositive? C fl]
[flround C fl]
[flsin C fl]
[flsqrt S fl]