Linear differential systems
function:opt_moser_reduce
ISOLDE[super_reduce] - compute a super-irreducible form of a linear differential system
ISOLDE[moser_reduce] - compute a Moser-irreducible form of a linear differential system
Calling Sequences
super_reduce(A, x, p, u)
super_reduce(A, x, p, u, T, invT)
moser_reduce(A, x, p, u)
moser_reduce(A, x, p, u, T, invT)
Parameters
A - square matrix with rational function entries
x - independent variable of the system Y' = A(x)Y
p - irreducible polynomial in x or the symbol infinity
u - name
T - name
invT - name
Description
Consider the linear differential system
Y' = A(x)Y.
For a rational function matrix S with det(S) <> 0 the transformation
Y = S Z
leads to a new system Z' = B Z. One has
B = S^(-1)(AS - d/dx S)
The matrices A and B are said to be equivalent.
The super_reduce function computes a matrix B equivalent to A in a special form, called super-irreducible at p. The output is a list of two elements. The first is the super-irreducible matrix; the second gives information about the integer slopes and Newton polynomials of the Newton polygon of the computed system. It is a list of couples, the first element of which is an integer (the slope) and the second a polynomial in u (the Newton polynomial associated with the slope).
The moser_reduce function computes a matrix B equivalent to A which is Moser-irreducible at p. This is an equivalent matrix of minimal pole order. The output is similar to the super_reduce function, but only the Newton polynomials associated with the two biggest slopes are returned.
If T and invT are passed as arguments, they are assigned to the transformation matrix T and their inverse which transforms A to the super-irreducible (Moser-irreducible) matrix.
These functions are part of the DEtools package, and so they can be used in the form super_reduce(..) and moser_reduce(..) only after executing the command with(DEtools). However, they can always be accessed through the long form of the command by using DEtools[super_reduce](..) or DEtools[moser_reduce](..).
For more information about super-irreducible forms of linear differential systems and applications see E. Pfluegel, "An Algorithm For Computing Exponential Solutions of First Order Linear Differential Systems", Proceedings of ISSAC '97, and the references therein.
Examples
> with(DEtools):
Consider the following matrix:
> A:=array(1 .. 4, 1 .. 4,[(2, 1)=0,(3, 2)=-6/x^4,(2, 4)=-1/x^2,
> (4, 2)=(3-2*x)/x^3, (1, 3)=(5+2*x)/x^3,(4, 1)=-4/x^2,(4, 3)=1,(4, 4)=2/x^2,
> (1, 1)=-1,(2, 2)=-1,(2, 3)=0,(1, 4)=(4*x^2-2*x)/x^4,(3, 3)=-1,(3, 1)=8/x^3,
> (1, 2)=1/x,(3, 4)=2/x^2]);
[ 2 ]
[ 5 + 2 x 4 x - 2 x]
[ -1 1/x ------- ----------]
[ 3 4 ]
[ x x ]
[ ]
[ 1 ]
[ 0 -1 0 - ---- ]
[ 2 ]
A := [ x ]
[ ]
[ 8 6 2 ]
[ ---- - ---- -1 ---- ]
[ 3 4 2 ]
[ x x x ]
[ ]
[ 4 3 - 2 x 2 ]
[- ---- ------- 1 ---- ]
[ 2 3 2 ]
[ x x x ]
The pole order of this matrix at the point x = 0 is 4. The Moser algorithm computes an equivalent matrix of minimal pole order.
> B := moser_reduce(A, x, x, u, 'T', 'invT'):
> B[1];
[ 7 x + 6 -5 + 16 x 24 4 x + 3]
[- 1/3 ------- , - 1/3 --------- , - ---- , - 4/9 -------]
[ x 3 2 2 ]
[ x x x ]
[ 2 2 ]
[ -3 x + 2 x - 24 6 + x 5 x - 24 1 ]
[- ---------------- , - ----- , --------- , - 8/3 ----]
[ 3 2 2 2 ]
[ x x x x ]
[ 2 ]
[ 6 2 -8 + x + x ]
[- ---- , ---- , - ----------- , 0]
[ 3 2 2 ]
[ x x x ]
[ 2 x - 1 6 x - 1 ]
[x , 2 ------- , 3 ------- , 1/3]
[ 2 2 ]
[ x x ]
Here, the pole order is now 3. The super reduction algorithm computes a matrix which is Moser-irreducible and moreover the minimum of the valuations of each column (or equivalently, each row) is minimal. This also gives as additional information the integer slopes of the Netwon polygon and the associated Newton polynomials.
> B := super_reduce(A, x, x, u, 'T', 'invT'):
> print(B[1]);
[ 7 x + 6 -5 + 16 x 24 4 x + 3]
[- 1/3 ------- , - 1/3 --------- , - ---- , - 4/9 -------]
[ x 3 2 2 ]
[ x x x ]
[ 2 2 ]
[ -3 x + 2 x - 24 6 + x 5 x - 24 1 ]
[- ---------------- , - ----- , --------- , - 8/3 ----]
[ 3 2 2 2 ]
[ x x x x ]
[ 2 ]
[ 6 2 -8 + x + x ]
[- ---- , ---- , - ----------- , 0]
[ 3 2 2 ]
[ x x x ]
[ 2 x - 1 6 x - 1 ]
[x , 2 ------- , 3 ------- , 1/3]
[ 2 2 ]
[ x x ]
> B[2];
2 2
[[0, 1], [1, 2 u - u + 2], [2, u - 40]]
Check whether the matrix T is the correct transformation matrix:
>
> map(normal, evalm(B[1] - invT &* (A &* T - map(diff, eval(T), x))));
[0 0 0 0]
[ ]
[0 0 0 0]
[ ]
[0 0 0 0]
[ ]
[0 0 0 0]
If p is an irreducible polynomial, the computations are done for all roots of p simultaneously. The transformation matrices and hence the transformed matrix do not involve algebraic extensions over the ground field.
> A :=
> array(1 .. 4, 1 .. 4,[(2, 1)=0,(3, 2)=0,(2, 4)=7/(x^2+1)^2,(4, 2)=3/(x^2+1)^2,
> (1, 3)=-6/(x^2+1),(4, 1)=0,(4, 3)=-3*x^2/(x^2+1)^3,(4, 4)=1,(1, 1)=1,(2, 2)=4/
> (x^2+1),(2, 3)=0,(1, 4)=9/(x^2+1),(3, 3)=1,(3, 1)=(-5*x-3)/(x^2+1)^2,(1, 2)=0,
> (3, 4)=0]);
[ 6 9 ]
[ 1 0 - ------ ------ ]
[ 2 2 ]
[ x + 1 x + 1 ]
[ ]
[ 4 7 ]
[ 0 ------ 0 ---------]
[ 2 2 2]
[ x + 1 (x + 1) ]
A := [ ]
[-5 x - 3 ]
[--------- 0 1 0 ]
[ 2 2 ]
[(x + 1) ]
[ ]
[ 2 ]
[ 3 x ]
[ 0 --------- -3 --------- 1 ]
[ 2 2 2 3 ]
[ (x + 1) (x + 1) ]
> B := super_reduce(A, x, x^2+1, u, 'T', 'invT'):
> print(B[1]);
[ 2 2 ]
[x + 1 - 2 x 5 x + 3 7 x - 3 - 2 x]
[------------ , - --------- , --------- , - ------------]
[ 2 2 2 2 2 2 ]
[ x + 1 (x + 1) (x + 1) x + 1 ]
[ 2 ]
[ 6 x + 1 - 2 x 9 6 ]
[- ------ , ------------ , --------- , ------]
[ 2 2 2 2 2 ]
[ x + 1 x + 1 (x + 1) x + 1]
[ 2 ]
[ x 3 ]
[-3 --------- , 0 , 1 , ------]
[ 2 2 2 ]
[ (x + 1) x + 1]
[ 7 4 ]
[0 , 0 , --------- , ------]
[ 2 2 2 ]
[ (x + 1) x + 1]