123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251 |
- \documentstyle[11pt,reduce,fancyheadings]{article}
- \title{
- A new exp-log limits package for \small{REDUCE}
- }
- \author{Neil Langmead \\
- Konrad-Zuse-Zentrum f\"ur Informationstechnik (ZIB) \\
- Takustrasse 7 \\
- D- 14195 Berlin Dahlem \\
- Berlin
- Germany}
- \date{January 1997}
- \def\foottitle{Limits}
- \pagestyle{fancy}
- \lhead[]{{\footnotesize\leftmark}{}}
- \rhead[]{\thepage}
- \setlength{\headrulewidth}{0.6pt}
- \setlength{\footrulewidth}{0.6pt}
- \addtolength{\oddsidemargin}{-20 mm}
- \addtolength{\textwidth}{25 mm}
- \pagestyle{fancy}
- \setlength{\headrulewidth}{0.6pt}
- \setlength{\footrulewidth}{0.6pt}
- \setlength{\topmargin}{1 mm}
- \setlength{\footskip}{10 mm}
- \setlength{\textheight}{220 mm}
- \cfoot{}
- \rfoot{\small\foottitle}
- \def\exprlist {exp$_{1}$,exp$_{2}$, \ldots ,exp$_{{\tt n}}$}
- \def\lineqlist {lin\_eqn$_{1}$,lin\_eqn$_{2}$, \ldots ,lin\_eqn$_{n}$}
- \begin{document}
- \maketitle{
- \begin{center} \Large A new exp-log limits package for \small{REDUCE}
- \end{center} }
- \pagebreak
- \tableofcontents
- \pagebreak
- \section{The Exp-Log Limits package}
- This package arises from the PhD thesis of Dominik Gruntz, of the ETH Z\"{u}rich. He developed a new algorithm to compute limits of "exp-log" functions. Many of the examples he gave were unable to be computed by the present limits package in \small{REDUCE},\normalsize the simplest example being the following, whose limit is obviously $0$:
- \begin{verbatim}
- load limits;
- limit(x^7/e^x,x,infinity);
- 7
- x
- limit(----,x,infinity)
- x
- e
- \end{verbatim}
- This particular problem arises, because L'Hopital's rule for the computation of indefinite forms (such as $0/0$, or $\frac{\infty}{\infty}$) can only be applied in a CAS a finite number of times, and in \small{REDUCE}~\cite{Red36}, \normalsize this number is 3. Applied 7 times to the above problem would have yielded the correct answer 0.
- The new algorithm solves this particular problem, and enables the computation of many more limit calculations in \small{REDUCE}. \normalsize We first define the domain in which we work, and then give a statement of the main algorithm that is used in this package. \\
- Definition: \\
- Let $\Re[x]$ be the ring of polynomials in $x$ with real coefficients, and let $f$ be an element in this ring. The field which is obtained from $\Re[x]$ by closing it under the operations $f$ $\rightarrow$ $exp(f)$ and $f$ $\rightarrow$ $\log |f|$ is called the $L$- field (or logarithmico-exponential field, or field of exp-log functions for short).
- \newline
- \newline
- Hardy proved that every $L$ function is ultimately continuous, of constant sign, monotonic, and tends to $\pm \infty$ or to a finite real constant as $x$ $\rightarrow +\infty.$ \\
- Here are some examples of exp-log functions, which the package is able to deal with: \\
- $ f(x)=e^{x}*\log(\log(x))$ \\
- $ f(x)=\frac{\log(\log(x+e^{-x}))}{e^{x^{2}}+\log(\log(x))} $ \\
- $ f(x)=\log(x)^{\log(x)} $ \\
- $ f(x)=e^{x*\log(x)} $ \\
- \pagebreak
- \section{The Algorithm}
- A complete statement of the algorithm now follows:
- %\hspace{-1cm}\shadowbox{\parbox{9cm}{
- Let $f$ be a log-exp function in $x$, whose limit we wish to compute as $x\rightarrow x_0.$ The main steps of the algorithm to do this are as follows: \\
- \begin{itemize}
- \item{Determine the set $\Omega$ of the most rapidly varying subexpressions of $f(x)$. Limits may have to be computed recursively at this stage.}
- \item{Choose an expression $\omega$ such that $\omega>0$, $\lim_{x \rightarrow \infty} \omega=0 $ and $\omega$ is in the same comparability class as any element of $\Omega$. Rewrite the other expressions in $\Omega$ as $A(x)\omega^{c}$, where $A(x)$ only contains subexpressions in lower comparability classes than $\Omega$.}
- \item{Let $f(\omega)$ be the function obtained from $f(x)$ by replacing all elements of $\Omega $ by their representation in terms of $\omega$. Consider all expressions independent of $\omega$ as constants and compute the leading term of the power series of f($\omega$) around $\omega=0^{+}$ }
- \item{If the leading exponent $e_0>0$, then the limit is 0, and we stop. If the leading exponent $e_0<0$ then the limit is $\pm \infty$. The sign is defined by the sign of the leading coefficient $c_0$. If the leading exponent $e_0=0$ then the limit is the limit of the leading coeficient $c_0$. If $c_0$ $\not \in C$, where $C=Const(L)$, the set of exp-log constants, we apply the same algorithm recursively on $c_0$.} \\
- \end{itemize}
- %}}
- The algorithm to compute the most rapidly varying subset (the mrv set) of a function f is given below:\\
- \begin{tabbing}
- procedure mrv(f) \= \\ % f an exp log function in $x$ \\
- if (not (depend(f,$x$))) $\rightarrow$ return (\{\}) \\
- \> else if $f=x \rightarrow$ return(\{$x$\}) \\
- \> else if $f=gh$ $\rightarrow$ return(max(mrv(g),mrv(h))) \\
- else if $f=g+h$ $\rightarrow$ return(max(mrv(g),mrv(h))) \\
- else if $f=g^{c}$ and c $\in C \rightarrow$ return(mrv(g)) \\
- else if $f=log(g)$ $\rightarrow$ return(mrv(g)) \\
- else if \= $f=e^{g}$ $\rightarrow$ \\
- \> if $\lim_{x \rightarrow \infty} g=\pm\infty \rightarrow$ \\
- \> return(max(\{$e^{g}$\}, mrv(g))) \\
- \> else $\rightarrow $ return mrv(g) \\
- \bf{end}
- \end{tabbing}
- \vspace{5 mm}
- The function max() computes the maximum of the two sets of expressions. Max() compares two elements of its argument sets and returns the set which is in the higher comparability class or the union of both if they have the same order of variation. \\
- For further details, proofs and explanations of the algorithm, please consult ~\cite{Grn96}.
- \pagebreak
- For example, we have \\
- $mrv(e^{x})=\{e^x\}$ \\
- $mrv(log(log(log(x+x^2+x^3))))=\{x\} $ \\
- $mrv(x)=\{x\} $\\
- $mrv(e^x+e^{-x}+x^2+x \log(x))= \{e^x,e^{-x} \}$ \\
- $mrv(e^{e^{-x}})=\{e^{-x} \} $ \\
- \subsection{Mrv\_limit Examples}
- Consider the following in \small{REDUCE}:
- \begin{verbatim}
- mrv_limit(e^x,x,infinity);
- infinity
- mrv_limit(1/log(x),x,infinity);
- 0
- b:=e^x*(e^(1/x-e^-x)-e^(1/x));
- -1 - x
- x + x - e
- b := e *(e - 1)
- mrv_limit(b,x,infinity);
- -1
- -1
- ex:= - log(log(log(log(x))) + log(x)) *log(x)
- *(log(log(x)) - log(log(log(x)) + log(x)));
- - log(x)*(log(log(x)) - log(log(log(x)) + log(x)))
- ex:= -----------------------------------------------------
- log(log(log(log(x))) + log(x))
- off mcd;
- mrv_limit(ex,x,infinity);
- 1
- (log(x+e^-x)+log(1/x))/(log(x)*e^x);
- - x -1 -1 - x
- e *log(x) *(log(x ) + log(e + x));
- mrv_limit(ws,x,infinity);
- 0
- mrv_limit((log(x)*e^-x)/e^(log(x)+e^(x^2)),x,infinity);
- 0
- \end{verbatim}
- \normalsize
- \section{The tracing facility}
- The package provides a means of tracing the $mrv\_limit$ function at its main steps, and is intended to help the user if he encounters problems. Messages are displayed informing the user which Taylor expansion is being computed, all recursive calls are listed, and the value returned by the $mrv$ function is given. This information is displayed when a switch $tracelimit$ is on. This is off by default, but can be switched on with the command
- \begin{verbatim}
- on tracelimit;
- \end{verbatim}
- For a more complete examination of the workings of the algorithm, the user could also try the command
- \begin{verbatim}
- tr mrv_limit;
- \end{verbatim}
- This is not recommended, as the amount of information returned is often huge and difficult to wade through.
- Here is a simple example in \small{REDUCE}:
- \begin{verbatim}
- Loading image file: /silo/cons/reduce35/Alpha/binary/redu37a.img
- REDUCE Development Version, 4-Nov-96 ...
- 1: load mrvlimit;
- 2: on tracelimit;
- 3: mrv_limit(e^x,x,infinity);
- -1
- performing taylor on: ww
- -1
- series expansion is ww
- -1
- series is ww
- exponent list is {expt,-1}
- leading exponent e0 is {expt,-1}
- x
- mrv_f is {e }
- mrv_f is {x}
- -1
- performing taylor on: ww
- -1
- series expansion is ww
- -1
- series is ww
- exponent list is {expt,-1}
- leading exponent e0 is {expt,-1}
- -1
- performing taylor on: ww
- infinity
- \end{verbatim}
- \vspace{10 mm}
- Note that, due to the recursiveness of the functions $mrv$ and $mrv\_limit$, many calls to each function are made, and information is given on all calls when the $ tracelimit$ switch is on.
- \section{Comments, Bug reports and Suggestions}
- Thsi package was written when the author was a placement student at ZIB Berlin. Please address all comments, bugs and suggestions to Winfried Neun, ZIB, Takustrasse 7, D-14195 Berlin Dahlem, Germany, or e/mail neun@zib.de. \\
- \pagebreak
- \begin{thebibliography}{99999}
- \normalsize
- \bibitem[Grn96]{Grn96} Gruntz, Dominik,
- {\it On Computing Limits in a Symbolik Manipulation System}, \\
- PhD Thesis, ETH Z\"urich
- \bibitem[Red36]{Red36} Hearn, Anthony C. and Fitch, John F.
- {\it REDUCE User's Manual 3.6}, \\ RAND Corporation, 1995
- \end{thebibliography}
- \end{document}
|