diff options
| author | Jay Belanger <jay.p.belanger@gmail.com> | 2005-10-28 03:51:00 +0000 | 
|---|---|---|
| committer | Jay Belanger <jay.p.belanger@gmail.com> | 2005-10-28 03:51:00 +0000 | 
| commit | cbd4e89beaf480605fc6b690a150c5382499e4f6 (patch) | |
| tree | 8951bd0aa8200585b92a4aaa79a3167e97952784 /lisp/calc/calc-ext.el | |
| parent | e069fa61e085d8be77a7f61cf7a1a74e1aafbf7a (diff) | |
| download | emacs-cbd4e89beaf480605fc6b690a150c5382499e4f6.tar.gz | |
Add functions to autoloads.
(math-identity-matrix-p, math-ident-row-p): New functions.
Diffstat (limited to 'lisp/calc/calc-ext.el')
| -rw-r--r-- | lisp/calc/calc-ext.el | 33 | 
1 files changed, 31 insertions, 2 deletions
| diff --git a/lisp/calc/calc-ext.el b/lisp/calc/calc-ext.el index db370f766d9..563bcd9b023 100644 --- a/lisp/calc/calc-ext.el +++ b/lisp/calc/calc-ext.el @@ -659,7 +659,7 @@   ("calc-alg" calc-has-rules math-defsimplify  calc-modify-simplify-mode calcFunc-collect calcFunc-esimplify  calcFunc-islin calcFunc-islinnt calcFunc-lin calcFunc-linnt -calcFunc-simplify calcFunc-subst math-beforep +calcFunc-simplify calcFunc-subst calcFunc-writeoutpower math-beforep  math-build-polynomial-expr math-expand-formula math-expr-contains  math-expr-contains-count math-expr-depends math-expr-height  math-expr-subst math-expr-weight math-integer-plus math-is-linear @@ -923,7 +923,7 @@ calc-force-refresh calc-locate-cursor-element calc-show-edit-buffer)   ("calc-alg" calc-alg-evaluate calc-apart calc-collect calc-expand  calc-expand-formula calc-factor calc-normalize-rat calc-poly-div  calc-poly-div-rem calc-poly-gcd calc-poly-rem calc-simplify -calc-simplify-extended calc-substitute) +calc-simplify-extended calc-substitute calc-writeoutpower)   ("calcalg2" calc-alt-summation calc-derivative  calc-dump-integral-cache calc-integral calc-num-integral @@ -2107,6 +2107,35 @@ calc-kill calc-kill-region calc-yank))))      (and (cdr dims)  	 (= (car dims) (nth 1 dims))))) +;;; True if MAT is an identity matrix. +(defun math-identity-matrix-p (mat &optional mul) +  (if (math-square-matrixp mat) +      (let ((a (if mul +                   (nth 1 (nth 1 mat)) +                 1)) +            (n (1- (length mat))) +            (i 1)) +        (while (and (<= i n) +                    (math-ident-row-p (nth i mat) i a)) +          (setq i (1+ i))) +        (if (> i n) +            a +          nil)))) + +(defun math-ident-row-p (row n &optional a) +  (unless a +    (setq a 1)) +  (and +   (not (memq nil (mapcar  +                   (lambda (x) (eq x 0)) +                   (nthcdr (1+ n) row)))) +   (not (memq nil (mapcar  +                   (lambda (x) (eq x 0)) +                   (butlast  +                    (cdr row) +                    (- (length row) n))))) +   (eq (elt row n) a))) +  ;;; True if A is any scalar data object.  [P x]  (defun math-objectp (a)    ;  [Public]    (or (integerp a) | 
