⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 lattice.scm

📁 Scheme跨平台编译器
💻 SCM
字号:
;;; LATTICE -- Obtained from Andrew Wright.;; 08/06/01 (felix): renamed "reverse!" to "reverse!2" because MZC doesn't like redefinitions.;; Given a comparison routine that returns one of;       less;       more;       equal;       uncomparable; return a new comparison routine that applies to sequences.(define lexico    (lambda (base)        (define lex-fixed            (lambda (fixed lhs rhs)                (define check                    (lambda (lhs rhs)                        (if (null? lhs)                            fixed                            (let ((probe                                        (base (car lhs)                                            (car rhs))))                                (if (or (eq? probe 'equal)                                        (eq? probe fixed))                                    (check (cdr lhs)                                        (cdr rhs))                                    'uncomparable)))))                (check lhs rhs)))        (define lex-first            (lambda (lhs rhs)                (if (null? lhs)                    'equal                    (let ((probe                                (base (car lhs)                                    (car rhs))))                        (case probe                            ((less more)                                (lex-fixed probe                                    (cdr lhs)                                    (cdr rhs)))                            ((equal)                                (lex-first (cdr lhs)                                    (cdr rhs)))                            ((uncomparable)                                'uncomparable))))))        lex-first))(define (make-lattice elem-list cmp-func)    (cons elem-list cmp-func))(define lattice->elements car)(define lattice->cmp cdr); Select elements of a list which pass some test.(define zulu-select    (lambda (test lst)        (define select-a            (lambda (ac lst)                (if (null? lst)                    (reverse!2 ac)                    (select-a                        (let ((head (car lst)))                            (if (test head)                                (cons head ac)                                ac))                        (cdr lst)))))        (select-a '() lst)))(define reverse!2    (letrec ((rotate                (lambda (fo fum)                    (let ((next (cdr fo)))                        (set-cdr! fo fum)                        (if (null? next)                            fo                            (rotate next fo))))))        (lambda (lst)            (if (null? lst)                '()                (rotate lst '()))))); Select elements of a list which pass some test and map a function; over the result.  Note, only efficiency prevents this from being the; composition of select and map.(define select-map    (lambda (test func lst)        (define select-a            (lambda (ac lst)                (if (null? lst)                    (reverse!2 ac)                    (select-a                        (let ((head (car lst)))                            (if (test head)                                (cons (func head)                                    ac)                                ac))                        (cdr lst)))))        (select-a '() lst))); This version of map-and tail-recurses on the last test.(define map-and    (lambda (proc lst)        (if (null? lst)            #t            (letrec ((drudge                        (lambda (lst)                            (let ((rest (cdr lst)))                                (if (null? rest)                                    (proc (car lst))                                    (and (proc (car lst))                                        (drudge rest)))))))                (drudge lst)))))(define (maps-1 source target pas new)    (let ((scmp (lattice->cmp source))            (tcmp (lattice->cmp target)))        (let ((less                    (select-map                        (lambda (p)                            (eq? 'less                                (scmp (car p) new)))                        cdr                        pas))                (more                    (select-map                        (lambda (p)                            (eq? 'more                                (scmp (car p) new)))                        cdr                        pas)))            (zulu-select                (lambda (t)                    (and                        (map-and                            (lambda (t2)                                (memq (tcmp t2 t) '(less equal)))                            less)                        (map-and                            (lambda (t2)                                (memq (tcmp t2 t) '(more equal)))                            more)))                (lattice->elements target)))))(define (maps-rest source target pas rest to-1 to-collect)    (if (null? rest)        (to-1 pas)        (let ((next (car rest))                (rest (cdr rest)))            (to-collect                (map                    (lambda (x)                        (maps-rest source target                            (cons                                (cons next x)                                pas)                            rest                            to-1                            to-collect))                    (maps-1 source target pas next))))))(define (maps source target)    (make-lattice        (maps-rest source            target            '()            (lattice->elements source)            (lambda (x) (list (map cdr x)))            (lambda (x) (apply append x)))        (lexico (lattice->cmp target))))(define (count-maps source target)  (maps-rest source             target             '()             (lattice->elements source)             (lambda (x) 1)             sum))(define (sum lst)  (if (null? lst)      0      (+ (car lst) (sum (cdr lst)))))(define (run)  (let* ((l2            (make-lattice '(low high)                (lambda (lhs rhs)                    (case lhs                        ((low)                            (case rhs                                ((low)                                    'equal)                                ((high)                                    'less)                                (else                                    (error 'make-lattice "base" rhs))))                        ((high)                            (case rhs                                ((low)                                    'more)                                ((high)                                    'equal)                                (else                                    (error 'make-lattice "base" rhs))))                        (else                            (error 'make-lattice "base" lhs))))))        (l3 (maps l2 l2))        (l4 (maps l3 l3)))    (count-maps l2 l2)    (count-maps l3 l3)    (count-maps l2 l3)    (count-maps l3 l2)    (count-maps l4 l4)))(time (run))

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -