12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214 |
- % This is a LaTeX file
- \documentstyle[12pt]{article}
- %Sets size of page and margins
- \oddsidemargin 10mm \evensidemargin 10mm
- \topmargin 0pt \headheight 0pt \headsep 0pt
- \footheight 14pt \footskip 40pt
- \textheight 23cm \textwidth 15cm
- %\textheight 15cm \textwidth 10cm
- %spaces lines at one and a half spacing
- %\def\baselinestretch{1.5}
- %\parskip = \baselineskip
- %Defines capital R for the reals, ...
- %\font\Edth=msym10
- %\def\Integer{\hbox{\Edth Z}}
- %\def\Rational{\hbox{\Edth Q}}
- %\def\Real{\hbox{\Edth R}}
- %\def\Complex{\hbox{\Edth C}}
- \title{The Computer Algebra Package {\tt CRACK} for Investigating PDEs}
- \author{Thomas Wolf \\
- School of Mathematical Sciences \\
- Queen Mary and Westfield College \\
- University of London \\
- London E1 4NS \\
- T.Wolf@maths.qmw.ac.uk
- \\ \\
- Andreas Brand \\ Institut f\"{u}r
- Informatik \\ Friedrich Schiller Universit\"{a}t Jena \\ 07740 Jena
- \\ Germany \\ maa@hpux.rz.uni-jena.de
- }
- \begin{document}
- \maketitle
- \tableofcontents
- \section{The purpose of {\tt CRACK}}
- The package {\tt CRACK} attempts the solution of an overdetermined
- system of ordinary or partial differential
- equations (ODEs/PDEs) with at most polynomial nonlinearities.
- Under `normal circumstances' the number of DEs which describe physical
- processes matches the number of unknown functions which are involved.
- Moreover none of those equations can be solved or integrated and
- integrability conditions yield only identities. Though the package
- {\tt CRACK} applied to solve such `difficult' systems
- directly will not be of much help usually, it is possible to
- investigate them indirectly by
- studying analytic properties which would be useful for their
- solution. Such `simpler' overdetermined PDEs also result from
- investigating properties of ODEs and problems in differential geometry.
- The property of overdetermination (by which we only mean the fact
- that there are more equations than unknown functions) is not a
- prerequisite for applying the package but it simplifies the problem
- and it is usually necessary for success in solving or simplifying the
- system.
- The following examples are quite different in nature. They demonstrate
- typical applications of {\tt CRACK} and give an impression of its efficiency.
- In principle it makes no difference to investigate more general
- symmetries, more general coordinate transformations and so on, except that the
- computational complexity may grow very rapidly for more general
- ans\"atze, especially for nonlinear problems, such that a solution
- becomes practically impossible.
- The following overview makes suggestions for possible
- applications; the mathematics of the applications and of the
- algorithms which are applied in {\tt CRACK} are described only
- superficially. These applications are only examples. The user will usually
- have to write own procedures to formulate his problem in form of
- an overdetermined system of PDEs which is then solved or simplified with
- {\tt CRACK}.
- \begin{enumerate}
- \item
- DEs as well as differential geometric objects, like a metric which
- describes infinitesimal distances in a manifold, can have
- infinitesimal symmetries, i.e.\ there exist transformations of dependent
- and independent variables, which leave the DE or metric
- form-invariant. According to a theory of Sophus Lie such
- symmetries of an ODE can be used to integrate the
- ODE and symmetries of a PDE can be used to decrease the number
- of independent variables.
- The determining conditions for the generators of this
- symmetry are given by a system of linear PDEs.
- \item
- Other ans\"atze, e.g.\ for finding
- \begin{itemize}
- \item integrating factors of DEs, or
- \item a variational principle, i.e.\ a Lagrangian which is equivalent
- to a given ODE, or
- \item a factorization ansatz which transforms a given $n$-th order
- ODE into two ODEs of order $k$ and $n-k,$
- \end{itemize}
- lead to PDE-systems for the remaining free functions with good
- prospects for solution.
- \item
- The ability of {\tt CRACK} to decouple systems of DEs with at most polynomial
- nonlinearity can be used to perform very general transformations of
- undetermined functions. If, for example, an equation
- \begin{equation}
- 0 = D_1(x, f) \label{df}
- \end{equation}
- for a function $f(x)$ is given with $D_1$ as a differential
- expression in $x$ and $f$, and a further function $g$ of $x$
- is related to $f$ through a differential relation
- \begin{equation}
- 0 = D_2(x, g, f), \label{dg}
- \end{equation}
- then, to obtain an equation equivalent to (\ref{df}) for the function $g,$
- the system (\ref{df},\ref{dg}) could be decoupled w.r.t.\ $f$ to
- obtain an equation
- \[ 0 = D_3(x, g) \]
- which contains only $g$.
- Such generalized transformations can in principle also be done for more
- than one equation of the form (\ref{df}), more old and new functions and
- variables, and more relations of the form (\ref{dg}).
- \item
- If a PDE or `well defined' system is too complicated to be solved in
- general, and one has some idea of the dependence of one of the
- functions which are to be calculated (e.g. $f$) on at least one
- variable (e.g. $x$), then one could try an ansatz for $f$ which
- involves $x$ (and possibly other variables)
- only explicitly and furthermore only unknown functions
- that are independent of $x$. Also other
- ans\"atze are possible where no variable occurs explicitly but all new
- functions involve only a subset of all variables. This approach
- includes separations such as the well known product ansatz $f(r,
- \theta, \varphi) = R(r)Y(\theta, \varphi)$ to solve the Laplace
- equation $\triangle f = 0$ in spherical coordinates. After such a
- substitution the resulting system is simplified and can be solved
- usually, because the
- number of functions of all independent variables is decreased and is
- now less than the number of equations.
- \item
- A difficult DE-system is simplified usually if further conditions
- in the form of differential equations are added,
- because then the resulting system is not necessarily in involution
- and integrability conditions can be used to lower the order or to
- solve it.
- \end{enumerate}
- To explain the input to {\tt CRACK}, which corresponds to examples
- given in the final two sections, the way to call {\tt CRACK} is described next.
- \section{How to apply {\tt CRACK}}
- \subsection{The call}
- {\tt CRACK} is written in the symbolic mode of REDUCE 3.4 and is loaded by
- {\tt load CRACK;}. Then {\tt CRACK} is called by
- \begin{tabbing}
- {\tt CRACK}(\=\{{\it equ}$_1$, {\it equ}$_2$, \ldots , {\it equ}$_m$\}, \\
- \>\{{\it ineq}$_1$, {\it ineq}$_2$, \ldots , {\it ineq}$_n$\}, \\
- \>\{{\it fun}$_1$, {\it fun}$_2$, \ldots , {\it fun}$_p$\}, \\
- \>\{{\it var}$_1$, {\it var}$_2$, \ldots , {\it var}$_q$\});
- \end{tabbing}
- $m,n,p,q$ are arbitrary.
- \begin{itemize}
- \item
- The {\it equ}$_i$ are identically vanishing partial differential expressions,
- i.e.\
- they represent equations $0 = {\it equ}_i$, which are to be solved for the
- functions ${\it fun}_j$ as far as possible, thereby drawing only necessary
- conclusions and not restricting the general solution.
- \item
- The {\it ineq}$_i$ are expressions which must not vanish identically for
- any solution to be determined, i.e. only such solutions are computed for which
- none of the {\it ineq}$_i$ vanishes identically in all independent variables.
- \item
- The dependence of the (scalar) functions ${\it fun}_j$ on possibly a number of
- variables is assumed to have been defined with DEPEND rather than
- declaring these functions
- as operators. Their arguments may themselves only be independent variables
- and not expressions.
- \item
- The functions ${\it fun}_j$ and their derivatives may only occur polynomially.
- Other unknown functions in ${\it equ}_i$ may be represented as operators.
- \item
- The ${\it var}_k$ are further independent variables, which are not
- already arguments
- of any of the ${\it fun}_j$. If there are none then the third argument is
- the empty list \{\}.
- \item
- The dependence of the ${\it equ}_i$ on the independent variables and on
- constants and functions other than ${\it fun}_j$ is arbitrary.
- \end{itemize}
- \subsection{The result}
- The result is a list of solutions
- \[ \{{\it sol}_1, \ldots \} \]
- where each solution is a list of 3 lists:
- \begin{tabbing}
- \{\=\{${\it con}_1, \; {\it con}_2, \ldots , \; {\it con}_q$\}, \\
- \>\{${\it fun}_a={\it ex}_a, \;\;
- {\it fun}_b={\it ex}_b, \ldots , \;\; {\it fun}_p={\it ex}_p$\},\= \\
- \>\{${\it fun}_c, \;\; {\it fun}_d, \ldots , \;\; {\it fun}_r$\} \>\}
- \end{tabbing}
- with integer $a, b, c, d, p, q, r.$
- If {\tt CRACK} finds a contradiction as e.g. $0=1$ then there exists no
- solution and it returns the empty list \{\}.
- The empty list is also returned if no solution exists
- which does not violate the inequalities
- {\it ineq}$_i \neq 0.$
- For example, in the case of a linear system as input, there is
- at most one solution ${\it sol}_1$.
- The expressions ${\it con}_i$ (if there are any), are the
- remaining necessary and sufficient conditions for the functions
- ${\it fun}_c,\ldots,{\it fun}_r$ in the third list. Those
- functions can be original functions from the equations to be
- solved (of the second argument of the call of {\tt CRACK}) or new
- functions or constants which arose from integrations.
- The dependence of new functions on variables is declared with {\tt DEPEND}
- and to visualize this dependence the algebraic mode function
- ${\tt FARGS({\it fun}_i)}$ can be used.
- If there are no ${\it con}_i$ then all equations are solved and the
- functions in the third list are unconstrained.
- The second list contains
- equations ${\it fun}_i={\it ex}_i$ where each ${\it fun}_i$ is an
- original function and ${\it ex}_i$ is the computed expression
- for ${\it fun}_i$.
- \subsection{Flags}
- Possible flags which can be changed in symbolic mode
- after {\tt CRACK} has been loaded are (initial values in brackets):
- \begin{description}
- \item[{\tt cont\_ :}] if t then if the maximal number of terms of an expression
- is greater then {\tt fcteval\_} or {\tt odesolve\_} then
- the user is asked
- whether or not the expression is to be substituted or integrated
- with {\tt ODESOLVE} respectively. (default: {\tt nil})
- \item[{\tt decouple\_ :}] maximal number of decoupling attempts for a
- function (default: 2)
- \item[{\tt factorize\_ :}] If an equation can be factored with more than one
- factor
- containing unknown functions then independent investigations
- start. In each investigation exactly one of these factors is set
- to zero. If
- many equations can be factorized then this may lead to a large
- number of individual investigations. {\tt factorize\_} is the
- maximal number
- of factorizations. If the starting system is linear then
- an attempt at factorization would be unsuccessful, i.e.
- {\tt factorize\_:=0} prevents this unnecessary
- attempt. (default: 4)
- \item[{\tt fcteval\_ :}] if a function has been computed from an equation and
- is to
- be substituted in other equations then {\tt fcteval\_} is the
- upper limit for the number of terms of the equated expression
- for which substitution is done. (default: 100)
- \item[{\tt fname\_ :}] the name to be used for new constants and functions
- which result from integrations (default: {\tt c})
- \item[{\tt genint\_ :}] generalized integration disabled/enabled
- (default: {\tt nil})
- \item[{\tt logoprint\_ :}] If t then printing of a standard message whenever
- {\tt CRACK} is called (default: {\tt t})
- \item[{\tt independence\_ :}] If t then the user will be asked during
- separation whether expressions are considered to
- be linear independent or not. This should be set true if
- in a previous run the assumption of linear independence made by
- {\tt CRACK} automatically was false. (default: {\tt nil})
- \item[{\tt odesolve\_ :}] the maximal number of terms of expressions which
- are to be
- investigated with {\tt ODESOLVE}. (default: $100$)
- \item[{\tt print\_ :}] If nil then there is no output during calculation
- otherwise {\tt print\_} is the maximal number of terms
- of equations which are to be output. (default: 8)
- \item[{\tt sp\_cases :}] After a factorization factors are dropped
- if they do not contain functions which are to be solved. An
- exceptional case is if a factor contains other (parametric)
- functions or constants. Then a corresponding message is given
- at the first appearance of each factor. These factors are
- stored in a list {\tt special\_cases}. If {\tt sp\_cases}
- is not {\tt nil} then such factors are not dropped.
- (default: {\tt nil})
- \item[{\tt time\_ :}] If t then printing the time necessary for the last
- {\tt CRACK} run (default: {\tt t})
- \item[{\tt tr\_gensep :}] to trace of the generalized separation
- (default: nil)
- \end{description}
- \subsection{Help}
- Parts of this text are provided after typing
- {\tt crackhp();}
- The authors are grateful for critical comments
- on the interface, efficiency and computational errors.
- \section{Contents of the {\tt CRACK} package}
- The package {\tt CRACK} contains modules for decoupling PDEs, integrating
- exact PDEs, separating PDEs, solving DEs containing functions of only
- a subset of all variables and solving standard ODEs (of Bernoulli or
- Euler type, linear, homogeneous and separable ODEs). These facilities
- will be described briefly together with examples.
- \subsection{Decoupling}
- The decoupling module differentiates equations and combines them algebraically
- to obtain if possible decoupled and simplified equations of lower order.
- How this could work is demonstrated in the following example.
- The integrability condition for the system
- \[ \begin{array}{cccl}
- f = f(x,y), \; \; & f,_{x} & = & 1 \\
- & f,_{y} & = & (f-x-1/y)x - 1/y^2
- \end{array} \]
- provides an algebraic condition for the function $f$
- which turns out not only to be necessary but also sufficient to solve both
- equations:
- \begin{eqnarray*}
- 0 = f,_{xy} - f,_{yx} & = & - xf,_x - f + 2x + 1/y \\
- & = & - f + x + 1/y \; \; \; \; \; \;
- \mbox{(with $f,_x$ from above)}
- \end{eqnarray*}
- \[ \rightarrow f = x + 1/y. \]
- A general algorithm to bring a system of PDEs into a standard form
- where all integrability conditions are satisfied by applying
- a finite number of additions, multiplications and differentiations
- is based on the general theory of involutive systems \cite{Riq,Th,Ja}.
- Essential to this theory is a total ordering of partial derivatives
- which allows assignment to each PDE of a {\em Leading Derivative}
- (LD) according to a chosen ordering of functions
- and derivatives. Examples for possible orderings are
- \begin{itemize}
- \item lex.\ order of functions $>$ lex.\ order of variables
- \item lex.\ order of functions $>$ total differential order $>$ lex.\
- order of variables
- \item total order $>$ lex.\ order of functions $>$ lex.\ order of variables
- \end{itemize}
- or mixtures of them by giving weights to individual functions and variables.
- Above, the `$>$' indicate ``before'' in priority of criteria. The principle
- is then to
- \begin{itemize}
- \item take two equations at a time and differentiate them as often as
- necessary to get equal LDs,
- \item regard these two equations as algebraic equations in
- the common LD and calculate the remainder w.r.t.\ the LD, i.e.\ to
- generate an equation without the LD by the Euclidean algorithm, and
- \item add this equation to the system.
- \end{itemize}
- Usually pairs of equations are taken first, such that only one must be
- differentiated. If in such a generation step one of both equations is not
- differentiated then it is called a
- simplification step and this equation will be replaced by the new equation.
- The algorithm ends if each combination of two equations yields only equations
- which simplify to an identity modulo the other equations.
- A more detailed description is given e.g. in \cite{Alex,Reid1}.
- In {\tt CRACK}, a reduced version of this algorithm has so far been
- implemented, which applies the first of the above orderings with
- lexicographical ordering of functions having the highest
- priority. This is done to get decoupled equations, i.e.\ a system with
- a ``triangular dependence'' of the equations on the functions,
- which is usually easier to solve
- successively (starting with the equation containing the fewest
- functions) than are coupled DEs. To save memory not all equations
- are stored but new equations replace in general older ones.
- Details of the algorithm used
- in {\tt CRACK} are given in \cite{Wo}.
- Programs implementing the standard algorithm are described e.g. in
- \cite{FS,Alex,Fush} and \cite{Reid1}.
- The possible variations of orderings or even the switch between
- them open possibilities for future optimization.
- {\em Example:}
- Applying the decoupling module alone without factorization and integration
- to the two equations
- \[ \begin{array}{rclcl}
- D_1 & := & f + f,_{yy}f,_x & = & 0 \\ \\
- D_2 & := & f,_y + f,_x^2 & = & 0
- \end{array} \]
- for $f(x,y)$, using the lexicographic ordering of variables $y>x>1,$
- the steps would be
- \begin{tabbing}
- $D_1:=$\=$D_1-D_{2y}f_x=f-2f_x^2f_{yx}$ \\
- \> $\rightarrow$ a second 1st order eqn. in $y$\\ \\
- $D_1:=$\>$D_1+2f_x^2D_{2x}=f+4f_x^3f_{xx} \rightarrow$ first ODE \\
- \> to get a second ODE we need an extra equation $D_3:$ \\ \\
- $D_3:=$\>$4f_x^3D_{2xx}-D_{1y}=8f_{xx}^2f_x^3+8f_{xxx}f_x^4-12f_x^2f_{xx}f_{xy}
- -f_y$ \\ \\
- $D_3:=$\>$D_3+12f_x^2f_{xx}D_{2x}=32f_{xx}^2f_x^3+8f_{xxx}f_x^4-f_y$
- \\ \\
- $D_2:=$\>$D_2+D_3=32f_{xx}^2f_x^3+8f_{xxx}f_x^4+f_x^2 \rightarrow$
- second ODE \\ \\
- $D_2:=$\>$2f_xD_{1x}-D_2=-8f_{xx}^2f_x^3+f_x^2$ \\ \\
- $D_2:=$\>$D_2+2f_{xx}D_1=2ff_{xx}+f_x^2$ \\ \\
- $D_2:=$\>$D_1f-2f_x^3D_2=f^2-2f_x^5$ \\ \\
- $D_1:=$\>$2D_{2x}+5f_xD_1=9ff_x$ \\ \\
- $D_2:=$\>$2f_x^4D_1+9fD_2=9f^3 \rightarrow f=0$ is necessary and \\
- \> as a test shows also sufficient, \\ \\
- $D_1:=$\>$D_{2x}-3fD_2=0 \rightarrow$ end
- \end{tabbing}
- Here $D_1:=\ldots$ means that the old expression for $D_1$ is replaced
- by the result of the calculation of the right side. As the indices
- show the calculation can be done by storing only 3 equations at a time,
- which is the purpose of the chosen total ordering of derivatives. If
- we have $n$ independent variables and $k$ equations at the beginning,
- then the calculation can be done by storing not more than $k+n-1$
- equations at a time (plus the original $k$ equations to test results for
- sufficiency at the end).
- In {\tt CRACK} all intermediate equations generated are checked to see
- whether they can be integrated at least once directly by an integration
- module.
- \subsection{Integrating exact PDEs}
- The technical term `exact' is adapted for PDEs from exterior calculus and
- is a small abuse of language but it is useful to characterize the kind of PDEs
- under consideration.
- The purpose of the integration module in {\tt CRACK} is to decide
- whether a given differential
- expression $D$ which involves unknown functions $f^i(x^j),\;\; 1\leq i\leq m$
- of independent variables $x^j, 1\leq j\leq n$
- is a total derivative of another expression $I$
- w.r.t. any variable $x^k, 1\leq k\leq n$
- \[ D(x^i,\; f^j,\; f^j,_p,\; f^j,_{pq}, \ldots)
- = \frac{d I(x^i,\; f^j,\; f^j,_p,\; f^j,_{pq}, \ldots)}{d x^k} \]
- and to invert the total derivative i.e. to find $I.$ The index $k$ is
- reserved in the following for the integration variable $x^k.$ Because
- the appropriate constant or function of integration which depends on
- all variables except $x^k$ is added to $I,$ a replacement of $0 = D$
- by $0 = I$ in a system of equations is no loss of generality.
- Of course there
- always exists a function $I$ with a total derivative equal to $D$ but
- the question is whether for \underline{arbitrary} $f^i$ the integral
- $I$ is functionally dependent only on the $f^i$ and their derivatives,
- and not on integrals of $f^i.$ \\
- \underline{Preconditions:} \\
- $D$ is a polynomial in the $f^i$ and their derivatives. The number of
- functions and variables is free.
- For deciding the existence of $I$ only, the explicit occurrence of the
- variables $x^i$ is arbitrary. In order to actually
- calculate $I$ explicitly, $D$ must have the property that all terms in $D$
- must either contain an unknown function of $x^k$ or
- must be formally integrable w.r.t. $x^k.$
- That means if $I$ exists then
- only a special explicit occurrence of $x^k$ can prevent the
- calculation of $I$
- and furthermore only in those terms which do not contain
- any unknown function of $x^k.$
- If such terms occur in $D$ and $I$ exists then $I$ can still be expressed
- as a polynomial in the $f^i, f^i,_j, \ldots$ and terms containing
- indefinite integrals with integrands explicit in $x^k.$ \\
- \underline{Algorithm:} \\
- Successive partial integration of the term with the highest
- $x^k$-derivative of any $f^i.$ By that the
- differential order w.r.t. $x^k$ is reduced
- successively. This procedure is always applicable because steps involve only
- differentiations and the polynomial
- integration $(\int h^n\frac{\partial h}{\partial x}dx =
- h^{n+1}/(n+1))$ where $h$ is a partial derivative of some function
- $f^i.$ For a more detailed description see \cite{WoInt}.\\
- \underline{Stop:} \\
- Iteration stops if no term with any $x^k$-derivative of any $f^i$ is left.
- If in the remaining un-integrated terms any $f^i(x^k)$ itself occurs,
- then $I$ is not expressible with $f^i$ and its derivatives only. In
- case no $f^i(x^k)$ occurs then any remaining terms can contain $x^k$ only
- explicitly. Whether they can be integrated depends on their formal
- integrability. For their integration the REDUCE integrator is applied. \\
- \underline{Example :} \\
- We apply the above algorithm to
- \begin{equation}
- D := 2f,_yg' + 2f,_{xy}g + gg'^3 + xg'^4 + 3xgg'^2g'' = 0
- \label{D}
- \end{equation}
- with $f = f(x,y), \, g = g(x), \, '\equiv d/dx.$
- Starting with terms containing $g$
- and at first with the highest derivative $g,_{xx},$ the steps are
- \[
- \begin{array}{rcccl}
- \int 3xgg,_x^2g,_{xx} dx
- & = & \int d(xgg,_x^3)
- & - & \int \left( \partial_x(xg) g,_x^3\right) dx \\ \\
- & = & xgg,_x^3 & - & \int g,_x^3(g + xg,_x) dx,
- \end{array} \]
- \[ I := I + xgg,_x^3 \]
- \[ D := D - g,_x^3(g + xg,_x) \]
- The new terms $- g,_x^3(g + xg,_x)$ are of lower order than $g,_{xx}$
- and so in the expression $D$ the maximal order of $x$-derivatives
- of $g$ is lowered. The conditions that $D$ is exact are the following.
- \begin{itemize}
- \item The leading derivative must occur linearly before each partial
- integration step.
- \item After the partial integration of the terms with first order
- $x$-derivatives of $f$ the remaining $D$ must not contain $f$
- or other derivatives of $f$, because such terms cannot
- be integrated w.r.t.\ $x$ without specifying $f$.
- \end{itemize}
- The result of $x$- and $y$-integration in the above example is
- (remember $g=g(x)$)
- \begin{equation}
- 0 = 2fg + xygg,_x^3 + c_1(x) + c_2(y) \; \; (=I). \nonumber
- \end{equation}
- {\tt CRACK} can now eliminate $f$ and substitute
- for it in all other equations.
- \underline{Generalization:} \\
- If after applying the above basic algorithm, terms are left which contain
- functions of $x^k$ but each of these functions depends only on a subset of
- all $x^i, 1\leq i\leq n,$ then a generalized version of the above algorithm
- can still provide a formal expression for the integral $I$
- (see \cite{WoInt}). The price consists of
- additional differential conditions, but they are equations in less variables
- than occur in the integrated equation. Integrating for example
- \begin{equation}
- \tilde{D} = D + g^2(y^2 + x\sin y + x^2e^y) \label{Dnew}
- \end{equation}
- by introducing as few
- new functions and additional conditions as possible gives as the integral
- $\tilde{I}$
- \begin{eqnarray*}
- \tilde{I} & = & 2fg + xygg,_{x}^{3} + c_1(x) + c_2(y) \\
- & & + \frac{1}{3}y^3c_3'' - \cos y(xc_3'' - c_3)
- + e^y(x^2c_3'' - 2xc_3' + 2c_3)
- \end{eqnarray*}
- with $c_3 = c_3(x), \, '\equiv d/dx$ and the single additional
- condition $g^2 = c_3'''.$
- The integration of the new terms of (\ref{Dnew}) is
- achieved by partial integration again. For example
- \begin{eqnarray*}
- \int g^2x^2 dx & = & x^2\int g^2 dx - \int (2x\!\int g^2 dx) dx \\
- & = & x^2\int g^2 dx - 2x\int\!\!\int g^2 dx
- + 2 \int\!\!\int\!\!\int g^2 dx \\
- & = & x^2c_3'' - 2xc_3' + 2c_3
- \end{eqnarray*}
- \underline{Characterization:} \\
- This algorithm is a decision algorithm which does not involve any
- heuristic. It is fast because time and memory requirements grow only
- linearly with the number of terms in $D$ and with the order of
- the highest derivative.
- After integration the new equation is still a polynomial
- in $f^i$ and in the new constant or function of integration,.
- Therefore the algorithms for bringing the system into standard form can still
- be applied to the PDE-system
- after the equation $D = 0$ is replaced by $I = 0.$
- The complexity of algorithms for bringing a PDE-system into a standard
- form depends nonlinearly on the order of these equations because of
- the nonlinear increase of the number of different leading derivatives
- and by that the number of equations generated intermediately by such
- an algorithm. It therefore in general pays off to integrate equations (with
- linear expenses) during such a standard form algorithm. The increase
- in the number of unknown constants/functions through integration does
- not play a role for standard form algorithms because these functions
- have less variables and do not increase the number of possible leading
- derivatives and therefore not the number of equations to be maintained
- during execution of the standard form algorithm.
- If an $f^i,$ which depends on all variables, can be eliminated after an
- integration, then depending on its length
- it is in general helpful to substitute $f^i$ in other equations and
- to reduce the number of equations and functions by one. This is especially
- profitable if the replaced expression is short and
- contains only functions of less variables than $f^i.$
- \underline{Test:} \\
- The corresponding test input is
- \begin{verbatim}
- depend f,x,y;
- depend g,x;
- crack({2*df(f,y)*df(g,x)+2*df(f,x,y)*g+g*df(g,x)**3
- +x*df(g,x)**4+3*x*g*df(g,x)**2*df(g,x,2)
- +g**2*(y**2+x*sin y+x**2*e**y)},
- {f,g},{});
- \end{verbatim}
- The meaning of the REDUCE command {\tt depend} is to declare that $f$
- depends in an unknown way on $x$ and $y$. For more details on the
- algorithm see \cite{WoInt}, for an introduction to REDUCE see \cite{WM}.
- \subsection{Direct separation of PDEs}
- As a result of repeated integrations the functions in the
- remaining equations have less and less variables. It therefore may happen
- that after a substitution an equation results where at least one variable
- occurs only explicitly and not as an argument of an unknown function.
- Consequently all coefficients of linearly independent expressions in this
- variable can be set to zero individually. \\
- {\em Example:} \\
- $f = f(x,y), \;\; g = g(x), \;\; x,y,z$ are independent variables.
- The equation is
- \begin{equation}
- 0 = f,_y + z(f^2+g,_x) + z^2(g,_x+yg^2) \label{sep}
- \end{equation}
- $x$-separation? $\rightarrow$ no \\
- $y$-separation? $\rightarrow$ no \\
- $z$-separation? $\rightarrow$ yes: $0 \,=\, f,_y \,=\, f^2+g,_x \,=\,
- g,_x+yg^2$ \\
- $y$-separation? $\rightarrow$ yes: $0 = g,_x = g^2\;\;$
- (from the third equation from the $z$-separation)
- If $z^2$ had been replaced in (\ref{sep}) by a third
- function $h(z)$ then direct separation would not have been possible.
- The situation changes if $h$ is a parametric function which is
- assumed to be independently given and which should not be
- calculated, i.e.\ $f$ and $g$ should be calculated for any
- arbitrary given $h(z)$. Then the same separation could have been
- done with an extra treatment of the special case $h,_{zz} = 0,$
- i.e.\ $h$ linear in $z$. This different treatment of unknown functions
- makes it necessary to input explicitly the functions to be
- calculated as the second argument to {\tt CRACK}. The input
- in this case would be
- \begin{verbatim}
- depend f,x,y;
- depend g,x;
- depend h,z;
- crack({df(f,y)+z*f**2+(z+h)*df(g,x)+h*y*g**2},{f,g},{z});
- \end{verbatim}
- The third parameter for {\tt CRACK} is necessary to make clear that
- in addition to the variables of $f$ and $g$, $z$ is also an independent
- variable.
- If the flag {\tt independence\_} is not {\tt nil} then {\tt CRACK} will
- stop if linear independence of the explicit expressions of the
- separation variable (in the example $1,z,z^2$) is not clear and ask
- interactively whether separation should be done or not.
- \subsection{Indirect separation of PDEs}
- For the above direct separation a precondition is that at least one
- variable occurs only explicitly or as an argument of parametric
- functions. The situation where each variable is an argument of at least
- one function but no function contains all independent variables of an
- equation needs a more elaborate treatment.
- The steps are these
- \begin{itemize}
- \item A variable $x_a$ is chosen which occurs in as few functions as possible.
- This variable will be separated directly later which
- requires that all unknown functions $f_i$ containing $x_a$ are to be
- eliminated. Therefore, as long as $F:=\{f_i\}$ is not empty do the following:
- \begin{itemize}
- \item Choose the function $f_i(y_p)$ in $F$ with the smallest number of
- variables $y_p$ and with $z_{ij}$ as those variables on which $f_i$ does
- not depend.
- \item Identify all different products $P_{ik}$ of powers of
- $f_i$-derivatives and of $f_i$ in the equation.
- Determine the $z_{ij}$-dependent factors $C_{ik}$ of the coefficients
- of $P_{ik}$.
- \item Choose a $z_{ij}$ and for each $C_{il}$ ($i$ fixed, $l=1,\ldots)$:
- \begin{itemize}
- \item divide by $C_{il}$ the equation and all the $C_{im}$ with $m>l,$
- \item differentiate the equation and the $C_{im}$ w.r.t.\ $z_{ij}$
- \end{itemize}
- \end{itemize}
- \item The resulting equation no longer contains any unknown function of $x_a$
- and can be separated w.r.t.\ $x_a$ directly. The
- equations arising can be integrated, inverting the sequence of differentiation
- and division, by
- \begin{itemize}
- \item multiplying them and the $C_{im}$ with $m<l$ by the elements
- of the $C_{ik}$-lists in exactly the inverse order
- \item integrating these exact PDEs and $C_{im}$ w.r.t.\ $z_{ij}$.
- \end{itemize}
- \item The equations originating that way are used to simplify the original
- DE\@. For example direct separability w.r.t.\ $y_p$ could be tested, because
- those products which contain functions $f_i(y_p)$ and their derivatives
- have been evaluated up to constants so that $y_p$ can occur only explicitly.
- \item The whole procedure is repeated for another variable $x_b$ if the
- original DE still has the property that it contains only functions of
- a subset of all variables in the equation.
- \end{itemize}
- The additional bookkeeping of coefficients $C_{ik}$ and their updating by
- division, differentiation, integration and multiplication is done to use
- them as integrating factors for the backward integration.
- The following example makes this clearer. The equation is
- \begin{equation}
- 0 = f(x) g(y) - \frac{1}{2}xf'(x) - g'(y) - (1+x^2)y. \label{isep}
- \end{equation}
- The steps are (equal levels of indentation correspond to the general
- description of the algorithm)
- \begin{itemize}
- \item $x_1:=x, \, F=\{f\}$
- \begin{itemize}
- \item Identify $f_1:=f, \; \; \; \; \; y_1:=x, \; \; \; \; \; z_{11}:=y$
- \item and $P_1=\{f',f\}, \; \; \; \; \; C_1=\{1,g\}$
- \begin{itemize}
- \item Divide $C_{12}$ and
- (\ref{isep}) by $C_{11}=1$ and differentiate w.r.t. $z_{11}=y:$
- \begin{eqnarray}
- 0 & = & fg' - g'' - (1+x^2) \label{isep2} \\
- C_{12} & = & g' \nonumber
- \end{eqnarray}
- \item Divide (\ref{isep2}) by $C_{12}=g'$ and differentiate w.r.t. $z_{11}=y:$
- \[ 0 = - (g''/g')' - (1+x^2)(1/g')' \]
- \end{itemize}
- \end{itemize}
- \item Direct separation w.r.t.\ $x$ and integration:
- \[\begin{array}{rclclcl}
- x^2: 0 & = & (1/g')' & \Rightarrow & c_1g' = 1 & \Rightarrow &
- g = y/c_1 + c_2 \\
- x^0: 0 & = & (g''/g')' & \Rightarrow & c_3g' = g'' & \Rightarrow &
- c_3 = 0
- \end{array} \]
- \item Substitution of $g$ in the original DE
- \[0 = (y/c_1+c_2)f - \frac{1}{2}xf' - 1/c_1 - (1+x^2)y \]
- and further solution by direct separation w.r.t.\ $y$
- \[\begin{array}{rclcl}
- y^1: 0 & = & f/c_1 - 1 - x^2 & \Rightarrow & f' = 2c_1x \\
- y^0: 0 & = & c_2f - \frac{1}{2}xf' - 1/c_1 & \Rightarrow & 0 =
- c_2c_1(1+x^2) - c_1x^2 - 1/c_1
- \end{array}\]
- and direct separation w.r.t.\ $x$:
- \begin{eqnarray*}
- x^0: 0 & = & c_2c_1 - c_1 \\
- x^2: 0 & = & c_2c_1 - 1/c_1 \\
- & \Rightarrow & 0 = c_1 - 1/c_1 \\
- & \Rightarrow & c_1 = \pm 1 \Rightarrow c_2 = 1.
- \end{eqnarray*}
- \end{itemize}
- We get the two solutions $f = 1 + x^2, g = 1 + y$ and
- $f = - 1 - x^2, g = 1 - y.$ The corresponding input to {\tt CRACK} would be
- \begin{verbatim}
- depend f,x;
- depend g,y;
- crack({f*g-x*df(f,x)/2-df(g,x)-(1+x**2)*y},{f,g},{});
- \end{verbatim}
- \subsection{Solving standard ODEs}
- For solving standard ODEs the package {\tt ODESOLVE} by MacCallum
- \cite{Mal} is applied. This package is distributed with REDUCE 3.4
- and can be used independently of {\tt CRACK}. The syntax of
- {\tt ODESOLVE} is quite similar to that of {\tt CRACK} \\
- \verb+depend+ {\it function}, {\it variable}; \\
- \verb+odesolve(+ODE, {\it function}, {\it variable}); \\
- In the present form (spring 93) it solves standard first order ODEs
- (Bernoulli and Euler type, with separable variables, $\ldots$) and linear
- higher order ODEs with constant coefficients. Its applicability is
- increased by a subroutine which recognizes such PDEs in which there is only
- one unknown function of all variables and all occurring derivatives
- are only derivatives w.r.t. one variable of only one partial derivative.
- For example the PDE for $f(x,y)$
- \[ 0 = f,_{xxy} + f,_{xxyy} \]
- can be viewed as a first order ODE in $y$ for $f,_{xxy}.$
- In preparation is a subpackage
- written by Y.K.\ Man for solving first order ODEs with the Prelle-Singer
- algorithm.
- \section{Examples}
- \subsection{Investigating symmetries of ODEs/PDEs and systems of them}
- According to a theory of Sophus Lie the knowledge of an infinitesimal symmetry
- of a DE(-system), i.e. of generators $\xi, \eta$ such that the
- infinitesimal transformation
- \begin{eqnarray*}
- \tilde{x} & = & x + \epsilon\xi \\
- \tilde{y} & = & y + \epsilon\eta
- \end{eqnarray*}
- keeps the DE(-system) forminvariant up to terms $O(\epsilon^2)$, can be used
- to integrate the ODE. The resulting conditions for $\xi, \eta$ are a
- linear system of PDEs. If the DEs are PDEs then $x$ and $\xi$ get an
- index. If one investigates a system of DEs then $y$ and $\eta$ get an index.
- To determine for example point-symmetries of the ODE (6.97) in \cite{Ka}
- \begin{equation}
- 0 = x^4y'' - y'(2xy + x^3) + 4y^2 \label{k97}
- \end{equation}
- for $y = y(x)$ the input would be
- \begin{verbatim}
- depend y,x;
- de := {df(y,x,2) - (df(y,x)*(2*x*y+x**3) + 4*y**2)/x**4, y, x};
- mo := {0, nil, nil};
- LIEPDE(de,mo);
- \end{verbatim}
- The first argument to {\tt LIEPDE} is a list which includes
- a single equation or a list of equations,
- a single unknown function or a list of unknown functions and
- a single independent variables or a list of independent variables.
- The second argument to {\tt LIEPDE} specifies the mode of operation.
- It is a list {\tt mo = \{od, lp, fl\}} where
- \begin{itemize}
- \item {\tt od} is the order of the ansatz for $\xi, \eta.$ It is = 0 for
- point symmetries and = 1 for contact symmetries (only in case of
- one ODE/PDE for one unknown function).
- % and $>1$ for dynamical symmetries
- %(only in case of one ODE for one unknown function)
- \item If {\tt lp} is $nil$ then the standard ansatz for $\xi^i, \eta^\alpha$
- is taken which is
- \begin{itemize}
- \item for point symmetries ({\tt od}=0) $\xi^i = \xi^i(x^j,u^\beta),
- u^\alpha = u^\alpha(x^j,u^\beta)$
- \item for contact symmetries ({\tt od}=1)
- $ \xi^i := \Omega,_{u,_i}, \;\;\;
- \eta := u,_i\Omega,_{u_i} \; - \; \Omega, \;\;\;
- \Omega:=\Omega(x^i, u, u,_j)$
- %\item for dynamical symmetries ({\tt od}$>1$) \\
- % $ \xi := \Omega,_{u'}, \;\;\;
- % \eta := u'\Omega,_{u'} \; - \; \Omega, \;\;\;
- % \Omega:=\Omega(x, u, u',\ldots, u^{({\tt od}-1)})$
- % where {\tt od} must be less than the order of the ODE.
- \end{itemize}
- If {\tt lp} is not $nil$ then {\tt lp} is the ansatz for
- $\xi^i, \eta^\alpha$ and must have the form
- \begin{itemize}
- \item for point symmetries
- {\tt \{xi\_\mbox{$x1$} = ..., ..., eta\_\mbox{$u1$} = ..., ...\}}
- where {\tt xi\_, eta\_}
- are fixed and $x1, \ldots, u1$ are to be replaced by the actual names
- of the variables and functions.
- \item otherwise {\tt spot\_ = ...} where the expression on the right hand
- side is the ansatz for the Symmetry-POTential $\Omega.$
- \end{itemize}
- \item {\tt fl} is the list of free functions in the ansatz
- in case {\tt lp} is not $nil.$
- \end{itemize}
- The conditions for the symmetry generators $\xi, \eta$ to provide
- infinitesimal transformations
- which leave (\ref{k97}) form-invariant to order $O(\varepsilon^2)$ are
- formulated by the program {\tt LIEPDE} to be
- \begin{eqnarray}
- 0 & = & \frac{1}{2}x^3\eta,_{yy} - x^3\xi,_{xy} - x^2\xi,_y - 2y\xi,_y
- \label{con1} \\
- 0 & = & 12y^2\xi,_y - x^4\xi,_{xx} - x^3\xi,_x - 2xy\xi,_x
- + 2x^4\eta,_{xy} + x^2\xi + 6y\xi - 2x\eta \\
- 0 & = & 2y^2\xi - xy^2\xi,_x - \frac{1}{8}x^5\eta,_{xx}
- + \frac{1}{8}x^4\eta,_x
- + \frac{1}{4}x^2y\eta,_x + \frac{1}{2}xy^2\eta,_y
- - xy\eta \\
- 0 & = & \xi,_{yy}. \label{con2}
- \end{eqnarray}
- {\tt LIEPDE} then calls {\tt CRACK} to solve this system.
- First (\ref{con2}) is integrated to $0 = \xi + c_1y + c_2$
- with new functions $c_1(x), c_2(x).$
- Then $\xi$ is substituted into the other three equations. Now (\ref{con1})
- can be integrated to
- \[ 0 = x^3\eta + x^3y^2c_1' - x^3yc_3 - x^3c_4 + x^2y^2c_1
- + \frac{2}{3}y^3c_1 \]
- with new functions $c_3(x), c_4(x)$ and $\eta$ can be substituted.
- Because the functions $c_1,\ldots,c_4$ are functions of $x$ only,
- a separation of the remaining two equations w.r.t.\ the independent
- variable $y$ becomes possible which yields 5 and 4 equations. One of
- them is $c_1=0$.
- After setting $c_1$ to zero, the exact second order ODE
- $0 = xc_4'' + 3c_4'$ can be integrated once and
- the resulting first order ODE can be solved by
- {\tt ODESOLVE} \cite{Mal} to give $c_4 = x^2c_6 - c_5/2$
- with constants $c_5, c_6$. From another equation $c_3$ can be eliminated
- and substituted: $c_3 = c_2' - 3c_2/x$. The last function $c_2(x)$ is
- solved by {\tt ODESOLVE} from $0 = x^2c_2'' - xc_2' + c_2$ to give
- $c_2 = x(c_8\log x + c_7)$. Because now only constants are involved in
- the remaining two equations, {\tt CRACK} separates them w.r.t.\ $x$ to obtain 4
- conditions which are solved to give $c_5 = 0$ and $c_6 = - c_8$,
- finally obtaining two symmetries (for $c_7 = 0, \, c_8 = -1$ and
- $c_7 = -1, \, c_8 = 0$):
- \[
- \begin{array}{rclrcl}
- \xi_1 & = & x\log x,\hspace{0.5in} & \eta_1 & = & 2y\log x + x^2 - y \\
- \xi_2 & = & x, & \eta_2 & = & 2y .
- \end{array} \]
- Applying Lie's algorithm by hand, the general solution of (\ref{k97})
- is \cite{Ka}
- \[ y = \left\{ \begin{array}{l}
- x^2(1 + c_9\tan(c_9\log x + c_{10})) \\
- x^2(1 - c_9\tanh(c_9\log x + c_{10})) \\
- x^2(1 - c_9\coth(c_9\log x + c_{10}))
- \end{array}
- \right. \]
- with constant $c_9, c_{10}$.
- If symmetries of a PDE or of a system of equations shall be determined then
- {\tt LIEPDE} does this iteratively by formulating some of the conditions and
- solving them by calling {\tt CRACK} to simplify the formulation of the
- remaining conditions. If a system of DEs is investigated then the conditions
- following from the form-invariance of each single equation are investigated
- successively. If a PDE is investigated then conditions which result from
- setting to zero the coefficients of the highest derivatives of $y$ are
- investigated first. For more details on this iteration see \cite{Alex},
- \cite{Step} and \cite{LIEPDE}.
- A more difficult system of PDEs are the Karpman equations \cite{Karp}
- which play a role in plasma physics. In their real form, which is used to
- determine symmetries, they are (\cite{Cham})
- \[\rho,_t+w_1\rho,_z+\frac{1}{2}\left[s_1(2\rho,_x\phi,_x+2\rho,_y\phi,_y
- +\rho\phi,_{xx}+\rho\phi,_{yy})+
- s_2(2\rho,_z\phi,_z+\rho\phi,_{zz})\right] = 0\]
- \[\phi,_t+w_1\phi,_z-\frac{1}{2}\left[s_1\left(\frac{\rho,_{xx}}{\rho}
- +\frac{\rho,_{yy}}{\rho}-\phi,_x^2-\phi,_y^2\right)+
- s_2\left(\frac{\rho,_{zz}}{\rho}-\phi,_z^2\right)\right]+a_1\nu = 0\]
- \[\nu,_{tt}-(w_2)^2(\nu,_{xx}+\nu,_{yy}+\nu,_{zz})-
- 2a_2\rho(\rho,_{xx}+\rho,_{yy}+\rho,_{zz})-2a_2(\rho,_x^2+\rho,_y^2+\rho,_z^2) = 0\]
- with the three functions $\rho,\phi,\nu$ of four variables $t,x,y,z$ and
- with constant parameters $a_i,s_i,w_i.$
- At first, preliminary symmetry conditions are
- derived and solved successively
- for each of the three equations.
- The solution
- of the preliminary conditions for the
- first equation
- requires 31 integrations and states that all $\xi^i$ are
- functions of $t,x,y,z$ only.
- The preliminary conditions of the second equation do not provide new
- constraints.
- The result from the preliminary conditions for the third equation
- is that $\nu$ is a function of $t,x,y,z$ only. This needs 4
- integrations.
- After 7.1/0.1 sec the full conditions for the first equation are derived
- which to solve requires further 77 integrations.
- The remaining full conditions for the second equation
- to solve requires 6 integrations. Finally,
- the full conditions for the last equation are
- solved with three more integrations.
- The general solution for the symmetry generators then reads
- \[ \begin{array}{rclrcl}
- \xi^x & = & - y c_1 + c_2 \;\;\;\;\; & \eta^r & = & 0 \\
- \xi^y & = & x c_1 + c_3 & \eta^\phi & = & a_1 c_6 t^2 + a_1 c_7 t + c_8 \\
- \xi^z & = & c_4 & \eta^v & = & - c_6 t - c_7 \\
- \xi^t & = & c_5 & & &
- \end{array}
- \]
- with constants $c_1, \ldots, c_8.$ The corresponding 8 symmetry generators are
- \begin{eqnarray*}
- X_1 = \partial_x & \;\;\;\;\;\;\;\;\;\; & X_5 = y\partial_x - x\partial_y \\
- X_2 = \partial_y & & X_6 = \partial_\phi \\
- X_3 = \partial_z & & X_7 = a_1t\partial_\phi - \partial_\nu \\
- X_4 = \partial_t & & X_8 = a_1t^2\partial_\phi - 2t\partial_\nu.
- \end{eqnarray*}
- The total time in a test run with {\tt lisp(print\_:=nil);} was
- 260/3.2 seconds on a PC486 with 33 MHz and 4MB RAM,
- i.e. less than 5 min.
- For comparison, the same calculation reported in \cite{Cham}, also split
- into 6 parts but with integrations done by hand, took more than 2 hours CPU
- on a VAX 8600 to formulate and simplify the symmetry conditions using the
- program {\tt SYMMGRP.MAX} written in MACSYMA.
- The corresponding input for {\tt LIEPDE} is
- \begin{verbatim}
- depend r,x,y,z,tt;
- depend f,x,y,z,tt;
- depend v,x,y,z,tt;
- de := {{df(r,tt)+w1*df(r,z)
- + s1*(df(r,x)*df(f,x)+df(r,y)*df(f,y)+r*df(f,x,2)/2+r*df(f,y,2)/2)
- + s2*(df(r,z)*df(f,z)+r*df(f,z,2)/2),
- df(f,tt)+w1*df(f,z)
- - (s1*(df(r,x,2)/r+df(r,y,2)/r-df(f,x)**2-df(f,y)**2) +
- s2*(df(r,z,2)/r-df(f,z)**2))/2 + a1*v,
- df(v,tt,2)-w2**2*(df(v,x,2)+df(v,y,2)+df(v,z,2))
- - 2*a2*r*(df(r,x,2)+df(r,y,2)+df(r,z,2))
- - 2*a2*(df(r,x)**2+df(r,y)**2+df(r,z)**2)},
- {r,f,v}, {x,y,z,tt}};
- mo := {0, nil, nil};
- LIEPDE(de,mo);
- \end{verbatim}
- \subsection{Determining integrating factors}
- Another way to solve or simplify nonlinear DEs is to determine first
- integrals by finding integrating factors. For the equation (6.37) of
- \cite{Ka} (which has no point symmetry)
- \begin{equation}
- 0 = y'' + y'(2y + F(x)) + F(x)y^2 - H(x) \label{k37}
- \end{equation}
- for $y(x)$ and parametric functions $F, H$ of $x$ the input
- consists of
- \begin{verbatim}
- depend f,x;
- depend h,x;
- depend y,x;
- de := {df(y,x,2) = -(2*y+f)*df(y,x)-f*y**2+h, y, x};
- mo := {0,{},2};
- FIRINT(de,mo);
- \end{verbatim}
- The arguments to {\tt FIRINT} are similar to those of {\tt LIEPDE}\@.
- Here {\tt mo = \{fi,fl,dg\}} specifies an ansatz for the first integral.
- For {\tt fi=0} the ansatz for the first integral is determined by
- {\tt dg}: The first integral is assumed to be a
- polynomial of degree {\tt dg} in $y^{(n-1)}$ (with $n$ as the order of the ODE)
- and with arbitrary functions of $x, y,\ldots,y^{(n-2)}$ as coefficients.
- In this case
- {\tt fl} has no meaning and is set to \{\}.
- For {\tt fi}$\neq${\tt 0, fi} is the ansatz for the first integral and
- {\tt fl} is a list of
- unknown functions in the ansatz, which are to be solved for. In this case
- {\tt dg} has no meaning.
- The above example determines first integrals which are at most quadratic
- in $y'$ for equation (6.37) in \cite{Ka}.
- {\tt FIRINT} starts with the ansatz
- \begin{equation}
- {\rm const.} = h_2(x,y)y'^2 + h_1(x,y)y' + h_0(x,y) \label{fians}
- \end{equation}
- and formulates the determining system by total differentiation of
- (\ref{fians}), identification of $y''$ with $y''$ in (\ref{k37}) and
- direct separation of $y',$ to produce
- \begin{eqnarray*}
- 0 & = & h_2,_y \\
- 0 & = & (H - F y^2)h_1 + h_0,_x \\
- 0 & = & h_1,_x + h_2,x - (2F + 4y)h_2 \\
- 0 & = & 2(H - Fy^2)h_2 - (F - 2y)h_1 + h_0,y + h_1,x.
- \end{eqnarray*}
- It then calls {\tt CRACK} which provides the solution for $h_0,h_1,h_2.$
- The first integral is
- \begin{equation}
- \mbox{const.} = \left( \frac{dy}{dx}+y^2 \right) e^{\int \!F\,dx} -
- \int He^{\int \!F\,dx} dx
- \end{equation}
- which is linear in $y'$. Many other nonlinear ODEs in \cite{Ka} have quadratic
- first integrals.
- \subsection{Determining a Lagrangian for a given 2nd order ODE}
- The knowledge of a Lagrangian $L$ for a given set of differential
- equations may be useful in solving and understanding these equations.
- If $L$ is known it is easier to determine symmetries, conserved
- quantities and singular points. An equivalent variational principle
- could also be useful for a more efficient numerical solution.
- This problem is known as the inverse problem of variational calculus.
- For example, the first transcendental Painlev\'{e} equation
- \begin{equation}
- y'' = 6y^2 + x \label{pain}
- \end{equation}
- has no point symmetries but proves to have a Lagrangian with the
- structure
- \begin{equation}
- L = u(x,y)(y')^2 + v(x,y). \label{lagr}
- \end{equation}
- (The other 5 transcendental Painlev\'{e} equations have a Lagrangian
- of this structure as well.)
- A program {\tt LAGRAN} formulates the conditions for $u$ and $v$ (a first
- order PDE-system). The call is
- \begin{verbatim}
- depend f,x; depend y,x;
- de := {df(y,x,2) = 6*y**2 + x, y, x};
- mo := {0,{}};
- LAGRAN(de,mo);
- \end{verbatim}
- If a system of ODEs or a PDE with at least two variables is given,
- then the existence of an equivalent Lagrangian $L$ is not guaranteed.
- Only in the case of
- a single 2nd order ODE, which is treated by the program {\tt LAGRAN},
- must a Lagrangian which is locally equivalent to the ODE
- exist. As a consequence the determination of $L$ for a second order
- ODE is in general not simpler than the solution of the ODE itself.
- Therefore the structure of
- $L$ must be specified, which is done through (\ref{lagr}).
- In the call of {\tt LAGRAN} the second argument {\tt mo=\{lg,fl\}} allows
- input of an ansatz for the Lagrangian.
- For {\tt lg=0} the default ansatz for the first integral is as given in
- (\ref{lagr}).
- For {\tt lg$\neq$0, lg} is the ansatz for the Lagrangian and {\tt fl} is a
- list of unknown functions in the ansatz which are to be solved.
- For equation (\ref{pain}) the resulting equivalent Lagrangian is
- \[ L = y'^2 + xy + 4y^3. \]
- Because the first order system for $u$ and $v$ is normally not too
- difficult, more complicated problems can also be solved, such as the
- determination of $L$ for the 6'th transcendental Painlev\'{e} equation
- \begin{eqnarray}
- y'' = & \frac{1}{2}\left(\frac{1}{y}+\frac{1}{y-1}+\frac{1}{y-x}\right) y'^2
- - \left(\frac{1}{x}+\frac{1}{x-1}+\frac{1}{y-x}\right)y' \nonumber \\
- & + \frac{y(y-1)(y-x)}{x^2(x-1)^2}\left(a+\frac{bx}{y^2}+\frac{c(x-1)}{(y-1)^2}
- +\frac{dx(x-1)}{(y-x)^2}\right)
- \end{eqnarray}
- for which $L$ turns out to be
- \[
- \begin{array}{rcll}
- L & = & 1/[xy(x-y)(x+1)(x-1)(y-1)] \cdot [(x+1)(x-1)^2x^2y'^2 \\
- & & - 2a(xy+x+y)(x-y)(y-1)y + 2b(x+y+1)(x-y)(y-1)x \\
- & & + 2c(x+y)(x-y)(x-1)y - 2d(x-1)(y+1)(y-1)xy ].
- \end{array} \]
- \subsection{A factorization ansatz for a given ODE}
- A further possible way to integrate an $n$'th order ODE is to decompose it
- into two ODEs of order $k$ and $n-k$. If one specifies the structure of the
- $k$'th order ODE and demands that these ODEs can be solved successively then
- this leads to a system of PDEs in the variables
- $x, y, \ldots, y^{k-1}$ with a good chance of solution.
- To solve the ODE (6.122) in \cite{Ka}
- \begin{equation}
- 0 = yy'' - y'^2 + F(x)yy' + Q(x)y^2 \label{6.122}
- \end{equation}
- the input would be
- \begin{verbatim}
- depend f,x;
- depend q,x;
- depend y,x;
- de := {df(y,x,2) = df(y,x)**2/y - f*df(y,x) - y*q, y, x};
- mo := {2,{}};
- DECOMP(de,mo);
- \end{verbatim}
- In contrast to {\tt FIRINT}, {\tt LAGRAN} the ODE could here
- be in the implicit form $0 = \ldots \;$ as well.
- The second argument {\tt mo = \{as,fl\}} specifies an ansatz for the $k$'th
- order ODE. If {\tt as} is an integer between 1 and 4 inclusive
- then a default ansatz
- is taken and {\tt fl} (the list of further unknown functions) is \{\}.
- The 4 ans\"atze for \verb+as+ $\in$ [1,4] are
- \begin{eqnarray}
- y' & = & a(x)\,b(y) \nonumber \\
- y' & = & a(x)\,y + b(x) \label{d2} \\
- y' & = & a(x)\,y^n + b(x)\,y \nonumber \\
- y' & = & a(x)\,y^2 + b(x)\,y + c(x) \nonumber
- \end{eqnarray}
- For {\tt as}$\not\in$[1,4], {\tt as} itself is the ansatz for the $k$'th
- order ODE with $y^{(k)}$ eliminated on the left side and {\tt fl} is
- a list of unknown functions in the ansatz, which are to be solved for.
- The program {\tt DECOMP} formulates the determining system, in the above
- example
- \begin{eqnarray*}
- 0 & = & b^2 \\
- 0 & = & - F(x)b - b' + ab \\
- 0 & = & - F(x)a - Q(x) - a'
- \end{eqnarray*}
- and calls {\tt CRACK} to solve it. Because the result
- \begin{eqnarray*}
- a(x) & = & \left(c_1 - \int Qe^{-\int F dx} dx\right)e^{-\int F dx} \\
- b(x) & = & 0
- \end{eqnarray*}
- contains $n-k = 1$ constant(s) of integration, this factorization ansatz
- does not restrict the solution space of (\ref{6.122})
- and because of (\ref{d2}) the general solution is
- \[y = c_2e^{\int \left[\left(c_1 - \int Qe^{-\int F dx} dx\right)e^{-\int F dx}
- \right] dx}.\]
- \subsection{General remarks on complexity}
- In general, PDE-systems are easier to solve, the fewer arbitrary functions of
- fewer variables are contained in the general solution. This in turn
- is the case if more and more equations have to be satisfied for less functions,
- i.e. the more restrictive is the PDE-system.
- Having more equations to solve for a given number of functions
- improves the
- chance of finding an integrable one among them and provides
- more possibilities to combine them and find a quick way to solve
- them. For example, it is usually more difficult to find all
- point symmetries of a very simple ODE with many point symmetries
- than to show that an ODE that is possibly more difficult
- to solve has no point symmetry.
- An appropriate strategy could therefore be to start an
- investigation with a very restrictive ansatz and later to try
- less restrictive ones. For example, an ODE could be investigated at first
- with respect to point symmetries and if none is found then one
- could look for contact and then for dynamical symmetries.
- Experience shows that nonlinear systems may lead to an
- explosion in the length of generated equations much quicker
- than linear equations
- even if they have more independent variables or are of higher order.
- For solving ODEs one should therefore investigate infinitesimal
- symmetries or integrating factors first which provide linear systems
- and only later consider the factorization into two ODEs of lower order.
- \subsection{Acknowledgement}
- We want to thank especially Francis Wright and Herbert Melenk for
- continuous help in respect with special features and bugs of REDUCE.
- \newpage
- \begin{thebibliography}{99}
- \bibitem{Riq} C. Riquier, Les syst\`{e}mes d'\'{e}quations aux d\'{e}riv\'{e}es
- partielles, Gauthier--Villars, Paris (1910).
- \bibitem{Th} J. Thomas, Differential Systems, AMS, Colloquium
- publications, v. 21, N.Y. (1937).
- \bibitem{Ja} M. Janet, Le\c{c}ons sur les syst\`{e}mes d'\'{e}quations aux
- d\'{e}riv\'{e}es, Gauthier--Villars, Paris (1929).
- \bibitem{Topu} V.L. Topunov, Reducing Systems of Linear Differential
- Equations to a Passive Form, Acta Appl. Math. 16 (1989) 191--206.
- \bibitem{Alex} A.V. Bocharov and M.L. Bronstein, Efficiently
- Implementing Two Methods of the Geometrical Theory of Differential
- Equations: An Experience in Algorithm and Software Design, Acta. Appl.
- Math. 16 (1989) 143--166.
- \bibitem{Reid1} G.J. Reid, A triangularization algorithm which
- determines the Lie symmetry algebra of any system of PDEs, J.Phys. A:
- Math. Gen. 23 (1990) L853-L859.
- \bibitem{FS} F. Schwarz, Automatically Determining Symmetries of Partial
- Differential Equations, Computing 34, (1985) 91-106.
- \bibitem{Fush} W.I. Fushchich and V.V. Kornyak, Computer Algebra
- Application for Determining Lie and Lie--B\"{a}cklund Symmetries of
- Differential Equations, J. Symb. Comp. 7 (1989) 611--619.
- \bibitem{Ka} E. Kamke, Differentialgleichungen, L\"{o}sungsmethoden
- und L\"{o}sungen, Band 1, Gew\"{o}hnliche Differentialgleichungen,
- Chelsea Publishing Company, New York, 1959.
- \bibitem{Wo} T. Wolf, An Analytic Algorithm for Decoupling and Integrating
- systems of Nonlinear Partial Differential Equations, J. Comp. Phys.,
- no. 3, 60 (1985) 437-446 and, Zur analytischen Untersuchung und exakten
- L\"{o}sung von Differentialgleichungen mit Computeralgebrasystemen,
- Dissertation B, Jena (1989).
- \bibitem{WoInt} T. Wolf, The Symbolic Integration of Exact PDEs,
- preprint, submitted to J.\ Symb.\ Comp. (1991).
- \bibitem{WM} M.A.H. MacCallum, F.J. Wright, Algebraic Computing with REDUCE,
- Clarendon Press, Oxford (1991).
- \bibitem{Mal} M.A.H. MacCallum, An Ordinary Differential Equation
- Solver for REDUCE, Proc. ISAAC'88, Springer Lect. Notes in Comp Sci.
- 358, 196--205.
- \bibitem{Step} H. Stephani, Differential equations, Their solution using
- symmetries, Cambridge University Press (1989).
- \bibitem{LIEPDE} T. Wolf, An efficiency improved program {\tt LIEPDE}
- for determining Lie-symmetries of PDEs, Proceedings of the workshop on
- Modern group theory methods in Acireale (Sicily) Nov. (1992)
- \bibitem{Karp} V.I. Karpman, Phys. Lett. A 136, 216 (1989)
- \bibitem{Cham} B. Champagne, W. Hereman and P. Winternitz, The computer
- calculation of Lie point symmetries of large systems of differential
- equation, Comp. Phys. Comm. 66, 319-340 (1991)
- \end{thebibliography}
- \end{document}
|