aboutsummaryrefslogtreecommitdiff
path: root/src/algebra
diff options
context:
space:
mode:
Diffstat (limited to 'src/algebra')
-rw-r--r--src/algebra/data.spad.pamphlet3
-rw-r--r--src/algebra/list.spad.pamphlet35
-rw-r--r--src/algebra/plot.spad.pamphlet2
-rw-r--r--src/algebra/plot3d.spad.pamphlet4
-rw-r--r--src/algebra/si.spad.pamphlet6
-rw-r--r--src/algebra/strap/SINT.lsp14
-rw-r--r--src/algebra/syntax.spad.pamphlet4
7 files changed, 35 insertions, 33 deletions
diff --git a/src/algebra/data.spad.pamphlet b/src/algebra/data.spad.pamphlet
index 744db27c..102cd55e 100644
--- a/src/algebra/data.spad.pamphlet
+++ b/src/algebra/data.spad.pamphlet
@@ -269,7 +269,8 @@ UInt64() == SystemNonNegativeInteger 64
++ This domain is a datatype system-level pointer values.
SystemPointer(): SetCategory
== add
- x = y == EQL(x,y)$Foreign(Builtin)
+ import %sptreq: (%,%) -> Boolean from Foreign Builtin
+ x = y == %sptreq(x,y)
coerce(x:%): OutputForm ==
FORMAT(NIL$Foreign(Builtin),"~A",x)$Foreign(Builtin)
@
diff --git a/src/algebra/list.spad.pamphlet b/src/algebra/list.spad.pamphlet
index aec6167f..3e7c6b28 100644
--- a/src/algebra/list.spad.pamphlet
+++ b/src/algebra/list.spad.pamphlet
@@ -44,12 +44,11 @@ IndexedList(S:Type, mn:Integer): Exports == Implementation where
-- a knowledgeable person wants to update it:
-- The following LISP dependencies are divided into two groups
-- Those that are required
--- CONS, EQ, NIL, NULL, RPLACA, RPLACD
+-- CONS, EQ, NIL, RPLACA, RPLACD
-- Those that are included for efficiency only
-- LIST, NCONC2, LENGTH
-- Also REVERSE, since it's called in Polynomial Ring
- Qnull ==> NULL$Lisp
Qpush ==> PUSH$Lisp
Exports ==> ListAggregate S
@@ -94,13 +93,13 @@ IndexedList(S:Type, mn:Integer): Exports == Implementation where
rest(x, n) ==
for i in 1..n repeat
- if Qnull x then error "index out of range"
+ if empty? x then error "index out of range"
x := %tail x
x
copy x ==
y := empty()
- for i in 0.. while not Qnull x repeat
+ for i in 0.. while not empty? x repeat
if i = cycleMax and cyclic? x then error "cyclic list"
y := %makepair(%head x,y)
x := %tail x
@@ -126,35 +125,35 @@ IndexedList(S:Type, mn:Integer): Exports == Implementation where
if S has SetCategory then
x = y ==
%peq(x,y) => true
- while not Qnull x and not Qnull y repeat
+ while not empty? x and not empty? y repeat
%head x ~=$S %head y => return false
x := %tail x
y := %tail y
- Qnull x and Qnull y
+ empty? x and empty? y
latex(x : %): String ==
s : String := "\left["
- while not Qnull x repeat
+ while not empty? x repeat
s := concat(s, latex(%head x)$S)$String
x := %tail x
- if not Qnull x then s := concat(s, ", ")$String
+ if not empty? x then s := concat(s, ", ")$String
concat(s, " \right]")$String
member?(s,x) ==
- while not Qnull x repeat
+ while not empty? x repeat
if s = %head x then return true else x := %tail x
false
-- Lots of code from parts of AGGCAT, repeated here to
-- get faster compilation
concat!(x:%,y:%) ==
- Qnull x =>
- Qnull y => x
+ empty? x =>
+ empty? y => x
Qpush(first y,x)
QRPLACD(x,rest y)$Lisp
x
z:=x
- while not Qnull %tail z repeat
+ while not empty? %tail z repeat
z:=%tail z
QRPLACD(z,y)$Lisp
x
@@ -163,13 +162,13 @@ IndexedList(S:Type, mn:Integer): Exports == Implementation where
if S has SetCategory then
removeDuplicates! l ==
p := l
- while not Qnull p repeat
+ while not empty? p repeat
-- p := setrest!(p, remove!(#1 = %head p, %tail p))
-- far too expensive - builds closures etc.
pp:=p
f:S:=%head p
p:=%tail p
- while not Qnull (pr:=%tail pp) repeat
+ while not empty? (pr:=%tail pp) repeat
if (%head pr)@S = f then QRPLACD(pp,%tail pr)$Lisp
else pp:=pr
l
@@ -180,17 +179,17 @@ IndexedList(S:Type, mn:Integer): Exports == Implementation where
sort!(f, l) == mergeSort(f, l, #l)
merge!(f, p, q) ==
- Qnull p => q
- Qnull q => p
+ empty? p => q
+ empty? q => p
%peq(p, q) => error "cannot merge a list into itself"
if f(%head p, %head q)
then (r := t := p; p := %tail p)
else (r := t := q; q := %tail q)
- while not Qnull p and not Qnull q repeat
+ while not empty? p and not empty? q repeat
if f(%head p, %head q)
then (QRPLACD(t, p)$Lisp; t := p; p := %tail p)
else (QRPLACD(t, q)$Lisp; t := q; q := %tail q)
- QRPLACD(t, if Qnull p then q else p)$Lisp
+ QRPLACD(t, if empty? p then q else p)$Lisp
r
split!(p, n) ==
diff --git a/src/algebra/plot.spad.pamphlet b/src/algebra/plot.spad.pamphlet
index 8f4731b2..fdeeafed 100644
--- a/src/algebra/plot.spad.pamphlet
+++ b/src/algebra/plot.spad.pamphlet
@@ -284,7 +284,7 @@ Plot(): Exports == Implementation where
xDiff = 0 or yDiff = 0 => curve
l := lo tRange; h := hi tRange
(tDiff := h-l) = 0 => curve
--- if (EQL(yDiff, quietDoubleNaN()$Lisp)$Lisp) then yDiff := 1::F
+-- if (%sptreq(yDiff, quietDoubleNaN()$Lisp)$Foreign(Builtin)) then yDiff := 1::F
t := curve.knots
#t < 3 => curve
p := curve.points; f := curve.source
diff --git a/src/algebra/plot3d.spad.pamphlet b/src/algebra/plot3d.spad.pamphlet
index eae26c33..44429031 100644
--- a/src/algebra/plot3d.spad.pamphlet
+++ b/src/algebra/plot3d.spad.pamphlet
@@ -192,11 +192,11 @@ Plot3D(): Exports == Implementation where
select(l,f,g) ==
m := f first l
- if (EQL(m, quietDoubleNaN()$Lisp)$Lisp) then m := 0
+ if (%sptreq(m, quietDoubleNaN()$Lisp)$Foreign(Builtin)) then m := 0
-- for p in rest l repeat m := g(m,fp)
for p in rest l repeat
fp : F := f p
- if (EQL(fp, quietDoubleNaN()$Lisp)$Lisp) then fp := 0
+ if (%sptreq(fp, quietDoubleNaN()$Lisp)$Foreign(Builtin)) then fp := 0
m := g(m,fp)
m
diff --git a/src/algebra/si.spad.pamphlet b/src/algebra/si.spad.pamphlet
index c8226492..494f306c 100644
--- a/src/algebra/si.spad.pamphlet
+++ b/src/algebra/si.spad.pamphlet
@@ -182,8 +182,8 @@ IntegerNumberSystem(): Category ==
-- Lisp dependencies
-- ABSVAL, TIMES,
--- QSLESSP, QSGREATERP, QSMINUS, QSPLUS, QSDIFFERENCE
--- QSTIMES,, QSODDP, QSNOT, QSAND
+-- QSLESSP, QSGREATERP, QSDIFFERENCE
+-- QSNOT, QSAND
-- QSOR, QSXOR, QSLEFTSHIFT, QSADDMOD, QSDIFMOD, QSMULTMOD
@@ -333,7 +333,7 @@ SingleInteger(): Join(IntegerNumberSystem,OrderedFinite,BooleanLogic,Logic,OpenM
mulmod(a,b,p) == QSMULTMOD(a,b,p)$Lisp
addmod(a,b,p) == QSADDMOD(a,b,p)$Lisp
submod(a,b,p) == QSDIFMOD(a,b,p)$Lisp
- negative?(x) == QSMINUSP$Lisp x
+ negative?(x) == %ilt(x,%icst0)
size() == (MAXINT -$Lisp MININT +$Lisp %icst1) pretend NonNegativeInteger
index i == per(i + MININT - 1$Lisp)
lookup x ==
diff --git a/src/algebra/strap/SINT.lsp b/src/algebra/strap/SINT.lsp
index 634d0e12..1aa715eb 100644
--- a/src/algebra/strap/SINT.lsp
+++ b/src/algebra/strap/SINT.lsp
@@ -247,7 +247,8 @@
(DECLAIM (FTYPE (FUNCTION (|%Short| |%Shell|) |%Boolean|)
|SINT;negative?;$B;53|))
-(PUT '|SINT;negative?;$B;53| '|SPADreplace| 'QSMINUSP)
+(PUT '|SINT;negative?;$B;53| '|SPADreplace|
+ '(XLAM (|x|) (|%ilt| |x| 0)))
(DECLAIM (FTYPE (FUNCTION (|%Shell|) (|%IntegerSection| 0))
|SINT;size;Nni;54|))
@@ -291,7 +292,7 @@
(DEFUN |SINT;writeOMSingleInt| (|dev| |x| $)
(SEQ (COND
- ((QSMINUSP |x|)
+ ((MINUSP |x|)
(SEQ (SPADCALL |dev| (|getShellEntry| $ 11))
(SPADCALL |dev| "arith1" "unaryminus"
(|getShellEntry| $ 13))
@@ -469,7 +470,7 @@
(DEFUN |SINT;negative?;$B;53| (|x| $)
(DECLARE (IGNORE $))
- (QSMINUSP |x|))
+ (MINUSP |x|))
(DEFUN |SINT;size;Nni;54| ($)
(DECLARE (IGNORE $))
@@ -490,8 +491,7 @@
(DEFUN |SINT;positiveRemainder;3$;58| (|x| |n| $)
(LET ((|r| (REM |x| |n|)))
(COND
- ((QSMINUSP |r|)
- (COND ((QSMINUSP |n|) (- |x| |n|)) (T (+ |r| |n|))))
+ ((MINUSP |r|) (COND ((MINUSP |n|) (- |x| |n|)) (T (+ |r| |n|))))
(T |r|))))
(DEFUN |SINT;coerce;I$;59| (|x| $)
@@ -505,11 +505,11 @@
(DEFUN |SINT;random;2$;61| (|n| $) (DECLARE (IGNORE $)) (RANDOM |n|))
(DEFUN |SINT;unitNormal;$R;62| (|x| $)
- (COND ((QSMINUSP |x|) (VECTOR -1 (- |x|) -1)) (T (VECTOR 1 |x| 1))))
+ (COND ((MINUSP |x|) (VECTOR -1 (- |x|) -1)) (T (VECTOR 1 |x| 1))))
(DEFUN |SingleInteger| ()
(DECLARE (SPECIAL |$ConstructorCache|))
- (PROG (#0=#:G1474)
+ (PROG (#0=#:G1478)
(RETURN
(COND
((SETQ #0# (HGET |$ConstructorCache| '|SingleInteger|))
diff --git a/src/algebra/syntax.spad.pamphlet b/src/algebra/syntax.spad.pamphlet
index e676f343..c62ff29a 100644
--- a/src/algebra/syntax.spad.pamphlet
+++ b/src/algebra/syntax.spad.pamphlet
@@ -114,6 +114,8 @@ Syntax(): Public == Private where
++ x case String is true if `x' really is a String
Private == add
+ import %nil: % from Foreign Builtin
+ import %peq: (%,%) -> Boolean from Foreign Builtin
import %integer?: % -> Boolean from Foreign Builtin
import %float?: % -> Boolean from Foreign Builtin
import %string?: % -> Boolean from Foreign Builtin
@@ -209,7 +211,7 @@ Syntax(): Public == Private where
%makepair(op,l)$Foreign(Builtin)
nil? x ==
- NULL(x)$Lisp
+ %peq(x,%nil)
atom?(x: %): Boolean ==
ATOM(x)$Lisp