aboutsummaryrefslogtreecommitdiff
path: root/src/input/pmint.input.pamphlet
diff options
context:
space:
mode:
Diffstat (limited to 'src/input/pmint.input.pamphlet')
-rw-r--r--src/input/pmint.input.pamphlet548
1 files changed, 548 insertions, 0 deletions
diff --git a/src/input/pmint.input.pamphlet b/src/input/pmint.input.pamphlet
new file mode 100644
index 00000000..35d8542b
--- /dev/null
+++ b/src/input/pmint.input.pamphlet
@@ -0,0 +1,548 @@
+\documentclass{article}
+\usepackage{axiom}
+\begin{document}
+\title{\$SPAD/src/input pmint.input}
+\author{Manuel Bronstein}
+\maketitle
+\begin{abstract}
+pmint is a very short (95 lines) Maple program for integrating
+transcendental elementary or special functions. It is based on recent
+improvements to a powerful heuristic called parallel
+integration. While it is not meant to be as complete as the large
+commercial integrators based on the Risch algorithm, its very small
+size makes it easy to port to any computer algebra system or library
+capable of factoring multivariate polynomials. Because it is
+applicable to special functions (such as Airy, Bessel, Whittaker,
+Lambert), it is able to compute integrals not handled by the existing
+integrators.
+
+pmint is not meant as a replacement for existing integrators, but
+either as an extension, or as a cheap and powerful alternative for any
+computer algebra project.
+
+\end{abstract}
+\eject
+\tableofcontents
+\eject
+\section{pmint}
+These come from Manuel Bronstein's pages at
+http://www-sop.inria.fr/cafe/Manuel.Bronstein/pmint/examples
+
+\section{The Maple Code}
+The maple code is:
+\begin{verbatim}
+
+# The Poor Man's Integrator, a parallel integration heuristic
+# Version 1.1 --- May 10, 2005 (c) M.Bronstein and INRIA 2004-2005
+pmint := proc(f,x)
+ local ff, si, li, lin, lout, ld, q, d, l, vars, dx, ls, fint, lc;
+ ff := eval(convert(f, tan)); # convert trigs to tan
+ si := select(proc(d) diff(d,x) <> 0 end, indets(ff));
+ si := select(proc(d) diff(d,x) <> 0 end, indets(map(diff, si, x))) union si;
+ li := [op(si)]; # list of terms in integrand and its derivative
+ lin := [seq(d=`tools/genglobal`(x), d=li)]; # substitution terms->indets
+ lout := [seq(rhs(d)=lhs(d), d=lin)]; # substitution indets->terms
+ ld := subs(lin, map(diff, li, x)); # derivatives of all the terms
+ q := lcm(seq(denom(d), d=ld)); # denominator of the total derivation
+ l := [seq(normal(q * d), d=ld)]; # q * derivatives of all the terms
+ vars := map(lhs, lout);
+ dx := totalDerivation(vars, l); # vector field dx = q * d/dx
+ ls := [seq(getSpecial(d, lin), d=li)]; # list of known Darboux for dx
+ fint := subs(lout, pmIntegrate(subs(lin, ff), dx, q, vars, ls));
+ lc := select(proc(d) convert(d,string)[1]="_"; end, indets(fint, name));
+ subs({seq(d = 0, d=lc minus si)}, fint);
+end;
+
+getSpecial := proc(f, l) local p; # return known Darboux polys
+ p := op(0,f);
+ if p = `tan` then [1+subs(l,f)^2, false];
+ elif p = `tanh` then [1 + subs(l,f), false], [1 - subs(l,f), false];
+ elif p = `LambertW` then [subs(l,f), true];
+ else NULL; fi;
+end;
+
+totalDerivation := proc(lv, ld)
+ proc(f) local fp, i;
+ fp := 0; for i to nops(ld) do fp := fp + ld[i] * diff(f, lv[i]); od;
+ fp;
+ end;
+end;
+
+pmIntegrate := proc(f, d, q, vars)
+ local ls, splq, s, ff, df, spl, cden, dg, monomials, cand, lunk, sol, i;
+ if nargs = 5 then ls := args[5]; else ls := []; fi;
+ splq := splitFactor(q, d);
+ s := splq[1]; for i to nops(ls) do if ls[i][2] then s := s*ls[i][1]; fi; od;
+ ff := normal(f); df := denom(ff); spl := splitFactor(df, d);
+ cden := s * spl[1] * deflation(spl[2], d);
+ dg := 1 + degree(s) + max(degree(numer(ff)), degree(denom(ff)));
+ monomials := [op(enumerateMonoms(vars, dg))];
+ cand := add('_A'[i] * monomials[i], i = 1..nops(monomials)) / cden;
+ lunk := { seq('_A'[i], i = 1..nops(monomials)) };
+ sol:= tryIntegral(f, d, q, vars, cand, lunk, spl[1], spl[2], splq[1], ls, 0);
+ if sol[1] then sol := tryIntegral(f, d, q, vars, cand, lunk,
+ spl[1], spl[2], splq[1], ls, I); fi;
+ if sol[1] then Int(f); else sol[2]; fi;
+end;
+
+tryIntegral := proc(f, d, q, vars, cand, lunk, l1, l2, l3, ls, K)
+ local candlog, p, candidate, i, sol;
+ candlog := [op({ myfactors(l1, K), myfactors(l2, K), myfactors(l3, K) }
+ union { seq(p[1], p=ls) })];
+ candidate := cand + add('_B'[i] * log(candlog[i]), i = 1..nops(candlog));
+ sol := solve({coeffs(numer(normal(f - d(candidate)/q)), {op(vars)})},
+ lunk union { seq('_B'[i], i = 1..nops(candlog)) });
+ [evalb(sol=NULL), subs(sol,candidate)];
+end;
+
+myfactors := proc(p, K) local l, fact;
+ if K = 0 then l := factors(p); else l := factors(p, K); fi;
+ seq(fact[1], fact=l[2]);
+end;
+
+enumerateMonoms := proc(vars, d) local n, x, i, v, s, w;
+ n := nops(vars);
+ if n = 0 then {1}; else
+ x := vars[n];
+ v := [seq(vars[i], i = 1..n-1)];
+ s := enumerateMonoms(v, d);
+ for i to d do s := s union {seq(x^i*w,w=enumerateMonoms(v,d-i))}; od;
+ s;
+ fi;
+end;
+
+splitFactor := proc(p, d) local si, x, c, q, spl, s, splh;
+ si := select(proc(z) d(z) <> 0 end, indets(p,name));
+ if si = {} then RETURN([1,p]) fi;
+ x := si[1];
+ c := content(p, x, 'q');
+ spl := splitFactor(c, d);
+ s := normal(gcd(q, d(q)) / gcd(q, diff(q, x)));
+ if degree(s) = 0 then RETURN([spl[1], q * spl[2]]); fi;
+ splh := splitFactor(normal(q / s), d);
+ [spl[1] * splh[1] * s, spl[2] * splh[2]];
+end;
+
+deflation := proc(p, d) local si, x, c, q;
+ si := select(proc(z) d(z) <> 0 end, indets(p,name));
+ if si = {} then RETURN(p) fi;
+ x := si[1];
+ c := content(p, x, 'q');
+ deflation(c, d) * gcd(q, diff(q, x));
+end;
+
+\end{verbatim}
+\section{rational functions}
+<<rational functions>>=
+)clear all
+-- Rational Functions
+
+f:=(x^7-24*x^4-4*x^2+8*x-8)/(x^8+6*x^6+12*x^4+8*x^2)
+-- should be:
+-- 7 4 2
+-- x - 24x - 4x + 8x - 8
+-- (1) ------------------------
+-- 8 6 4 2
+-- x + 6x + 12x + 8x
+-- Type: Fraction Polynomial Integer
+
+g:=integrate(f,x)
+-- should be:
+-- 5 3 3 2
+-- (x + 4x + 4x)log(x) + 3x + 8x + 6x + 4
+-- (2) ------------------------------------------
+-- 5 3
+-- x + 4x + 4x
+-- Type: Union(Expression Integer,...)
+
+differentiate(g,x)
+-- should be:
+-- 7 4 2
+-- x - 24x - 4x + 8x - 8
+-- (3) ------------------------
+-- 8 6 4 2
+-- x + 6x + 12x + 8x
+-- Type: Expression Integer
+
+@
+\section{trigonometric functions}
+<<trigonometric functions>>=
+)clear all
+-- Trigonometric Functions
+
+f:=(x-tan(x))/tan(x)^2 + tan(x)
+-- should be:
+-- 3
+-- tan(x) - tan(x) + x
+-- (1) --------------------
+-- 2
+-- tan(x)
+-- Type: Expression Integer
+
+g:=integrate(f,x)
+-- should be:
+-- 2 2
+-- tan(x)log(tan(x) + 1) - x tan(x) - 2x
+-- (2) --------------------------------------
+-- 2tan(x)
+-- Type: Union(Expression Integer,...)
+
+differentiate(g,x)
+-- should be:
+-- 3
+-- tan(x) - tan(x) + x
+-- (3) --------------------
+-- 2
+-- tan(x)
+-- Type: Expression Integer
+
+@
+\section{log-exp functions}
+<<log-exp functions>>=
+)clear all
+-- Log-Exp Functions
+
+f:=(1+x+x*exp(x))*(x+log(x)+exp(x)-1)/(x+log(x)+exp(x))^2/x
+-- should be:
+-- x x 2 2 x 2
+-- (x %e + x + 1)log(x) + x (%e ) + (x + 1)%e + x - 1
+-- (1) ---------------------------------------------------------
+-- 2 x 2 x 2 2 x 3
+-- x log(x) + (2x %e + 2x )log(x) + x (%e ) + 2x %e + x
+-- Type: Expression Integer
+
+g:=integrate(f,x)
+-- should be:
+-- x x
+-- (log(x) + %e + x)log(log(x) + %e + x) + 1
+-- (2) -------------------------------------------
+-- x
+-- log(x) + %e + x
+-- Type: Union(Expression Integer,...)
+
+differentiate(g,x)
+-- should be:
+-- x x 2 2 x 2
+-- (x %e + x + 1)log(x) + x (%e ) + (x + 1)%e + x - 1
+-- (3) ---------------------------------------------------------
+-- 2 x 2 x 2 2 x 3
+-- x log(x) + (2x %e + 2x )log(x) + x (%e ) + 2x %e + x
+-- Type: Expression Integer
+
+@
+\section{liouvillian functions}
+<<liouvillian functions>>=
+)clear all
+-- Liouvillian special functions
+
+f:=exp(-x^2)+erf(x)/(erf(x)^3-erf(x)^2-erf(x)+1)
+-- should be:
+-- 2
+-- 3 2 - x
+-- (erf(x) - erf(x) - erf(x) + 1)%e + erf(x)
+-- (4) -----------------------------------------------
+-- 3 2
+-- erf(x) - erf(x) - erf(x) + 1
+-- Type: Expression Integer
+
+--
+-- 2
+-- x 3 2 - %G
+-- ++ (erf(%G) - erf(%G) - erf(%G) + 1)%e + erf(%G)
+-- (2) | ---------------------------------------------------- d%G
+-- ++ 3 2
+-- erf(%G) - erf(%G) - erf(%G) + 1
+-- Type: Union(Expression Integer,...)
+
+
+
+f:=(exp(-x^2)+erf(x))/(erf(x)^3-erf(x)^2-erf(x)+1)
+-- should be:
+-- 2
+-- - x
+-- %e + erf(x)
+-- (3) ------------------------------
+-- 3 2
+-- erf(x) - erf(x) - erf(x) + 1
+-- Type: Expression Integer
+
+integrate(f,x)
+-- should be:
+-- 1 sqrt(%pi) 1 1
+-- - - ------------ - - sqrt(%pi) log(erf(x)+1) + - sqrt(%pi) log(erf(x)-1)
+-- 4 erf(x) - 1 8 8
+
+-- but axiom cannot do this and gives:
+-- 2
+-- x - %G
+-- ++ %e + erf(%G)
+-- (4) | --------------------------------- d%G
+-- ++ 3 2
+-- erf(%G) - erf(%G) - erf(%G) + 1
+-- Type: Union(Expression Integer,...)
+
+@
+\section{airy functions}
+<<airy functions>>=
+)clear all
+-- Airy Functions
+
+-- f:=(x-airyAi(x)*airyAi(1,x))/(x^2-airyAi(x)^2)
+-- Axiom does not have a 2 argument form of the airyAi function
+
+-- integrate(f,x)
+-- should be:
+-- 1 1
+-- - log(x+airyAi(x)) + - log(x-airyAi(x))
+-- 2 2
+
+f:=x^2*airyAi(x)
+-- should be:
+-- 2
+-- (1) x airyAi(x)
+-- Type: Expression Integer
+
+g:=integrate(f,x)
+-- should be:
+-- -airyAi(x) + airyAi(1,x) x
+-- but Axiom cannot integrate this and gives:
+--
+-- x
+-- ++ 2
+-- (2) | %H airyAi(%H)d%H
+-- ++
+-- Type: Union(Expression Integer,...)
+
+@
+\section{bessel functions}
+<<bessel functions>>=
+)clear all
+-- Bessel functions
+
+f:=besselJ(y+1,x)/besselJ(y,x)
+-- should be:
+-- besselJ(y + 1,x)
+-- (1) ----------------
+-- besselJ(y,x)
+-- Type: Expression Integer
+
+g:=integrate(f,x)
+-- should be:
+-- y log(x) - log(besselJ(y,x))
+-- but Axiom cannot integrate it and gives:
+--
+-- x
+-- ++ besselJ(y + 1,%H)
+-- (2) | ----------------- d%H
+-- ++ besselJ(y,%H)
+-- Type: Union(Expression Integer,...)
+
+-- f:=normal(y*besselJ(y,x)/x = besselJ(y+1,x))
+-- Axiom does not have Maple's normal function
+-- should be:
+-- besselJ(y+1,x) x - y besselJ(y,x)
+-- - ---------------------------------
+-- x
+--
+
+@
+\section{whittaker functions}
+<<whittaker functions>>=
+)clear all
+-- Whittaker functions
+
+-- f:=WhittakerW(u+1,n,x)/(WhittakerW(u,n,x)*x)
+-- Axiom does not implement WhittakerW
+-- should be:
+-- Whittaker(u+1,n,x)
+-- ------------------
+-- Whittaker(u,n,x) x
+
+-- integrate(f,x)
+-- should be:
+-- x
+-- - - u log(x) - log(WhattakerW(u,n,x))
+-- 2
+
+@
+\section{lambertW function}
+<<lambertW function>>=
+)clear all
+-- The Lambert W function
+
+-- f:=LambertW(x)
+-- Axiom does not implement LambertW
+
+-- g:=integrate(f,x)
+-- should be:
+-- 2 2 2 2
+-- x + LambertW(x) x - LambertW(x) x
+-- ------------------------------------
+-- x LambertW(x)
+
+--integrate(sin(LambertW(x)),x)
+--should be:
+-- +- -+
+-- | 2 |
+-- | +- -+ |
+-- | 1 | 1 | 2 |
+-- | - LambertW(x) tan | - LambertW(x) | x + |
+-- | 2 | 2 | |
+-- | +- -+ |
+-- | |
+-- | +- -+ |
+-- | | 1 | 2 |
+-- | LambertW(x) tan | - LambertW(x) | x + |
+-- | | 2 | |
+-- | +- -+ |
+-- | |
+-- | +- -+ |
+-- | | 1 | 2 1 2 |
+-- | tan | - LambertW(x) | x - - LambertW(x) x |
+-- | | 2 | 2 |
+-- | +- -+ |
+-- +- -+
+-- ------------------------------------------------------
+-- +- 2 -+
+-- | +- -+ |
+-- | | 1 | |
+-- x LambertW(x) | 1 + tan | - LambertW(x) | |
+-- | | 2 | |
+-- | +- -+ |
+-- +- -+
+
+-- f:=((x^2+2)*LambertW(x^2)^2+x^2*(2*LambertW(x^2)+1))/(x*(1+LambertW(x^2)^3))
+--should be:
+-- 2
+-- 2 2 2 2
+-- (x + 2) LambertW(x ) + x (2 LambertW(x ) + 1)
+-- ------------------------------------------------
+-- 3
+-- 2
+-- x (1 + LambertW(x ))
+
+--integrate(f,x)
+--should be:
+-- 2 4
+--1 4 2 4 2 x 2 2 2 2
+--- x LambertW(x ) + x LambertW(x ) + -- + LambertW(x ) x + x LambertW(x )
+--2 2
+-----------------------------------------------------------------------------
+-- 2
+-- 2 2 2
+-- x LambertW(x ) (1 + LambertW(x ))
+--
+-- +
+-- 2
+-- log(1 + LambertW(x ))
+
+--f:=(2*LambertW(x^2)*cos(LambertW(x^2))*(a*x+LambertW(x^2))+a*x*(1+LambertW(x^2)) + 2*LambertW(x^2))/((1+LambertW(x^2))*(a*x+LambertW(x^2))*x)
+--+- -+
+--| |
+--| 2 2 2 |
+--| 2 LambertW(x ) cos(LambertW(x )) (a x + LambertW(x )) + |
+--| |
+--| 2 2 |
+--| a x (1 + LambertW(x )) + 2 LambertW(x ) |
+--| |
+--+- -+
+-------------------------------------------------------------
+-- 2 2
+-- (1 + LambertW(x ))(a x+LambertW(x )) x
+--
+
+--integrate(f,x)
+--
+-- +- -+
+-- | 1 2 |
+-- 2 tan | - LambertW(x ) |
+-- | 2 |
+-- +- -+ 2
+-- --------------------------- + log(a x + LambertW(x ))
+-- 2
+-- +- -+
+-- | 1 2 |
+-- 1 + tan | - LambertW(x ) |
+-- | 2 |
+-- +- -+
+--
+--
+
+@
+wright omega function}
+<<wright omega function>>=
+)clear all
+-- The Wright omega function
+
+-- omega:=proc(z) LambertW(exp(z)); end;
+-- should be (in Maple notation)
+--
+-- proc(z) LambertW(exp(z)) end proc
+--
+--normal(integrate(omega(x),x))
+--
+-- 1 x x
+-- - LambertW(%e )(LambertW(%e )+2)
+-- 2
+--
+--f:=(1+LambertW(%e^x)*(2+cos(LambertW(%e^x))*(x+LambertW(%e^x))))/((1+LambertW(%e^x))*(x+LambertW(%e^x)))
+--
+--integrate(f,x)
+--
+-- +- -+
+-- | 1 x |
+-- 2 tan | - LambertW(%e ) |
+-- | 2 |
+-- +- -+ x
+-- ---------------------------- + log(x + LambertW(%e ))
+-- 2
+-- +- -+
+-- | 1 x |
+-- 1 + tan | - LambertW(%e ) |
+-- | 2 |
+-- +- -+
+--
+
+@
+\section{License}
+<<license>>=
+--Version 1.1 --- May 10, 2005 (c) M.Bronstein and INRIA 2004-2005
+@
+<<*>>=
+<<license>>
+<<rational functions>>
+<<trigonometric functions>>
+<<log-exp functions>>
+<<liouvillian functions>>
+<<airy functions>>
+<<bessel functions>>
+<<whittaker functions>>
+<<lambertW function>>
+<<wright omega function>>
+@
+\section{\eject
+\begin{thebibliography}{99}
+\bibitem{1} J.H.Davenport (1982):
+On the Parallel Risch Algorithm (I),
+Proceedings of EUROCAM'82, LNCS 144, Springer, 144-157.
+\bibitem{2} J.H.Davenport (1982):
+On the Parallel Risch Algorithm (III): Use of Tangents,
+SIGSAM Bulletin 16, 3-6.
+\bibitem{3} J.H.Davenport, B.M.Trager (1985):
+On the Parallel Risch Algorithm (II),
+ACM Transactions on Mathematical Software 11, 356-362.
+\bibitem{4} J.Fitch (1981):
+User-based integration software,
+Proceedings of SYMSAC'81, ACM Press, 245-248.
+\bibitem{5} K.Geddes, L.Stefanus (1989):
+On the Risch-Norman Integration Method and its Implementation in Maple,
+Proceedings of ISSAC'89, ACM Press, 212-217.
+\bibitem{6} S.H.Harrington (1979):
+A new symbolic integration system in reduce,
+The Computer Journal 22, 127-131.
+\bibitem{7} A.C.Norman, P.M.A.Moore (1977):
+Implementing the new Risch Integration Algorithm,
+Proceedings of the 4th International Colloquium on Advanced Computing
+Methods in Theoretical Physics, 99-110.
+\end{thebibliography}
+\end{document}