- intset? now does what it should

This commit is contained in:
Michel Schinz 2003-04-02 17:51:39 +00:00
parent ae6bdcbf88
commit 49fa6ec239
1 changed files with 15 additions and 8 deletions

View File

@ -22,6 +22,8 @@
;;; Functions on bounds.
(define (b? thing) (or (number? thing) (b-max? thing)))
(define (b-max? bound) (eq? bound 'max))
(define (b< b1 b2)
@ -59,6 +61,13 @@
(define i-beg car)
(define i-end cdr)
(define (i? thing)
(and (pair? thing)
(let ((b1 (car thing)) (b2 (cdr thing)))
(and (b? b1)
(b? b2)
(b<= b1 b2)))))
;; Beware: the following syntax leads to multiple evaluations of each
;; interval expression!
(define-syntax let-int
@ -108,13 +117,11 @@
;;; Functions on sets (lists of individual intervals).
(define (intset? thing)
;; TODO check that intervals are disjoint and increasing
(and (list? thing)
(every (lambda (pair)
(and (pair? pair)
(number? (car pair))
(or (number? (cdr pair)) (b-max? (cdr pair)))
(b< (car pair) (cdr pair))))
(and (proper-list? thing)
(pairwise (lambda (i1 i2)
(and (i? i1) (i? i2)
(not (i-contiguous? i1 i2))
(i< i1 i2)))
thing)))
(define (intset-union s1 s2)