\(\texttt{NLDE}\): A Maple package for D-algebraic functions
Bertrand Teguia Tabuguia
April 2023
This is a documentation for the Maple package NLDE to perform operations with D-algebraic functions. We give syntaxes and examples for each command of of the package. For introduction and configuration of the package check the link Operations for D-Algebraic Functions.
We now assume that the reader can already load the package.
[1]:
restart; #safe attitude
We load the \(\texttt{NLDE}\) package. It currently has 11 procedures whose three are part of its subpackage \(\texttt{AnsatzDalg}\).
[2]:
with(NLDE)
[2]:
Let us consider the algebraic differential equation of the Weirstrass elliptic functions.
[3]:
ADEwp:=diff(w(x),x)^2=4*w(x)^3-g2*w(x)-g3
[3]:
\(\texttt{OrderDegreeADE}\)
Syntax and Description
Calling sequence: OrderDegreeADE(ADE,y(x))
ADE: An algebraic differential equation in the dependent variable y(x) (and the independent variable x).
y(x): y and x are variable names.
Description: Returns a list \([r,d]\), where \(r\) and \(d\) are the order and the (total) degree of ADE, respectively.
Examples
[4]:
OrderDegreeADE(ADEwp,w(x))
[4]:
[5]:
OrderDegreeADE(ADEwp*x^4,w(x))
[5]:
[6]:
OrderDegreeADE(lhs(ADEwp)-rhs(ADEwp)+diff(w(x),x,x)^2*w(x)^3+x*diff(w(x),x$4)^4=0,w(x))
[6]:
\(\texttt{unaryDalg}\)
Syntax and Description
Calling sequence: unaryDalg(ADE,y(x),z=r(x,y),options)
ADE: An algebraic differential equation in the dependent variable y(x) (and the independent variable x).
y(x): y and x are variable names.
z=r(x,y): r is a rational function in x and y, and z is the variable name for the dependent variable in the output.
options: of the form keyword = value. There is only one option for this procedure:
The keyword ordering: it has two possible values: lexdeg (default) and plex. lexdeg is the elimination order defined by Bayer and Stillman. plex is the pure lexicographic ordering.
Description: Computes a least-order algebraic differential equation that \(r(x,f(x))\) satisfies, where \(f(x)\) is any solution of ADE.
Examples
[7]:
unaryDalg(ADEwp,w(x),z=w/(w+x))
[7]:
[8]:
unaryDalg(ADEwp,w(x),z=w^2+x)
[8]:
Every rational function satisfies a first-order algebraic differential equation. One can generate ADEs for rational functions with this command. Let us generate an ADE for \(x\mapsto \frac{(x+5)^2}{x^3+3x+7}\)
[9]:
unaryDalg(diff(y(x),x)=1,y(x),z=(y+5)^2/(x^3+3*x+7))
[9]:
Let us verify the result.
[10]:
simplify(eval(Out[9],z(x)=(x+5)^2/(x^3+3*x+7)))
[10]:
\(\texttt{arithmeticDalg}\)
Syntax and Description
Calling sequence: arithmeticDalg([ADE1,…,ADEN],[y1(x),…,yN(x)],z=r(x,y1,…,yN),options)
[ADE1,…,ADEN]: A list of algebraic differential equations in the dependent variables y1(x),…,yN(x) (and the independent variable x) given in the same order.
y1(x),…,yN(x): y1,…,yN, and x are variable names.
z=r(x,y1,…,yN): r is a rational function in x,y1,…,yN, and z is the variable name for the dependent variable in the output.
options: of the form keyword = value. There are three options for this procedure:
The keyword ordering: it has two possible values: lexdeg and plex (default). lexdeg is the elimination order defined by Bayer and Stillman. plex is the pure lexicographic ordering. Theoretically, the result is guaranteed when ordering=plex.
The keyword lho: it is a boolean variable with value true (default) or false. When lho=true the order is not optimal if at least one of the input equation is not linear in its highest order term. If lho=false, the optimal order is guaranteed; however, this might be computationally more expensive.
The keyword lhoplex: it has two possible values: lexdeg (default) and plex. This option is considered when lhô=false.
Description: Computes an algebraic differential equation (mostly of least order) that \(r(x,f_1(x),\ldots,f_N(x))\) satisfies, where \(f_1(x),\ldots,f_N(x)\) are generic solutions of ADE1,…,ADEN, respectively.
Examples
We consider two more ADEs: one for \(\exp(x)\) and another for \(\sqrt{1+x}\) One can find those using Maple’s command \(\texttt{DEtools:-FindODE}\)
[11]:
ADEexp:=DEtools:-FindODE(exp(x),y[1](x))=0
[11]:
[12]:
ADEsqrt:=DEtools:-FindODE(sqrt(x+1),y[2](x))=0
[12]:
Let us find an ADE for the product \(\exp(x)\,\wp(x)\). Since the equation of \(\wp\) is not lho, we specify lho=false to obtain a least-order ADE.
[13]:
arithmeticDalg([ADEwp,ADEexp],[w(x),y[1](x)],z=w*y[1],lho=false)
kilobytes used=20492, alloc=18610, time=2.06
[13]:
The next one if for the ratio \(\frac{\exp(x)}{x+\sqrt{1+x}}\)
[14]:
arithmeticDalg([ADEexp,ADEsqrt],[y[1](x),y[2](x)],z=y[1]/(x+y[2]))
kilobytes used=27867, alloc=18610, time=2.81
[14]:
\(\texttt{composeDalg}\)
Syntax and Description
Calling sequence: composeDalg([ADE1,ADE2],[y1(x),y2(x)],z(x),options)
[ADE1,ADE2]: A list of two algebraic differential equations in the dependent variables y1(x),y2(x) (and the independent variable x) given in the same order. The order in the list is the one use for the composition.
y1(x),y2(x),z(x): y1,y2,z and x are variable names. z(x) is the dependent variable for the output.
options: of the form keyword = value. There is only one option for this procedure:
The keyword ordering: it has two possible values: lexdeg and plex (default). lexdeg is the elimination order defined by Bayer and Stillman. plex is the pure lexicographic ordering. Theoretically, the result is guaranteed when ordering=plex. However, the computations are often faster when ordering=lexdeg.
Description: Computes an algebraic differential equation (mostly of least order) that \(f_1(f_2(x))\) satisfies, where \(f_1(x)\) and \(f_2(x)\) are generic solutions of ADE1 and ADE2, respectively.
Examples
Let us find an ADE satisfied by \(\wp(\sqrt{1+x})\).
[15]:
composeDalg([ADEwp,ADEsqrt],[w(x),y[2](x)],z(x),ordering=lexdeg)
[15]:
The next one is for \(\sqrt{1+\exp(x)}\)
[16]:
composeDalg([ADEsqrt,ADEexp],[y[2](x),y[1](x)],z(x),ordering=lexdeg)
[16]:
Observe that the latter output is the same quadratic differential equation obtained by \(\texttt{DEtools:-FindODE}\) directly from the expression \(\sqrt{1+\exp(x)}\). This is not always the case; here the result comes from pure algebraic computations with all solutions at once (no simplification knownledge is used). For \(\exp(\sqrt{1+x})\), the results are not the same.
[17]:
DEtools:-FindODE(sqrt(1+exp(x)),z(x),method=quadratic)
[17]:
[18]:
composeDalg([ADEexp,ADEsqrt],[y[1](x),y[2](x)],z(x),ordering=lexdeg)
[18]:
[19]:
DEtools:-FindODE(exp(sqrt(1+x)),z(x),method=quadratic)
[19]:
\(\texttt{diffDalg}\)
Calling sequence: diffDalg(ADE,y(x),options)
ADE: An algebraic differential equation in the dependent variable y(x) (and the independent variable x).
y(x): y and x are variable names.
options: of the form value. There is only one option for this procedure:
A positive integer n: it represents the order. The default value is \(1\) for the first derivative.
Description: Computes a least-order algebraic differential equation that \(f^{(n)}(x)\) (\(f'(x)\) by default) satisfies, where \(f(x)\) is a solution of ADE.
Examples
Let us find the ADEs for any \(\wp'(x)\) and \(\wp''(x)\).
[20]:
diffDalg(ADEwp,w(x))
[20]:
[21]:
diffDalg(ADEwp,w(x),2)
[21]:
Let us compute for the first derivatives of \(\exp(x)\) and \(\sqrt{1+x}\). The result here can be recovered by algorithms for holonomic functions.
[22]:
diffDalg(ADEexp,y[1](x))
[22]:
[23]:
diffDalg(ADEsqrt,y[2](x))
[23]:
\(\texttt{invDalg}\)
Calling sequence: diffDalg(ADE,y(x),z(x))
ADE: An algebraic differential equation in the dependent variable y(x) (and the independent variable x).
y(x),z(x): y,z and x are variable names. z(x) is the dependent variable for the output.
Description: Computes the algebraic differential equation of the lowest degree among those of lowest order that \(f^{-1}(x)\) satisfies; where \(f^{-1}\) is such that \(f^{-1}\circ f= f\circ f^{-1} = \text{Id}\) (in the appropriate domains), and \(f(x)\) is a solution of ADE.
Examples
Let us find ADEs for \(\wp^{-1}, \exp^{-1}=\log\) and \(\left(x\mapsto \sqrt{1+x}\right)^{-1} = x\mapsto x^2-1\)
[24]:
invDalg(ADEwp,w(x),z(x))
[24]:
[25]:
invDalg(ADEexp,y[1](x),z(x))
[25]:
[26]:
invDalg(ADEsqrt,y[2](x),z(x))
[26]:
\(\texttt{SysToMinDiffPoly}\)
Syntax and Description
Calling sequence: SysToMinDiffPoly([r1,…,rN],F,[X1,…,XN],z(t),options)
[r1,…,rN]: A list of rational functions in the variables X1,…,XN.
X1,…,XN: The variable names of the dynamical system.
F: A rational function in the variables X1,…,XN.
z(t): z(t) is the dependent variable (with independent variable t) for the input-output equation sought.
options: of the form keyword = value. There is only one option for this procedure:
The keyword ordering: it has two possible values: lexdeg and plex (default). lexdeg is the elimination order defined by Bayer and Stillman. plex is the pure lexicographic ordering.
Description: Computes the input-output equation of a rational dynamical system. The system has the form
This is the core procedure of all procedures in \(\texttt{NLDE}\) that uses Groebner bases elimination (when lho=true).
Examples
SIR model where we replace \(I\) by \(T\), as \(I\) is a protected Maple symbol. We compute a differential equation for \(R\) (the recovered individual).
[27]:
SysToMinDiffPoly([-beta*S*T-delta*S + mu, beta*S*T - gamma*T + nu, delta*S+gamma*T],R,[S,T,R],w(t))
kilobytes used=67777, alloc=23730, time=6.76
[27]:
[28]:
OrderDegreeADE(Out[27],w(t))
[28]:
\(\texttt{DDfiniteToDalg}\)
Syntax and Description
Calling sequence: DDfiniteToDalg(DDeq,y(x),[HDE1,…,HDEN],[C1(x),…,CN(x)],options)
DDeq: A linear differential equation in dependent variable y(x) (and independent variable x) with D-finite function coefficients, among which C1,…,CN linearly appear.
y(x): y and x are variable names.
[HDE1,…,HDEN]: A list of holonomic differential equations in the dependent variables C1(x),…,CN(x) (and the independent variable x) given in the same order.
C1(x),…,CN(x): C1,…,CN, and x are variable names.
options: of the form keyword = value. There is only one option for this procedure:
The keyword ordering: it has two possible values: lexdeg and plex (default). lexdeg is the elimination order defined by Bayer and Stillman. plex is the pure lexicographic ordering.
Description: Computes a least-order algebraic differential equation that has the same solutions as DDeq. Note, however, that the scope of the algorithm goes beyond the conversion of DD-finite equation into ADE. In fact, DDeq can be a linear differential equation with DD-finite function coefficients.
Examples
We consider Mathieu functions. These are solutions of the following differential equation:
where \(q\) and \(a\) are some parameters. We first compute a holonomic ODE (in the independent variable \(C(x)\)), satisfied by \(\cos(2\,x)\), and replace \(\cos(2\,x)\) in the equation by \(C\).
[29]:
DDeq:=diff(y(x),x,x)+(a-2*q*C)*y(x)=0
[29]:
[30]:
HDE:=DEtools:-FindODE(cos(2*x),C(x))=0
[30]:
[31]:
ADE:=DDfiniteToDalg(DDeq,y(x),[HDE],[C(x)])
[31]:
One can verify this result in Maple. The solutions of Mathieu equations in Maple are MathieuC(a,q,x) and MathieurS(a,q,x).
[32]:
simplify(eval(ADE,y(x)=MathieuC(a,q,x)))
[32]:
[33]:
simplify(eval(ADE,y(x)=MathieuS(a,q,x)))
[33]:
For our next example, we consider
satisfied by \(\cos(x/2)^2\, \exp(\tan(x/2))\). This example is from [Jiménez-Pastor, A. and Pillwein, V., (2020)]
[34]:
DDeq:=(C+1)*diff(y(x),x) + (S-1)*y(x) = 0
[34]:
For this example, since \(\cos(x)\) and \(\sin(x)\) satisfy the same differential equation, we cannot use their holnomic ODE here. Instead, we consider the equations
for \(\cos(x)\) and \(\sin(x)\), respectively.
[35]:
HDE1:=diff(C(x),x)=-S
[35]:
[36]:
HDE2:=diff(S(x),x)=C
[36]:
[37]:
ADE:=DDfiniteToDalg(DDeq,y(x),[HDE1,HDE2],[C(x),S(x)])
[37]:
[38]:
simplify(eval(ADE,y(x)=cos(x/2)^2*exp(tan(x/2))))
[38]:
\(\texttt{AnsatzDalg}\)
A subpackage of \(\texttt{NLDE}\) for doing arithmetic with D-algebraic functions. It (currently – April 2023) has two main procedures: \(\texttt{AnsatzDalg:-arithmeticDeltak}\) and \(\texttt{AnsatzDalg:-unaryDeltak}\). One can also use them without the prefix \(\texttt{AnsatzDalg}\) aftern loading the subpackage as \(\texttt{with(AnsatzDalg)}\). Sometimes these procedures are the best choice when the order and the degree of the expected ADE are small (\(\leq 6\)).
\(\texttt{AnsatzDalg:-unaryDeltak}\)
Syntax and Description
Calling sequence: AnsatzDalg:-unaryDeltak(ADE,y(x),z=F(x,y),options)
ADE: An algebraic differential equation in the dependent variable y(x) (and the independent variable x).
y(x): y and x are variable names.
z=F(x,y): F is a rational function in x, y, and their compositions by elementary functions. z is the variable name for the dependent variable in the output. Although, F can contain elementary functions, it is maint for rational function in x and y to have a reductionist approach of \(\texttt{unaryDalg}\).
options: of the form keyword = value. There are three options this procedure:
The keyword degreeDE: the possible values are positive integers. By default, degreeDE=2. When degreeDE=k, the code looks for an algebraic differential equation of degree at most k.
The keyword startingord: the possible values are positive integers. By default, startingord is the order of ADE. When startingord=s (larger than the order of ADE), the code starts the search from ADEs of order s.
The keyword maxdeorder: the possible values are positive integers. By default, maxdeorder is the order of ADE. When maxdeorder=m (larger than startingord), the code looks for an ADE of order at most m.
Description: Computes (looks for) the least-order algebraic differential equation of degree at most the value of degreeDE that \(\textbf{F}(x,f(x))\) satisfies, where \(f(x)\) is any solution of ADE.
Examples
Let us recover the results obtained by \(\texttt{unaryDalg}\).
[39]:
AnsatzDalg:-unaryDeltak(ADEwp,w(x),z=w/(w+x),degreeDE=4)
[39]:
[40]:
AnsatzDalg:-unaryDeltak(ADEwp,w(x),z=w^2+x,degreeDE=5)
[40]:
[41]:
AnsatzDalg:-unaryDeltak(diff(y(x),x)=1,y(x),z=(y+5)^2/(x^3+3*x+7))
[41]:
A different result for the composition \(\sqrt{1+\exp(x)}\). Remember that \(\texttt{composeDalg}\) finds an ADE fulfilled by \(\alpha_1\,\sqrt{1+\alpha_2\,\exp(x)}\) for arbitrary \(\alpha_1,\alpha_2\)
[42]:
AnsatzDalg:-unaryDeltak(ADEexp,y[1](x),z=sqrt(1+y[1]))
[42]:
[43]:
simplify(eval(Out[42],z(x)=sqrt(1+exp(x))))
[43]:
The same result for \(\exp(\sqrt{1+x})\).
[44]:
AnsatzDalg:-unaryDeltak(ADEsqrt,y[2](x),z=exp(y[2]))
[44]:
\(\texttt{AnsatzDalg:-arithmeticDeltak}\)
Syntax and Description
Calling sequence: AnsatzDalg:-arithmeticDeltak([ADE1,…,ADEN],[y1(x),…,yN(x)],z=F(x,y1,…,yN),options)
[ADE1,…,ADEN]: A list of algebraic differential equations in the dependent variables y1(x),…,yN(x) (and the independent variable x) given in the same order.
y1(x),…,yN(x): y1,…,yN, and x are variable names.
z=F(x,y1,…,yN): F is a rational function in x, y1,…,yN, and their compositions by elementary functions. z is the variable name for the dependent variable in the output. Although, F can contain elementary functions, it is maint for rational function in x and y1,…,yN to have a reductionist approach of \(\texttt{arithmeticDalg}\).
options: of the form keyword = value. There are three options this procedure:
The keyword degreeDE: the possible values are positive integers. By default, degreeDE=2. When degreeDE=k, the code looks for an algebraic differential equation of degree at most k.
The keyword startingord: the possible values are positive integers. By default, startingord is the smallest order among the orders of the input ADEs. When startingord=s (larger than the smallest order in the input ADEs), the code starts the search from ADEs of order s.
The keyword maxdeorder: the possible values are positive integers. By default, maxdeorder is the smallest order among the orders of the input ADEs. When maxdeorder=m (larger than startingord), the code looks for an ADE of order at most m.
Description: Computes (looks for) the least-order algebraic differential equation of degree at most the value of degreeDE that \(\textbf{F}(x,f_1(x),\ldots,f_N(x))\) satisfies, where \(f_1(x),\ldots,f_N(x)\) are any solutions of ADE1,…,ADEN, respectively.
Examples
Let us try the same examples of \(\texttt{arithmeticDalg}\).
[45]:
ADE:=CodeTools:-CPUTime(AnsatzDalg:-arithmeticDeltak([ADEwp,ADEexp],[w(x),y[1](x)],z=w*y[1],degreeDE=5))
kilobytes used=277133, alloc=23792, time=25.11
[45]:
[46]:
OrderDegreeADE(ADE[2],z(x))
[46]:
As it often happens, \(\texttt{AnsatzDalg:-arithmeticDeltak}\) detected a smaller degree ADE for \(\wp(x)*\exp(x)\). It is thererfore enough (and computationally more efficient – as shown by the CPU time) to use the option degreeDE=4.
[47]:
CodeTools:-CPUTime(AnsatzDalg:-arithmeticDeltak([ADEwp,ADEexp],[w(x),y[1](x)],z=w*y[1],degreeDE=4))
kilobytes used=345495, alloc=23792, time=31.08
[47]:
We end with \(\frac{\exp(x)}{x+\sqrt{1+x}}\).
[48]:
AnsatzDalg:-arithmeticDeltak([ADEexp,ADEsqrt],[y[1](x),y[2](x)],z=y[1]/(x+y[2]))
[48]:
\(\texttt{AnsatzDalg:-deltakdiff}\)
Syntax and Description
Calling sequence: AnsatzDalg:-deltakdiff(expr,x,k,n)
expr: A symbolic mathematical expression depending on x.
x: A variable name.
k: A positive integer representing the degree bound.
n: A non-negative integer representing the rank (order) of the output according to the \(\delta_{\textbf{k}}\) derivation.
Description: Computes the \(n\)th \(\delta_{\textbf{k}}\) derivative of expr.
Examples
Let us show how the first 10 products of at most 2 derivatives, at most 3 derivatives, and at most 4 derivatives are ordered w.r.t. the derivation rules \(\delta_2, \delta_3,\) and \(\delta_4\), respectively.
[49]:
seq(AnsatzDalg:-deltakdiff(F(x),x,2,j),j=0..10)
[49]:
[50]:
seq(AnsatzDalg:-deltakdiff(F(x),x,3,j),j=0..10)
[50]:
[51]:
seq(AnsatzDalg:-deltakdiff(F(x),x,4,j),j=0..10)
[51]:
[ ]: