From 52d8ccbf25a71457f923860824696742328bdb35 Mon Sep 17 00:00:00 2001 From: dos-reis <gdr@axiomatics.org> Date: Mon, 30 Apr 2012 12:57:58 +0000 Subject: * algebra/si.spad.pamphlet (SingleInteger): Use %iaddmod, %isubmod, and %imulmod. * interp/g-opt.boot: These are now builtin side-effect operators. (optIaddmod): New optimizer. Register. (optIsubmod): Likewise. (optImulmod): Likewise. * interp/sys-macros.lisp (QSADDMOD): Remove. (QSDIFMOD): Likewise. (QSMULMOD): Likewise. --- src/interp/g-opt.boot | 14 +++++++++++++- src/interp/sys-macros.lisp | 19 ------------------- 2 files changed, 13 insertions(+), 20 deletions(-) (limited to 'src/interp') diff --git a/src/interp/g-opt.boot b/src/interp/g-opt.boot index ecf4b08c..fedbc988 100644 --- a/src/interp/g-opt.boot +++ b/src/interp/g-opt.boot @@ -639,7 +639,7 @@ $VMsideEffectFreeOperators == %beq %blt %ble %bgt %bge %bitand %bitior %bitxor %bitnot %bcompl %ilength %ibit %icst0 %icst1 %icstmin %icstmax %imul %iadd %isub %igcd %ilcm %ipow %imin %imax %ieven? %iodd? %iinc - %idec %irem %iquo %idivide %idec %irandom + %idec %irem %iquo %idivide %idec %irandom %imulmod %iaddmod %isubmod %feq %flt %fle %fgt %fge %fmul %fadd %fsub %fexp %fmin %fmax %float? %fpowi %fdiv %fneg %i2f %fminval %fmaxval %fbase %fprec %ftrunc %fsqrt %fpowf %flog %flog2 %flog10 %fmanexp %fNaN? %fdecode @@ -917,6 +917,9 @@ optIadd(x is ['%iadd,a,b]) == x x +optIaddmod ['%iaddmod,a,b,c] == + optIrem ['%irem,optIadd ['%iadd,a,b],c] + optIinc(x is ['%iinc,a]) == integer? a => a + 1 a is [op,b,c] and op in '(%isub %iadd) => @@ -951,6 +954,9 @@ optIsub(x is ['%isub,a,b]) == x x +optIsubmod ['%isubmod,a,b,c] == + optIrem ['%irem,optIsub ['%isub,a,b],c] + optIdec(x is ['%idec,a]) == integer? a => a - 1 a is ['%iadd,b,c] => @@ -969,6 +975,9 @@ optImul(x is ['%imul,a,b]) == integer? b and b = 1 => a x +optImulmod(x is ['%imulmod,a,b,c]) == + optIrem ['%irem,optImul ['%imul,a,b],c] + optIneg(x is ['%ineg,a]) == integer? a => -a x @@ -1001,11 +1010,14 @@ for x in '((%call optCall) _ (%ige optIge)_ (%ineg optIneg)_ (%iadd optIadd)_ + (%iaddmod optIaddmod)_ (%iinc optIinc)_ (%isub optIsub)_ + (%isubmod optIsubmod)_ (%irem optIrem)_ (%iquo optIquo)_ (%imul optImul)_ + (%imulmod optImulmod)_ (%2bit opt2bit)_ (%2bool opt2bool)_ (%list optList)_ diff --git a/src/interp/sys-macros.lisp b/src/interp/sys-macros.lisp index 60f71304..8e949642 100644 --- a/src/interp/sys-macros.lisp +++ b/src/interp/sys-macros.lisp @@ -269,25 +269,6 @@ (defmacro SPADDIFFERENCE (&rest x) `(- . ,x)) -;; following macros assume 0 <= x,y < z - -(defmacro QSADDMOD (x y z) - `(let* ((sum (QSPLUS ,x ,y)) - (rsum (QSDIFFERENCE sum ,z))) - (if (QSMINUSP rsum) - sum - rsum))) - -(defmacro QSDIFMOD (x y z) - `(let ((dif (QSDIFFERENCE ,x ,y))) - (if (QSMINUSP dif) - (QSPLUS dif ,z) - dif))) - -(defmacro QSMULTMOD (x y z) - `(REM (* ,x ,y) ,z)) - - ;; ;; -*- Pattern Matching -*- ;; -- cgit v1.2.3