1 ;;; -*- Mode: Lisp; Package: Maxima; Syntax: Common-Lisp; Base: 10 -*- ;;;;
2 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
3 ;;; The data in this file contains enhancments. ;;;;;
5 ;;; Copyright (c) 1984,1987 by William Schelter,University of Texas ;;;;;
6 ;;; All rights reserved ;;;;;
7 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
8 ;;; (c) Copyright 1981 Massachusetts Institute of Technology ;;
9 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
13 (macsyma-module laplac
)
15 (declare-top (special var $savefactors
16 checkfactors $ratfac $keepfloat
*nounl
* *nounsflag
*
19 ;;; The properties NOUN and VERB give correct linear display
21 (defprop $laplace %laplace verb
)
22 (defprop %laplace $laplace noun
)
24 (defprop $ilt %ilt verb
)
25 (defprop %ilt $ilt noun
)
27 (defun exponentiate (pow)
28 ;;;COMPUTES %E**Z WHERE Z IS AN ARBITRARY EXPRESSION TAKING SOME OF THE WORK AWAY FROM SIMPEXPT
29 (cond ((zerop1 pow
) 1)
31 (t (power '$%e pow
))))
33 (defun fixuprest (rest)
34 ;;;REST IS A PRODUCT WITHOUT THE MTIMES.FIXUPREST PUTS BACK THE MTIMES
36 ((cdr rest
) (cons '(mtimes) rest
))
39 (defun isquadraticp (e x
)
40 (let ((b (sdiff e x
)))
41 (cond ((zerop1 b
) (list 0 0 e
))
42 ((freeof x b
) (list 0 b
(maxima-substitute 0 x e
)))
43 ((setq b
(islinear b x
))
44 (list (div* (car b
) 2) (cdr b
) (maxima-substitute 0 x e
))))))
46 ;;;INITIALIZES SOME GLOBAL VARIABLES THEN CALLS THE DISPATCHING FUNCTION
48 (defmfun $laplace
(fun var parm
)
49 (setq fun
(mratcheck fun
))
50 (cond ((or *nounsflag
* (member '%laplace
*nounl
* :test
#'eq
))
51 (setq fun
(remlaplace fun
))))
52 (cond ((and (null (atom fun
)) (eq (caar fun
) 'mequal
))
54 (laplace (cadr fun
) parm
)
55 (laplace (caddr fun
) parm
)))
56 (t (laplace fun parm
))))
58 ;;;LAMBDA BINDS SOME SPECIAL VARIABLES TO NIL AND DISPATCHES
63 (cons (delete 'laplace
(append (car e
) nil
) :count
1 :test
#'eq
)
64 (mapcar #'remlaplace
(cdr e
)))))
66 (defun laplace (fun parm
&optional
(dvar nil
))
68 ;;; Handles easy cases and calls appropriate function on others.
69 (cond ((equal fun
0) 0)
71 (cond ((zerop1 parm
) (simplify (list '($delta
) 0)))
73 ((alike1 fun var
) (power parm -
2))
74 ((or (atom fun
) (freeof var fun
))
75 (cond ((zerop1 parm
) (mul2 fun
(simplify (list '($delta
) 0))))
76 (t (mul2 fun
(power parm -
1)))))
78 (let ((op (caar fun
)))
79 (let ((result ; We store the result of laplace for further work.
83 (laptimes (cdr fun
) parm
))
85 (lapexpt fun nil parm
))
87 (lapsin fun nil nil parm
))
89 (lapsin fun nil t parm
))
91 (lapsinh fun nil nil parm
))
93 (lapsinh fun nil t parm
))
99 (lapint fun parm dvar
))
102 (laplace (cadr fun
) parm
)
108 ((and (eq op
'%ilt
)(eq (cadddr fun
) var
))
109 (cond ((eq parm
(caddr fun
))(cadr fun
))
110 (t (subst parm
(caddr fun
)(cadr fun
)))))
112 (lapdelta fun nil parm
))
113 ((setq op
($get op
'$laplace
))
114 (mcall op fun var parm
))
115 (t (lapdefint fun parm
)))))
116 (when (isinop result
'%integrate
)
117 ;; Laplace has not found a result but returns a definit
118 ;; integral. This integral can contain internal integration
119 ;; variables. Replace such a result with the noun form.
120 (setq result
(list '(%laplace
) fun var parm
)))
121 ;; Check if we have a result, when not call $specint.
122 (check-call-to-$specint result fun parm
)))))))
124 ;;; Check if laplace has found a result, when not try $specint.
126 (defun check-call-to-$specint
(result fun parm
)
128 ((or (isinop result
'%laplace
)
129 (isinop result
'%limit
) ; Try $specint for incomplete results
130 (isinop result
'%at
)) ; which contain %limit or %at too.
131 ;; laplace returns a noun form or a result which contains %limit or %at.
132 ;; We pass the function to $specint to look for more results.
134 ;; laplace assumes the parameter s to be positive and does a
135 ;; declaration before an integration is done. Therefore we declare
136 ;; the parameter of the Laplace transform to be positive before
137 ;; we call $specint too.
138 (with-new-context (context)
139 (meval `(($assume
) ,@(list (list '(mgreaterp) parm
0))))
140 (setq res
($specint
(mul fun
(power '$%e
(mul -
1 var parm
))) var
)))
141 (if (or (isinop res
'%specint
) ; Both symobls are possible, that is
142 (isinop res
'$specint
)) ; not consistent! Check it! 02/2009
143 ;; $specint has not found a result.
145 ;; $specint has found a result
149 (defun laplus (fun parm
)
150 (simplus (cons '(mplus) (mapcar #'(lambda (e) (laplace e parm
)) (cdr fun
))) 1 t
))
152 (defun laptimes (fun parm
)
153 ;;;EXPECTS A LIST (PERHAPS EMPTY) OF FUNCTIONS MULTIPLIED TOGETHER WITHOUT THE MTIMES
154 ;;;SEES IF IT CAN APPLY THE FIRST AS A TRANSFORMATION ON THE REST OF THE FUNCTIONS
155 (cond ((null fun
) (list '(mexpt) parm -
1.
))
156 ((null (cdr fun
)) (laplace (car fun
) parm
))
157 ((freeof var
(car fun
))
158 (simptimes (list '(mtimes)
160 (laptimes (cdr fun
) parm
))
164 (simptimes (list '(mtimes) -
1 (sdiff (laptimes (cdr fun
) parm
) parm
))
168 (let ((op (caaar fun
)))
169 (cond ((eq op
'mexpt
)
170 (lapexpt (car fun
) (cdr fun
) parm
))
172 (laplus ($multthru
(fixuprest (cdr fun
)) (car fun
)) parm
))
174 (lapsin (car fun
) (cdr fun
) nil parm
))
176 (lapsin (car fun
) (cdr fun
) t parm
))
178 (lapsinh (car fun
) (cdr fun
) nil parm
))
180 (lapsinh (car fun
) (cdr fun
) t parm
))
182 (lapdelta (car fun
) (cdr fun
) parm
))
184 (lapshift (car fun
) (cdr fun
) parm
)))))))
186 (defun lapexpt (fun rest parm
)
187 ;;;HANDLES %E**(A*T+B)*REST(T), %E**(A*T**2+B*T+C),
188 ;;; 1/SQRT(A*T+B), OR T**K*REST(T)
189 (prog (ab base-of-fun power result
)
190 (setq base-of-fun
(cadr fun
) power
(caddr fun
))
193 (freeof var base-of-fun
)
197 (cond ((eq base-of-fun
'$%e
) power
)
198 (t (simptimes (list '(mtimes)
205 (cond ((equal (car ab
) 0) (go %e-case-lin
))
206 ((null rest
) (go %e-case-quad
))
208 ((and (eq base-of-fun var
) (freeof var power
))
210 ((and (alike1 '((rat) -
1 2) power
) (null rest
)
211 (setq ab
(islinear base-of-fun var
)))
212 (setq result
(div* (cdr ab
) (car ab
)))
221 (exponentiate (list '(mtimes) result parm
))
237 (rest (sratsimp ($at
(laptimes rest parm
)
247 (afixsign (cadr ab
) nil
))
249 (return (simptimes (list '(mtimes)
250 (exponentiate (caddr ab
))
255 (setq result
(afixsign (car ab
) nil
))
264 (exponentiate (div* (list '(mexpt) parm
2)
265 (list '(mtimes) 4 result
)))
278 (and (null (equal (cadr ab
) 0))
280 (maxima-substitute (list '(mplus)
287 (return (simptimes (list '(mtimes)
288 (exponentiate (caddr ab
))
291 (cond ((or (null rest
) (freeof var
(fixuprest rest
)))
293 (cond ((posint power
)
294 (return (afixsign (apply '$diff
295 (list (laptimes rest parm
)
300 (return (mydefint (hackit power rest parm
)
301 (createname parm
(- power
))
306 (simplus (list '(mplus) 1 power
) 1 t
))
307 (or (eq (asksign power
) '$positive
) (go noluck
))
308 (setq result
(list (list '(%gamma
) power
)
311 (afixsign power nil
))))
312 (and rest
(setq result
(nconc result rest
)))
313 (return (simptimes (cons '(mtimes) result
) 1 nil
))
318 (member (caar base-of-fun
)
319 '(mplus %sin %cos %sinh %cosh
) :test
#'eq
))
320 (laptimes (cons base-of-fun
321 (cons (cond ((= power
2) base-of-fun
)
326 (t (lapshift fun rest parm
))))))
328 ;;;INTEGRAL FROM A TO INFINITY OF F(X)
329 (defun mydefint (f x a parm
)
330 (let ((tryint (and (not ($unknown f
))
331 ;; We don't want any errors thrown by $defint to propagate,
332 ;; so we set errset, errcatch, $errormsg and *mdebug*. If
333 ;; $defint throws a error, then no error message is printed
334 ;; and errset simply returns nil below.
335 (with-new-context (context)
336 (meval `(($assume
) ,@(list (list '(mgreaterp) parm
0))))
337 (meval `(($assume
) ,@(list (list '(mgreaterp) x
0))))
338 (meval `(($assume
) ,@(list (list '(mgreaterp) a
0))))
343 (errset ($defint f x a
'$inf
)))))))
346 (list '(%integrate
) f x a
'$inf
))))
348 ;;;CREATES UNIQUE NAMES FOR VARIABLE OF INTEGRATION
349 (defun createname (head tail
)
350 (intern (format nil
"~S~S" head tail
)))
352 ;;;REDUCES LAPLACE(F(T)/T**N,T,S) CASE TO LAPLACE(F(T)/T**(N-1),T,S) CASE
353 (defun hackit (exponent rest parm
)
354 (cond ((equal exponent -
1)
355 (let ((parm (createname parm
1)))
356 (laptimes rest parm
)))
357 (t (mydefint (hackit (1+ exponent
) rest parm
)
358 (createname parm
(- -
1 exponent
))
359 (createname parm
(- exponent
)) parm
))))
361 (defun afixsign (funct signswitch
)
362 ;;;MULTIPLIES FUNCT BY -1 IF SIGNSWITCH IS NIL
363 (cond (signswitch funct
)
364 (t (simptimes (list '(mtimes) -
1 funct
) 1 t
))))
366 (defun lapshift (fun rest parm
)
367 (cond ((atom fun
) (merror "LAPSHIFT: expected a cons, not ~M" fun
))
368 ((or (member 'laplace
(car fun
) :test
#'eq
) (null rest
))
369 (lapdefint (cond (rest (simptimes (cons '(mtimes)
370 (cons fun rest
)) 1 t
))
372 (t (laptimes (append rest
373 (ncons (cons (append (car fun
)
375 (cdr fun
)))) parm
))))
377 ;;;COMPUTES %E**(W*B*%I)*F(S-W*A*%I) WHERE W=-1 IF SIGN IS T ELSE W=1
378 (defun mostpart (f parm sign a b
)
379 (let ((substinfun ($at f
382 (list '(mplus) parm
(afixsign (list '(mtimes) a
'$%i
) sign
))))))
386 (exponentiate (afixsign (list '(mtimes) b
'$%i
) (null sign
)))
389 ;;;IF WHICHSIGN IS NIL THEN SIN TRANSFORM ELSE COS TRANSFORM
390 (defun compose (fun parm whichsign a b
)
391 (let ((result (list '((rat) 1 2)
393 (mostpart fun parm t a b
)
394 (afixsign (mostpart fun parm nil a b
)
396 (sratsimp (simptimes (cons '(mtimes)
402 ;;;FUN IS OF THE FORM SIN(A*T+B)*REST(T) OR COS
403 (defun lapsin (fun rest trigswitch parm
)
404 (let ((ab (islinear (cadr fun
) var
)))
407 (compose (laptimes rest parm
)
415 (cond ((zerop1 (cdr ab
))
416 (if trigswitch parm
(car ab
)))
422 (list '(%cos
) (cdr ab
)))
426 (list '(%sin
) (cdr ab
)))))
431 (list '(%sin
) (cdr ab
)))
434 (list '(%cos
) (cdr ab
))))))))
437 (list '(mexpt) parm
2)
438 (list '(mexpt) (car ab
) 2))
442 (lapshift fun rest parm
)))))
444 ;;;FUN IS OF THE FORM SINH(A*T+B)*REST(T) OR IS COSH
445 (defun lapsinh (fun rest switch parm
)
446 (cond ((islinear (cadr fun
) var
)
451 (nconc (list '(mtimes)
457 (afixsign (nconc (list '(mtimes)
467 (t (lapshift fun rest parm
))))
469 ;;;FUN IS OF THE FORM LOG(A*T)
470 (defun laplog (fun parm
)
471 (let ((ab (islinear (cadr fun
) var
)))
472 (cond ((and ab
(zerop1 (cdr ab
)))
473 (simptimes (list '(mtimes)
475 (subfunmake '$psi
'(0) (ncons 1))
476 (list '(%log
) (car ab
))
477 (list '(mtimes) -
1 (list '(%log
) parm
)))
478 (list '(mexpt) parm -
1))
481 (lapdefint fun parm
)))))
483 (defun raiseup (fbase exponent
)
484 (if (equal exponent
1)
486 (list '(mexpt) fbase exponent
)))
488 ;;TAKES TRANSFORM OF DELTA(A*T+B)*F(T)
489 (defun lapdelta (fun rest parm
)
490 (let ((ab (islinear (cadr fun
) var
))
494 (setq recipa
(power (car ab
) -
1) ab
(div (cdr ab
) (car ab
)))
495 (setq sign
(asksign ab
) recipa
(simplifya (list '(mabs) recipa
) nil
))
496 (simplifya (cond ((eq sign
'$positive
)
500 (maxima-substitute 0 var
(fixuprest rest
))
504 (maxima-substitute (neg ab
) var
(fixuprest rest
))
505 (list '(mexpt) '$%e
(cons '(mtimes) (cons parm
(ncons ab
))))
509 (lapshift fun rest parm
)))))
511 (defun laperf (fun parm
)
512 (let ((ab (islinear (cadr fun
) var
)))
513 (cond ((and ab
(equal (cdr ab
) 0))
514 (simptimes (list '(mtimes)
515 (div* (exponentiate (div* (list '(mexpt) parm
2)
518 (list '(mexpt) (car ab
) 2))))
524 (list '(%erf
) (div* parm
(list '(mtimes) 2 (car ab
)))))))
528 (lapdefint fun parm
)))))
530 (defun lapdefint (fun parm
)
532 (and ($unknown fun
)(go skip
))
533 (setq mult
(simptimes (list '(mtimes) (exponentiate
534 (list '(mtimes) -
1 var parm
)) fun
) 1 nil
))
535 (with-new-context (context)
536 (meval `(($assume
) ,@(list (list '(mgreaterp) parm
0))))
538 ;; We don't want any errors thrown by $defint to propagate,
539 ;; so we set errset, errcatch, $errormsg and *mdebug*. If
540 ;; $defint throws a error, then no error message is printed
541 ;; and errset simply returns nil below.
546 (errset ($defint mult var
0 '$inf
)))))
547 (and tryint
(not (eq (and (listp (car tryint
))
550 (return (car tryint
)))
551 skip
(return (list '(%laplace
) fun var parm
))))
554 (defun lapdiff (fun parm
)
555 ;;;FUN IS OF THE FORM DIFF(F(T),T,N) WHERE N IS A POSITIVE INTEGER
556 (prog (difflist degree frontend resultlist newdlist order arg2
)
557 (setq newdlist
(setq difflist
(copy-tree (cddr fun
))))
558 (setq arg2
(list '(mequal) var
0))
559 a
(cond ((null difflist
)
560 (return (cons '(%derivative
)
561 (cons (list '(%laplace
)
566 ((eq (car difflist
) var
)
567 (setq degree
(cadr difflist
)
568 difflist
(cddr difflist
))
570 (setq difflist
(cdr (setq frontend
(cdr difflist
))))
572 out
(cond ((null (posint degree
))
573 (return (list '(%laplace
) fun var parm
))))
574 (cond (frontend (rplacd frontend difflist
))
575 (t (setq newdlist difflist
)))
576 (cond (newdlist (setq fun
(cons '(%derivative
)
579 (t (setq fun
(cadr fun
))))
583 (cons (list '(mtimes)
584 (raiseup parm degree
)
585 ($at
($diff fun var order
) arg2
))
588 (and (> degree
0) (go loop
))
589 (setq resultlist
(cond ((cdr resultlist
)
592 (t (car resultlist
))))
593 (return (simplus (list '(mplus)
602 ;;;FUN IS OF THE FORM INTEGRATE(F(X)*G(T)*H(T-X),X,0,T)
603 (defun lapint (fun parm dvar
)
604 (prog (newfun parm-list f var-list var-parm-list
)
605 (and dvar
(go convolution
))
606 (setq dvar
(cadr (setq newfun
(cdr fun
))))
608 (zerop1 (caddr newfun
))
609 (eq (cadddr newfun
) var
)
610 (go convolutiontest
))
612 (setq newfun
(cdr fun
))
614 (cond ((and (freeof var
(caddr newfun
))
615 (freeof var
(cadddr newfun
)))
616 (return (list '(%integrate
)
617 (laplace (car newfun
) parm dvar
)
622 (t (return (list '(%integrate
)
623 (laplace (car newfun
) parm dvar
)
626 (return (list '(%laplace
) fun var parm
))
628 (setq newfun
($factor
(car newfun
)))
629 (cond ((eq (caar newfun
) 'mtimes
)
630 (setq f
(cadr newfun
) newfun
(cddr newfun
)))
631 (t (setq f newfun newfun nil
)))
633 (cond ((freeof dvar f
)
634 (setq parm-list
(cons f parm-list
)))
635 ((freeof var f
) (setq var-list
(cons f var-list
)))
637 (sratsimp (maxima-substitute (list '(mplus)
642 (setq var-parm-list
(cons f var-parm-list
)))
644 (cond (newfun (setq f
(car newfun
) newfun
(cdr newfun
))
653 (ncons (list '(%integrate
)
665 (laplace ($expand
(maxima-substitute var
667 (fixuprest var-list
))) parm dvar
)
669 ($expand
(maxima-substitute 0 dvar
(fixuprest var-parm-list
))) parm dvar
))
673 (declare-top (special varlist ratform ils ilt
))
675 (defmfun $ilt
(exp ils ilt
)
676 ;;;EXP IS F(S)/G(S) WHERE F AND G ARE POLYNOMIALS IN S AND DEGR(F) < DEGR(G)
677 (let (varlist ($savefactors t
) checkfactors $ratfac $keepfloat
)
678 ;;; MAKES ILS THE MAIN VARIABLE
679 (setq varlist
(list ils
))
681 (orderpointer varlist
)
682 (setq var
(caadr (ratrep* ils
)))
683 (cond ((and (null (atom exp
))
684 (eq (caar exp
) 'mequal
))
686 ($ilt
(cadr exp
) ils ilt
)
687 ($ilt
(caddr exp
) ils ilt
)))
690 (list '(%ilt
) exp ils ilt
))
693 (defun maxima-rationalp (le v
)
695 ((and (null (atom (car le
))) (null (freeof v
(car le
))))
697 (t (maxima-rationalp (cdr le
) v
))))
699 ;;;THIS FUNCTION DOES THE PARTIAL FRACTION DECOMPOSITION
701 (prog (wholepart frpart num denom y content real factor
702 apart bpart parnumer ratarg ratform
)
704 (return (simplus (cons '(mplus)
705 (mapcar #'(lambda (f) ($ilt f ils ilt
)) (cdr exp
))) 1 t
)))
706 (and (null (atom exp
))
707 (eq (caar exp
) '%laplace
)
708 (eq (cadddr exp
) ils
)
709 (return (cond ((eq (caddr exp
) ilt
) (cadr exp
))
713 (setq ratarg
(ratrep* exp
))
714 (or (maxima-rationalp varlist ils
)
715 (return (list '(%ilt
) exp ils ilt
)))
716 (setq ratform
(car ratarg
))
717 (setq denom
(ratdenominator (cdr ratarg
)))
718 (setq frpart
(pdivide (ratnumerator (cdr ratarg
)) denom
))
719 (setq wholepart
(car frpart
))
720 (setq frpart
(ratqu (cadr frpart
) denom
))
721 (cond ((not (zerop1 (car wholepart
)))
722 (return (list '(%ilt
) exp ils ilt
)))
723 ((zerop1 (car frpart
)) (return 0)))
724 (setq num
(car frpart
) denom
(cdr frpart
))
725 (setq y
(oldcontent denom
))
726 (setq content
(car y
))
728 (setq factor
(pfactor real
))
729 loop
(cond ((null (cddr factor
))
734 (setq apart
(pexpt (car factor
) (cadr factor
)))
735 (setq bpart
(car (ratqu real apart
)))
736 (setq y
(bprog apart bpart
))
738 (cdr (ratdivide (ratti (ratnumerator num
)
741 (ratti (ratdenominator num
)
742 (ratti content apart t
)
746 (cons (ilt1 (ratqu (ratnumerator frpart
)
747 (ratti (ratdenominator frpart
)
748 (ratti (ratdenominator num
)
755 (setq factor
(cddr factor
))
757 (return (simplus (cons '(mplus) parnumer
) 1 t
))))
758 (setq num
(cdr (ratdivide (ratti num
(car y
) t
)
759 (ratti content bpart t
))))
763 (declare-top (special q z
))
767 (cond ((onep1 k
) (ilt3 p
))
768 (t (setq z
(bprog q
(pderivative q var
)))
772 ;;;INVERTS P(S)/Q(S)**K WHERE Q(S) IS IRREDUCIBLE
773 ;;;DOESN'T CALL ILT3 IF Q(S) IS LINEAR
776 (and (onep1 k
) (return (ilt3 p
)))
778 (setq a
(ratti p
(car z
) t
))
779 (setq b
(ratti p
(cdr z
) t
))
782 ((or (null (equal (pdegree q var
) 1))
783 (> (pdegree (car p
) var
) 0))
789 (cdr (ratdivide (ratplus a
(ratqu (ratderivative b var
) k
)) y
))
791 ($multthru
(simptimes (list '(mtimes)
794 (ilt2 (cdr (ratdivide b y
)) k
))
799 (setq a
(disrep (polcoef q
1))
800 b
(disrep (polcoef q
0)))
802 (simptimes (list '(mtimes)
805 (simpexpt (list '(mexpt)
811 (list '(mexpt) a -
1)))
823 ;;(DEFUN COEF MACRO (POL) (SUBST (CADR POL) (QUOTE DEG)
824 ;; '(DISREP (RATQU (POLCOEF (CAR P) DEG) (CDR P)))))
827 `(disrep (ratqu (polcoef (car p
) ,pol
) (cdr p
))))
829 (defun lapsum (&rest args
)
830 (cons '(mplus) args
))
832 (defun lapprod (&rest args
)
833 (cons '(mtimes) args
))
835 (defun expo (&rest args
)
836 (cons '(mexpt) args
))
838 ;;;INVERTS P(S)/Q(S) WHERE Q(S) IS IRREDUCIBLE
840 (prog (discrim sign a c d e b1 b0 r term1 term2 degr
)
841 (setq e
(disrep (polcoef q
0))
842 d
(disrep (polcoef q
1))
843 degr
(pdegree q var
))
849 (expo '$%e
(lapprod -
1 ilt e
(expo d -
1))))
852 (setq c
(disrep (polcoef q
2)))
853 (and (equal degr
2) (go quadratic
))
854 (and (equal degr
3) (zerop1 c
) (zerop1 d
)
856 (return (list '(%ilt
) (div* (disrep p
)(disrep q
)) ils ilt
))
857 cubic
(setq a
(disrep (polcoef q
3))
858 r
(simpnrt (div* e a
) 3))
859 (setq d
(div* (disrep p
)(lapprod a
(lapsum
860 (expo ils
3)(expo '%r
3)))))
861 (return (ilt0 (maxima-substitute r
'%r
($partfrac d ils
))))
862 quadratic
(setq b0
(coef 0) b1
(coef 1))
870 (setq sign
(cond ((free discrim
'$%i
) (asksign discrim
)) (t '$positive
))
873 (setq degr
(expo '$%e
(lapprod ilt d
(power c -
1) '((rat) -
1 2))))
874 (cond ((eq sign
'$zero
)
875 (return (simptimes (lapprod degr
(lapsum (div* b1 c
)
877 (div* (lapsum (lapprod 2 b0 c
) (lapprod -
1 b1 d
))
878 (lapprod 2 c c
)) ilt
))) 1 nil
))
879 ) ((eq sign
'$negative
)
882 discrim
(simptimes (lapprod -
1 discrim
) 1 t
))))
883 (setq discrim
(simpnrt discrim
2))
893 (setq c
(power c -
1))
894 (setq discrim
(simptimes (lapprod
905 (lapprod b1
(list term1 discrim
))
906 (lapprod sign
(list term2 discrim
))))
910 (declare-top (unspecial ils ilt
*nounl
* q ratform var