* Numeric comparison functions =, <, <=, >, >= now understand

ratnums.
This commit is contained in:
Abdulaziz Ghuloum 2007-06-11 11:59:11 +03:00
parent 90feb453f5
commit b01e289798
3 changed files with 118 additions and 9 deletions

Binary file not shown.

View File

@ -861,7 +861,8 @@
(define-syntax mk< (define-syntax mk<
(syntax-rules () (syntax-rules ()
[(_ name fxfx< fxbn< bnfx< bnbn< [(_ name fxfx< fxbn< bnfx< bnbn<
fxfl< flfx< bnfl< flbn< flfl<) fxfl< flfx< bnfl< flbn< flfl<
fxrt< rtfx< bnrt< rtbn< flrt< rtfl< rtrt<)
(let () (let ()
(define err (define err
(lambda (x) (error 'name "~s is not a number" x))) (lambda (x) (error 'name "~s is not a number" x)))
@ -886,6 +887,12 @@
(if (fxfl< x y) (if (fxfl< x y)
(flloopt y (car ls) (cdr ls)) (flloopt y (car ls) (cdr ls))
(loopf (car ls) (cdr ls))))] (loopf (car ls) (cdr ls))))]
[(ratnum? y)
(if (null? ls)
(fxrt< x y)
(if (fxrt< x y)
(rtloopt y (car ls) (cdr ls))
(loopf (car ls) (cdr ls))))]
[else (err y)]))) [else (err y)])))
(define bnloopt (define bnloopt
(lambda (x y ls) (lambda (x y ls)
@ -908,6 +915,12 @@
(if (bnfl< x y) (if (bnfl< x y)
(flloopt y (car ls) (cdr ls)) (flloopt y (car ls) (cdr ls))
(loopf (car ls) (cdr ls))))] (loopf (car ls) (cdr ls))))]
[(ratnum? y)
(if (null? ls)
(bnrt< x y)
(if (bnrt< x y)
(rtloopt y (car ls) (cdr ls))
(loopf (car ls) (cdr ls))))]
[else (err y)]))) [else (err y)])))
(define flloopt (define flloopt
(lambda (x y ls) (lambda (x y ls)
@ -930,6 +943,40 @@
(if (flfl< x y) (if (flfl< x y)
(flloopt y (car ls) (cdr ls)) (flloopt y (car ls) (cdr ls))
(loopf (car ls) (cdr ls))))] (loopf (car ls) (cdr ls))))]
[(flonum? y)
(if (null? ls)
(flrt< x y)
(if (flrt< x y)
(rtloopt y (car ls) (cdr ls))
(loopf (car ls) (cdr ls))))]
[else (err y)])))
(define rtloopt
(lambda (x y ls)
(cond
[(fixnum? y)
(if (null? ls)
(rtfx< x y)
(if (rtfx< x y)
(fxloopt y (car ls) (cdr ls))
(loopf (car ls) (cdr ls))))]
[(bignum? y)
(if (null? ls)
(rtbn< x y)
(if (rtbn< x y)
(bnloopt y (car ls) (cdr ls))
(loopf (car ls) (cdr ls))))]
[(flonum? y)
(if (null? ls)
(rtfl< x y)
(if (rtfl< x y)
(flloopt y (car ls) (cdr ls))
(loopf (car ls) (cdr ls))))]
[(flonum? y)
(if (null? ls)
(rtrt< x y)
(if (rtrt< x y)
(rtloopt y (car ls) (cdr ls))
(loopf (car ls) (cdr ls))))]
[else (err y)]))) [else (err y)])))
(define loopf (define loopf
(lambda (x ls) (lambda (x ls)
@ -945,18 +992,28 @@
[(fixnum? y) (fxfx< x y)] [(fixnum? y) (fxfx< x y)]
[(bignum? y) (fxbn< x y)] [(bignum? y) (fxbn< x y)]
[(flonum? y) (fxfl< x y)] [(flonum? y) (fxfl< x y)]
[(ratnum? y) (fxrt< x y)]
[else (err y)])] [else (err y)])]
[(bignum? x) [(bignum? x)
(cond (cond
[(fixnum? y) (bnfx< x y)] [(fixnum? y) (bnfx< x y)]
[(bignum? y) (bnbn< x y)] [(bignum? y) (bnbn< x y)]
[(flonum? y) (bnfl< x y)] [(flonum? y) (bnfl< x y)]
[(ratnum? y) (bnrt< x y)]
[else (err y)])] [else (err y)])]
[(flonum? x) [(flonum? x)
(cond (cond
[(fixnum? y) (flfx< x y)] [(fixnum? y) (flfx< x y)]
[(bignum? y) (flbn< x y)] [(bignum? y) (flbn< x y)]
[(flonum? y) (flfl< x y)] [(flonum? y) (flfl< x y)]
[(ratnum? y) (flrt< x y)]
[else (err y)])]
[(ratnum? x)
(cond
[(fixnum? y) (rtfx< x y)]
[(bignum? y) (rtbn< x y)]
[(flonum? y) (rtfl< x y)]
[(ratnum? y) (rtrt< x y)]
[else (err y)])] [else (err y)])]
[else (err x)])] [else (err x)])]
[(x y z) [(x y z)
@ -970,6 +1027,8 @@
(and (fxfx< x y) (fxbn< y z))] (and (fxfx< x y) (fxbn< y z))]
[(flonum? z) [(flonum? z)
(and (fxfx< x y) (fxfl< y z))] (and (fxfx< x y) (fxfl< y z))]
[(ratnum? z)
(and (fxfx< x y) (fxrt< y z))]
[else (err z)])] [else (err z)])]
[(bignum? y) [(bignum? y)
(cond (cond
@ -978,6 +1037,8 @@
(and (fxbn< x y) (bnbn< y z))] (and (fxbn< x y) (bnbn< y z))]
[(flonum? z) [(flonum? z)
(and (fxbn< x y) (bnfl< y z))] (and (fxbn< x y) (bnfl< y z))]
[(ratnum? z)
(and (fxbn< x y) (bnrt< y z))]
[else (err z)])] [else (err z)])]
[(flonum? y) [(flonum? y)
(cond (cond
@ -990,9 +1051,12 @@
(fxfl< x y) (fxfl< x y)
(flbn< y z))] (flbn< y z))]
[(flonum? z) [(flonum? z)
(and (flfl< y z) (and (flfl< y z) (fxfl< x y))]
(fxfl< x y))] [(ratnum? z)
(and (fxfl< x y) (flrt< y z))]
[else (err z)])] [else (err z)])]
[(ratnum? y)
(and (fxrt< x y) (name y z))]
[else (err y)])] [else (err y)])]
[(bignum? x) [(bignum? x)
(cond (cond
@ -1003,12 +1067,15 @@
(and (bnfx< x y) (bnfx< y z))] (and (bnfx< x y) (bnfx< y z))]
[(flonum? z) [(flonum? z)
(and (bnfx< x y) (fxfl< y z))] (and (bnfx< x y) (fxfl< y z))]
[(ratnum? z)
(and (bnfx< x y) (fxrt< y z))]
[else (err z)])] [else (err z)])]
[(bignum? y) [(bignum? y)
(cond (cond
[(fixnum? z) (and (bnfx< y z) (bnbn< x y))] [(fixnum? z) (and (bnfx< y z) (bnbn< x y))]
[(bignum? z) (and (bnbn< x y) (bnbn< y z))] [(bignum? z) (and (bnbn< x y) (bnbn< y z))]
[(flonum? z) (and (bnfl< y z) (bnbn< x y))] [(flonum? z) (and (bnfl< y z) (bnbn< x y))]
[(ratnum? z) (and (bnbn< x y) (bnrt< y z))]
[else (err z)])] [else (err z)])]
[(flonum? y) [(flonum? y)
(cond (cond
@ -1018,7 +1085,11 @@
(and (bnfl< x y) (flbn< y z))] (and (bnfl< x y) (flbn< y z))]
[(flonum? z) [(flonum? z)
(and (flfl< y z) (bnfl< x y))] (and (flfl< y z) (bnfl< x y))]
[(ratnum? z)
(and (flrt< y z) (bnfl< x y))]
[else (err z)])] [else (err z)])]
[(ratnum? y)
(and (bnrt< x y) (name y z))]
[else (err y)])] [else (err y)])]
[(flonum? x) [(flonum? x)
(cond (cond
@ -1030,6 +1101,8 @@
(and (flfx< x y) (fxbn< y z))] (and (flfx< x y) (fxbn< y z))]
[(flonum? z) [(flonum? z)
(and (flfx< x y) (fxfl< y z))] (and (flfx< x y) (fxfl< y z))]
[(ratnum? z)
(and (flfx< x y) (fxrt< y z))]
[else (err z)])] [else (err z)])]
[(bignum? y) [(bignum? y)
(cond (cond
@ -1039,6 +1112,8 @@
(and (bnbn< y z) (flbn< x y))] (and (bnbn< y z) (flbn< x y))]
[(flonum? z) [(flonum? z)
(and (flbn< x y) (bnfl< y z))] (and (flbn< x y) (bnfl< y z))]
[(ratnum? z)
(and (flbn< x y) (bnrt< y z))]
[else (err z)])] [else (err z)])]
[(flonum? y) [(flonum? y)
(cond (cond
@ -1048,8 +1123,14 @@
(and (flfl< x y) (flbn< y z))] (and (flfl< x y) (flbn< y z))]
[(flonum? z) [(flonum? z)
(and (flfl< x y) (flfl< y z))] (and (flfl< x y) (flfl< y z))]
[(ratnum? z)
(and (flfl< x y) (flrt< y z))]
[else (err z)])] [else (err z)])]
[(ratnum? y)
(and (flrt< x y) (name y z))]
[else (err y)])] [else (err y)])]
[(ratnum? x)
(and (name x y) (name y z))]
[else (err x)])] [else (err x)])]
[(x) (if (number? x) #t (err x))] [(x) (if (number? x) #t (err x))]
[(x y . ls) [(x y . ls)
@ -1057,6 +1138,7 @@
[(fixnum? x) (fxloopt x y ls)] [(fixnum? x) (fxloopt x y ls)]
[(bignum? x) (bnloopt x y ls)] [(bignum? x) (bnloopt x y ls)]
[(flonum? x) (flloopt x y ls)] [(flonum? x) (flloopt x y ls)]
[(ratnum? x) (rtloopt x y ls)]
[else (err x)])]))])) [else (err x)])]))]))
(define-syntax false (syntax-rules () [(_ x y) #f])) (define-syntax false (syntax-rules () [(_ x y) #f]))
@ -1106,17 +1188,42 @@
(flcmp flfl<= flfx<= fxfl<= flbn<= bnfl<= $fl<=) (flcmp flfl<= flfx<= fxfl<= flbn<= bnfl<= $fl<=)
(flcmp flfl>= flfx>= fxfl>= flbn>= bnfl>= $fl>=) (flcmp flfl>= flfx>= fxfl>= flbn>= bnfl>= $fl>=)
(define-syntax flrt= (syntax-rules () [(_ x y) (= (inexact->exact x) y)]))
(define-syntax rtfl= (syntax-rules () [(_ x y) (= x (inexact->exact y))]))
(define-syntax flrt< (syntax-rules () [(_ x y) (< (inexact->exact x) y)]))
(define-syntax rtfl< (syntax-rules () [(_ x y) (< x (inexact->exact y))]))
(define-syntax flrt<= (syntax-rules () [(_ x y) (<= (inexact->exact x) y)]))
(define-syntax rtfl<= (syntax-rules () [(_ x y) (<= x (inexact->exact y))]))
(define-syntax flrt> (syntax-rules () [(_ x y) (> (inexact->exact x) y)]))
(define-syntax rtfl> (syntax-rules () [(_ x y) (> x (inexact->exact y))]))
(define-syntax flrt>= (syntax-rules () [(_ x y) (>= (inexact->exact x) y)]))
(define-syntax rtfl>= (syntax-rules () [(_ x y) (>= x (inexact->exact y))]))
(define (exrt< x y) (< (* x ($ratnum-d y)) ($ratnum-n y)))
(define (rtex< x y) (< ($ratnum-n x) (* y ($ratnum-d x))))
(define (rtrt< x y) (< (* ($ratnum-n x) ($ratnum-d y)) (* ($ratnum-n y) ($ratnum-d x))))
(define (rtrt<= x y) (<= (* ($ratnum-n x) ($ratnum-d y)) (* ($ratnum-n y) ($ratnum-d x))))
(define (exrt> x y) (> (* x ($ratnum-d y)) ($ratnum-n y)))
(define (rtex> x y) (> ($ratnum-n x) (* y ($ratnum-d x))))
(define (rtrt> x y) (> (* ($ratnum-n x) ($ratnum-d y)) (* ($ratnum-n y) ($ratnum-d x))))
(define (rtrt>= x y) (>= (* ($ratnum-n x) ($ratnum-d y)) (* ($ratnum-n y) ($ratnum-d x))))
(define (rtrt= x y)
(and (= ($ratnum-n x) ($ratnum-n y)) (= ($ratnum-d x) ($ratnum-d y))))
(define = (define =
(mk< = $fx= false false bnbn= fxfl= flfx= bnfl= flbn= flfl=)) (mk< = $fx= false false bnbn= fxfl= flfx= bnfl= flbn= flfl=
false false false false flrt= rtfl= rtrt=))
(define < (define <
(mk< < $fx< fxbn< bnfx< bnbn< fxfl< flfx< bnfl< flbn< flfl<)) (mk< < $fx< fxbn< bnfx< bnbn< fxfl< flfx< bnfl< flbn< flfl<
exrt< rtex< exrt< rtex< flrt< rtfl< rtrt<))
(define > (define >
(mk< > $fx> fxbn> bnfx> bnbn> fxfl> flfx> bnfl> flbn> flfl>)) (mk< > $fx> fxbn> bnfx> bnbn> fxfl> flfx> bnfl> flbn> flfl>
exrt> rtex> exrt> rtex> flrt> rtfl> rtrt>))
(define <= (define <=
(mk< <= $fx<= fxbn< bnfx< bnbn<= fxfl<= flfx<= bnfl<= flbn<= flfl<=)) (mk< <= $fx<= fxbn< bnfx< bnbn<= fxfl<= flfx<= bnfl<= flbn<= flfl<=
exrt< rtex< exrt< rtex< flrt<= rtfl<= rtrt<=))
(define >= (define >=
(mk< >= $fx>= fxbn> bnfx> bnbn>= fxfl>= flfx>= bnfl>= flbn>= flfl>=)) (mk< >= $fx>= fxbn> bnfx> bnbn>= fxfl>= flfx>= bnfl>= flbn>= flfl>=
exrt> rtex> exrt> rtex> flrt>= rtfl>= rtrt>=))
(define add1 (define add1
(lambda (x) (lambda (x)
@ -1361,6 +1468,7 @@
[(ratnum? x) (- (log (numerator x)) (log (denominator x)))] [(ratnum? x) (- (log (numerator x)) (log (denominator x)))]
[else (error 'log "~s is not a number" x)]))) [else (error 'log "~s is not a number" x)])))
(define string->number (define string->number
(lambda (x) (lambda (x)
(define (convert-data str len pos? idx ac) (define (convert-data str len pos? idx ac)

View File

@ -12,4 +12,5 @@
(error 'test-all "~s failed, got ~s" (error 'test-all "~s failed, got ~s"
'(p0 e0) e))) '(p0 e0) e)))
... ...
(printf "[~s] Happy Happy Joy Joy\n" 'test-all)))]))) (printf "[~s: ~s] Happy Happy Joy Joy\n"
(length '(p0 ...))'test-all )))])))