aboutsummaryrefslogtreecommitdiff
path: root/src/algebra/strap/ORDRING.lsp
blob: 341a4bc7ebe9cc6904938c15cad5dfd6fe7578db (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
(/VERSIONCHECK 2) 

(DEFPARAMETER |OrderedRing;AL| 'NIL) 

(DEFUN |OrderedRing| ()
  (LET (#:G1402)
    (COND
      (|OrderedRing;AL|)
      (T (SETQ |OrderedRing;AL| (|OrderedRing;|)))))) 

(DEFUN |OrderedRing;| ()
  (PROG (#0=#:G1400)
    (RETURN
      (PROG1 (LETT #0#
                   (|Join| (|OrderedAbelianGroup|) (|Ring|) (|Monoid|)
                           (|mkCategory| '|domain|
                               '(((|positive?| ((|Boolean|) $)) T)
                                 ((|negative?| ((|Boolean|) $)) T)
                                 ((|sign| ((|Integer|) $)) T)
                                 ((|abs| ($ $)) T))
                               NIL '((|Integer|) (|Boolean|)) NIL))
                   |OrderedRing|)
        (SETELT #0# 0 '(|OrderedRing|)))))) 

(SETQ |$CategoryFrame|
      (|put| '|OrderedRing| '|isCategory| T
             (|addModemap| '|OrderedRing| '(|OrderedRing|)
                 '((|Category|)) T '|OrderedRing| |$CategoryFrame|))) 

(MAKEPROP '|OrderedRing| 'NILADIC T)