GetIDBasis
get initial data basis as an IDBasis object from a LAVF object
SetIDBasis
set initial data basis as an IDBasis object in a LAVF object
Calling Sequence
Parameters
Description
Examples
Compatibility
GetIDBasis( obj)
SetIDBasis( obj, B)
SetIDBasis( obj, Vs)
SetIDBasis( obj, str)
obj
-
a LAVF object
B
a IDBasis object
Vs
a list of Vectors, a Matrix, a list of linear combinations of parametric derivatives of obj, or the string "standardBasis": representing a change-of-basis for the initial data of obj
str
a string, which can be one of the following: "derivedAlgebra", "solvableRadical", "nilRadical", "nilpotentRadical", killingRadical", "centre", "derivedSeries", "lowerCentralSeries", "upperCentralSeries"
An LAVF object has ability to store a initial data (ID) basis within it. An ID basis that is stored in a LAVF object is also a Maple object named IDBasis (see Overview of the IDBasis object).
The GetIDBasis method returns the initial data basis for the determining system of a LAVF object, as an IDBasis object.
The SetIDBasis method sets the value of the IDBasis object in a LAVF object.
The first two calling sequences are front-ends to the corresponding methods of a LHPDE object. That is, let L be a LAVF object and S be its determining system, then the call GetIDBasis(L) is equivalent to GetIDBasis(S). And the call SetIDBasis(L, B) is equivalent to SetIDBasis(S, B) where B is a valid IDBasis object for L (and for S). See GetIDBasis and SetIDBasis of a LHPDE object for more detail.
The third calling sequence is a convenient special case for constructing and setting an IDBasis in a LAVF object in one go, without having to construct an IDBasis first. That is, let L be a LAVF object and S its determining system, then the call SetIDBasis(L,Vs) is equivalent to SetIDBasis(L, B) where B := IDBasis(S,Vs). See LieAlgebrasOfVectorFields[IDBasis] for constructing an IDBasis object.
In the fourth calling sequence, the call SetIDBasis(L, str) first chooses a good ID basis based on the Lie algebraic structure of L. It then sets the IDBasis in L.
The second input argument str can be one of the following: "derivedAlgebra", "solvableRadical", "nilRadical", "nilpotentRadical", "killingRadical", "centre", "derivedSeries", "lowerCentralSeries", "upperCentralSeries". It gives a hint to the method for how to choose a good IDBasis. That is, if str is the name of an ideal ("derivedAlgebra", "solvableRadical", "nilRadical", "nilpotentRadical", "killingRadical", "centre"), SetIDBasis first picks an IDBasis for that ideal, then extends it to a IDBasis of L. If str is the name of a series of ideals ("derivedSeries", "lowerCentralSeries", "upperCentralSeries"), the extension process is applied recursively.
For an IDBasis object to be eligible to be set in a LAVF object, the two objects' parametric derivatives must be the same. See example below.
These methods are associated with the LAVF object. For more detail, see Overview of the LAVF object.
with⁡LieAlgebrasOfVectorFields:
Typesetting:-Settings⁡userep=true:
Typesetting:-Suppress⁡ξ⁡x,y,η⁡x,y:
First, construct an indeterminate vector field and a determining system, then construct an LAVF object from them...
X≔VectorField⁡ξ⁡x,y⁢Dx+η⁡x,y⁢Dy,space=x,y
X≔ξ⁢ⅆⅆx+η⁢ⅆⅆy
S≔LHPDE⁡ξ⁡x,y=−15⁢x⁢3⁢diff⁡diff⁡η⁡x,y,x,y⁢x+2⁢diff⁡η⁡x,y,y,diff⁡diff⁡η⁡x,y,x,x=−−4⁢diff⁡diff⁡η⁡x,y,x,y⁢x⁢y−2⁢diff⁡η⁡x,y,y⁢y+4⁢diff⁡η⁡x,y,x⁢x+2⁢η⁡x,yx2,diff⁡diff⁡η⁡x,y,y,y=0,indep=x,y,dep=ξ,η
S≔ξ=−3⁢ηx,y⁢x25−2⁢ηy⁢x5,ηx,x=4⁢y⁢ηx,yx+2⁢y⁢ηyx2−4⁢ηxx−2⁢ηx2,ηy,y=0,indep=x,y,dep=ξ,η
L≔LAVF⁡X,S
L≔ξ⁢ⅆⅆx+η⁢ⅆⅆy&whereηx,x=−2⁢y⁢ηy⁢x−12⁢ηx⁢x2−20⁢ξ⁢y−6⁢η⁢x3⁢x3,ηx,y=−2⁢ηy⁢x−5⁢ξ3⁢x2,ηy,y=0,ξx=2⁢ηy⁢x+8⁢ξ3⁢x,ξy=0
ParametricDerivatives⁡L
η,ξ,ηy,ηx
If L's determining system has not set an IDBasis, then as default the Initial data basis of L is set to a standard IDBasis object (i.e. whose change-of-basis is the identity matrix).
GetIDBasis⁡L
We can set the value of IDBasis in L by first constructing one...
B≔IDBasis⁡GetDeterminingSystem⁡L,η⁡x,y−y⁢diff⁡η⁡x,y,y,η⁡x,y−x⁢ξ⁡x,y,−diff⁡η⁡x,y,x,η⁡x,y
B≔η−ηy⁢y,η−x⁢ξ,−ηx,η
.. and then setting it (this is the 2nd calling sequence).
SetIDBasis⁡L,B
η−ηy⁢y,η−x⁢ξ,−ηx,η
Note here: for B to be eligible to be set on the LAVF object L, the parametric derivatives on both objects must be the same.
GetParametricDerivatives⁡B
Using the third calling sequence we can construct and set IDBasis in one go..
SetIDBasis⁡L,Matrix⁡1,0,1,0,0,1,0,0,0,0,y,0,x,0,0,z
η+ηy,ξ,ηy⁢y,η⁢x+z⁢ηx
or we can reset IDBasis in L to the default IDBasis
SetIDBasis⁡L,standardBasis
We fetch the structure constants of L.
Cijk≔StructureConstants⁡L
Using the fourth calling sequence, the method chooses a good IDBasis based on the derived series of L.
SetIDBasis⁡L,derivedSeries
η,ηx+ηx,ξ,ξx+ηy
The commutator table will now be displayed with respect to a better ID basis.
DisplayStructure⁡L,Z
000Z100−Z1Z230Z10−2⁢y⁢Z23⁢x2+2⁢Z33−Z1−Z232⁢y⁢Z23⁢x2−2⁢Z330
As the dimensions of the derived series are [4,3,1,0], here we can see the table is divided into ideals as 1x1,3x3,4x4. And this commutator table has much less dependencies on (x,y) and expressions are much simpler than the one with default IDBasis (as shown below):
DisplayStructure⁡Cijk,Z
0Z43⁢x2Z1−2⁢Z43⁢x0−Z43⁢x202⁢Z23−2⁢Z33⁢x−2⁢y⁢Z43⁢x2Z1−4⁢Z43⁢x−Z1+2⁢Z43⁢x−2⁢Z23+2⁢Z33⁢x+2⁢y⁢Z43⁢x20−Z430−Z1+4⁢Z43⁢xZ430
The GetIDBasis and SetIDBasis commands were introduced in Maple 2020.
For more information on Maple 2020 changes, see Updates in Maple 2020.
See Also
LieAlgebrasOfVectorFields (Package overview)
LAVF (Object overview)
LieAlgebrasOfVectorFields[VectorField]
LieAlgebrasOfVectorFields[LHPDE]
LieAlgebrasOfVectorFields[LAVF]
LieAlgebrasOfVectorFields[IDBasis]
LieAlgebrasOfVectorFields[EliminationLAVF]
LieAlgebrasOfVectorFields[DisplayStructure]
StructureConstants
Download Help Document