(*********************************************************************** Mathematica-Compatible Notebook This notebook can be used on any computer system with Mathematica 4.0, MathReader 4.0, or any compatible application. The data for the notebook starts with the line containing stars above. To get the notebook into a Mathematica-compatible application, do one of the following: * Save the data starting with the line of stars above into a file with a name ending in .nb, then open the file inside the application; * Copy the data starting with the line of stars above to the clipboard, then use the Paste menu command inside the application. Data for notebooks contains only printable 7-bit ASCII and can be sent directly in email or through ftp in text mode. Newlines can be CR, LF or CRLF (Unix, Macintosh or MS-DOS style). NOTE: If you modify the data for this notebook not in a Mathematica- compatible application, you must delete the line below containing the word CacheID, otherwise Mathematica-compatible applications may try to use invalid cache data. For more information on notebooks and Mathematica-compatible applications, contact Wolfram Research: web: http://www.wolfram.com email: info@wolfram.com phone: +1-217-398-0700 (U.S.) Notebook reader applications are available free of charge from Wolfram Research. ***********************************************************************) (*CacheID: 232*) (*NotebookFileLineBreakTest NotebookFileLineBreakTest*) (*NotebookOptionsPosition[ 33368, 866]*) (*NotebookOutlinePosition[ 34535, 904]*) (* CellTagsIndexPosition[ 34491, 900]*) (*WindowFrame->Normal*) Notebook[{ Cell[TextData[StyleBox["In this example we use the package IntroToSymmetry.m \ to work out the point group of the nonlinear heat equation, \n\n\ Ut-(k(U))xUx-k(U)Uxx=0.\n\nfor two choices of k(U). Reference: Ibragimov, N. \ CRC Handbook Volume 1, page 110.", FontSize->14, FontWeight->"Plain"]], "Text", ImageRegion->{{0, 1}, {0, 1}}], Cell["\<\ This next command turns off spurious spelling error warnings.\ \>", \ "Text"], Cell[BoxData[ \(Off[General::spell]\)], "Input"], Cell[TextData[StyleBox["First read in the package which is located in a \ folder called SymmetryAnalysis inside the Mathematica folder.", FontWeight->"Plain"]], "Text", ImageRegion->{{0, 1}, {0, 1}}], Cell[BoxData[ \(Needs["\"]\)], "Input"], Cell[TextData[StyleBox["Enter the input equation as a string. Don't include \ the ==0 at the end.", FontWeight->"Plain"]], "Text", ImageRegion->{{0, 1}, {0, 1}}], Cell[BoxData[ \(\(inputequation = \n\ "\";\)\)], \ "Input"], Cell[TextData[StyleBox["The function u[x,t] is a solution of the equation and \ this constraint must be applied in the form of a rule to the invariance \ condition. Be careful to check signs.", FontWeight->"Plain"]], "Text", ImageRegion->{{0, 1}, {0, 1}}], Cell[BoxData[ \(\(rulesarray = \ \[IndentingNewLine]{"\D[k[u[x,t]],x]*D[u[x,t],x]+k[u[x,t]]*D[u[\ x,t],x,x]\>"};\)\)], "Input"], Cell[TextData[StyleBox["Enter the list of independent variables.", FontWeight->"Plain"]], "Text", ImageRegion->{{0, 1}, {0, 1}}], Cell[BoxData[ \(\(independentvariables = {"\", "\"};\)\)], "Input"], Cell[TextData[StyleBox["Enter the list of dependent variables.", FontWeight->"Plain"]], "Text", ImageRegion->{{0, 1}, {0, 1}}], Cell[BoxData[ \(\(dependentvariables = {"\"};\)\)], "Input"], Cell[TextData[StyleBox["Enter the list of function and constant names that \ need to be preserved when the equation is converted to generic y1[x1,x2] \ variables.", FontWeight->"Plain"]], "Text", ImageRegion->{{0, 1}, {0, 1}}], Cell[BoxData[ \(\(frozennames = {"\"};\)\)], "Input"], Cell[TextData[StyleBox["Enter the maximum derivative order of the input \ equation(s).", FontWeight->"Plain"]], "Text", ImageRegion->{{0, 1}, {0, 1}}], Cell[BoxData[ \(\(porder = 2;\)\)], "Input"], Cell[TextData[StyleBox["The maximum derivative order that the infinitesimals \ are assumed to depend on is specified by the input parameter r. This \ parameter is only nonzero when the user is looking for Lie contact groups or \ Lie-Backlund groups. For the usual case where one is searching for point \ groups set r=0.", FontWeight->"Plain"]], "Text", ImageRegion->{{0, 1}, {0, 1}}], Cell[BoxData[ \(\(rorder = 0;\)\)], "Input"], Cell[TextData[StyleBox["When searching for Lie-Backlund groups (r=1 or \ greater) one can, without loss of generality, leave the independent variables \ untransformed. The corresponding infinitesimals (the xse's) are set to zero \ by setting xseon=0. If one is searching for point groups then set xseon=1. \ The choice xseon=1 is also an option when looking for Lie-Backlund groups and \ this can be useful when looking for contact symmetries.", FontWeight->"Plain"]], "Text", ImageRegion->{{0, 1}, {0, 1}}], Cell[BoxData[ \(\(xseon = 1;\)\)], "Input"], Cell[TextData[StyleBox["When searching for Lie-Backlund groups it is \ necessary to differentiate the input equation with respect to each of the \ independent variables producing derivatives of order p+r. These higher order \ differential consequences are appended to the set of rules applied to the \ invariance condition. This process is carried out automatically when \ internalrules=1. For point groups the equation or equation system is the only \ rule or set of rules needed and one sets internalrules=0.", FontWeight->"Plain"]], "Text", ImageRegion->{{0, 1}, {0, 1}}], Cell[BoxData[ \(\(internalrules = 0;\)\)], "Input"], Cell[TextData[StyleBox["Now work out the determining equations of the Lie \ point group that leaves the equation invariant. The output is available as a \ table of strings called zdeterminingequations.", FontWeight->"Plain"]], "Text", ImageRegion->{{0, 1}, {0, 1}}], Cell[CellGroupData[{ Cell[BoxData[ \(FindDeterminingEquations[\[IndentingNewLine]independentvariables, dependentvariables, frozennames, porder, rorder, xseon, inputequation, rulesarray, internalrules]\)], "Input"], Cell[BoxData[ \("FindDeterminingEquations has finished executing. You can look at the \ output in the table zdeterminingequations. Each entry in this table is a \ determining equation in string format expressed in terms of z-variables. \ Rules for converting between z-variables and conventional variables are \ contained in the table ztableofrules. To view the determining equations in \ terms of conventional variables use the command \ ToExpression[zdeterminingequations]/.ztableofrules. There are two other items \ the user may wish to look at; the equation converted to generic \ (x1,x2,...,y1,y2,...) variables is designated equationgenericvariables and \ the various derivatives of the equation that appear in the invariance \ condition can be viewed in the table invarconditiontable. Rules for \ converting between z-variables and generic variables are contained in the \ table ztableofrulesxy."\)], "Print"] }, Open ]], Cell[CellGroupData[{ Cell[BoxData[ \(equationgenericvariables\)], "Input"], Cell[BoxData[ \("D[y1[x1,x2],x2]-D[k[y1[x1,x2]],x1]*D[y1[x1,x2],x1]-k[y1[x1,x2]]*D[y1[\ x1,x2],x1,x1]"\)], "Output"] }, Open ]], Cell[CellGroupData[{ Cell[BoxData[ \(invarconditiontable\)], "Input"], Cell[BoxData[ RowBox[{"{", RowBox[{"0", ",", "0", ",", RowBox[{ RowBox[{ RowBox[{"-", RowBox[{ SuperscriptBox["k", "\[Prime]\[Prime]", MultilineFunction->None], "[", \(y1[x1, x2]\), "]"}]}], " ", SuperscriptBox[ RowBox[{ SuperscriptBox["y1", TagBox[\((1, 0)\), Derivative], MultilineFunction->None], "[", \(x1, x2\), "]"}], "2"]}], "-", RowBox[{ RowBox[{ SuperscriptBox["k", "\[Prime]", MultilineFunction->None], "[", \(y1[x1, x2]\), "]"}], " ", RowBox[{ SuperscriptBox["y1", TagBox[\((2, 0)\), Derivative], MultilineFunction->None], "[", \(x1, x2\), "]"}]}]}], ",", RowBox[{\(-2\), " ", RowBox[{ SuperscriptBox["k", "\[Prime]", MultilineFunction->None], "[", \(y1[x1, x2]\), "]"}], " ", RowBox[{ SuperscriptBox["y1", TagBox[\((1, 0)\), Derivative], MultilineFunction->None], "[", \(x1, x2\), "]"}]}], ",", "1", ",", \(-k[y1[x1, x2]]\), ",", "0", ",", "0"}], "}"}]], "Output"] }, Open ]], Cell[CellGroupData[{ Cell[TextData[StyleBox["The program expresses the determining equations in \ terms of zvariables. Here is the correspondence between z-variables and \ conventional variables.", FontWeight->"Plain"]], "Text", ImageRegion->{{0, 1}, {0, 1}}], Cell[BoxData[ \(ztableofrules\)], "Input"], Cell[BoxData[ \({z1 \[Rule] x, z2 \[Rule] t, z3 \[Rule] u[x, t]}\)], "Output"] }, Open ]], Cell[CellGroupData[{ Cell[TextData[StyleBox["Here are the determining equations expressed in terms \ of z-variables. The equations in the table can be distinguished by the == 0 \ at the end of each item.", FontWeight->"Plain"]], "Text", ImageRegion->{{0, 1}, {0, 1}}], Cell[BoxData[ \(zdeterminingequations\)], "Input"], Cell[BoxData[ \({"-(eta1[z1, z2, z3]*Derivative[2][k][z3]) - \ Derivative[1][k][z3]*Derivative[0, 0, 1][eta1][z1, z2, z3] - \ k[z3]*Derivative[0, 0, 2][eta1][z1, z2, z3] - \ Derivative[1][k][z3]*Derivative[0, 1, 0][xse2][z1, z2, z3] + \ 2*Derivative[1][k][z3]*Derivative[1, 0, 0][xse1][z1, z2, z3] + \ 2*k[z3]*Derivative[1, 0, 1][xse1][z1, z2, z3] + \ k[z3]*Derivative[1][k][z3]*Derivative[2, 0, 0][xse2][z1, z2, z3] == 0", "-(eta1[z1, z2, z3]*Derivative[1][k][z3]) - k[z3]*Derivative[0, 1, \ 0][xse2][z1, z2, z3] + 2*k[z3]*Derivative[1, 0, 0][xse1][z1, z2, z3] + \ k[z3]^2*Derivative[2, 0, 0][xse2][z1, z2, z3] == 0", "Derivative[1][k][z3]*Derivative[0, 0, 1][xse1][z1, z2, z3] + \ k[z3]*Derivative[0, 0, 2][xse1][z1, z2, z3] + \ 2*Derivative[1][k][z3]^2*Derivative[1, 0, 0][xse2][z1, z2, z3] + \ 2*k[z3]*Derivative[1][k][z3]*Derivative[1, 0, 1][xse2][z1, z2, z3] == 0", "2*k[z3]*Derivative[0, 0, 1][xse1][z1, z2, z3] + \ 2*k[z3]*Derivative[1][k][z3]*Derivative[1, 0, 0][xse2][z1, z2, z3] + \ 2*k[z3]^2*Derivative[1, 0, 1][xse2][z1, z2, z3] == 0", "Derivative[1][k][z3]^2*Derivative[0, 0, 1][xse2][z1, z2, z3] + \ k[z3]*Derivative[1][k][z3]*Derivative[0, 0, 2][xse2][z1, z2, z3] == 0", "2*k[z3]*Derivative[0, 0, 1][xse2][z1, z2, z3] == 0", "k[z3]*Derivative[1][k][z3]*Derivative[0, 0, 1][xse2][z1, z2, z3] + \ k[z3]^2*Derivative[0, 0, 2][xse2][z1, z2, z3] == 0", "Derivative[0, 1, 0][eta1][z1, z2, z3] - k[z3]*Derivative[2, 0, \ 0][eta1][z1, z2, z3] == 0", "-Derivative[0, 1, 0][xse1][z1, z2, z3] - \ 2*Derivative[1][k][z3]*Derivative[1, 0, 0][eta1][z1, z2, z3] - \ 2*k[z3]*Derivative[1, 0, 1][eta1][z1, z2, z3] + k[z3]*Derivative[2, 0, \ 0][xse1][z1, z2, z3] == 0", "2*k[z3]*Derivative[1, 0, 0][xse2][z1, z2, z3] == 0"}\)], "Output"] }, Open ]], Cell[CellGroupData[{ Cell[BoxData[ \(TraditionalForm[\[IndentingNewLine]ColumnForm[ ToExpression[zdeterminingequations], Left, Below]]\)], "Input"], Cell[BoxData[ FormBox[ InterpretationBox[GridBox[{ { RowBox[{ RowBox[{ RowBox[{\(-\(eta1(z1, z2, z3)\)\), " ", RowBox[{ SuperscriptBox["k", "\[Prime]\[Prime]", MultilineFunction->None], "(", "z3", ")"}]}], "-", RowBox[{ RowBox[{ SuperscriptBox["k", "\[Prime]", MultilineFunction->None], "(", "z3", ")"}], " ", RowBox[{ SuperscriptBox["eta1", TagBox[\((0, 0, 1)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}]}], "-", RowBox[{\(k(z3)\), " ", RowBox[{ SuperscriptBox["eta1", TagBox[\((0, 0, 2)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}]}], "-", RowBox[{ RowBox[{ SuperscriptBox["k", "\[Prime]", MultilineFunction->None], "(", "z3", ")"}], " ", RowBox[{ SuperscriptBox["xse2", TagBox[\((0, 1, 0)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}]}], "+", RowBox[{"2", " ", RowBox[{ SuperscriptBox["k", "\[Prime]", MultilineFunction->None], "(", "z3", ")"}], " ", RowBox[{ SuperscriptBox["xse1", TagBox[\((1, 0, 0)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}]}], "+", RowBox[{"2", " ", \(k(z3)\), " ", RowBox[{ SuperscriptBox["xse1", TagBox[\((1, 0, 1)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}]}], "+", RowBox[{\(k(z3)\), " ", RowBox[{ SuperscriptBox["k", "\[Prime]", MultilineFunction->None], "(", "z3", ")"}], " ", RowBox[{ SuperscriptBox["xse2", TagBox[\((2, 0, 0)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}]}]}], "==", "0"}]}, { RowBox[{ RowBox[{ RowBox[{ RowBox[{ SuperscriptBox["xse2", TagBox[\((2, 0, 0)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}], " ", \(\(k(z3)\)\^2\)}], "-", RowBox[{ RowBox[{ SuperscriptBox["xse2", TagBox[\((0, 1, 0)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}], " ", \(k(z3)\)}], "+", RowBox[{"2", " ", RowBox[{ SuperscriptBox["xse1", TagBox[\((1, 0, 0)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}], " ", \(k(z3)\)}], "-", RowBox[{\(eta1(z1, z2, z3)\), " ", RowBox[{ SuperscriptBox["k", "\[Prime]", MultilineFunction->None], "(", "z3", ")"}]}]}], "==", "0"}]}, { RowBox[{ RowBox[{ RowBox[{"2", " ", RowBox[{ SuperscriptBox["xse2", TagBox[\((1, 0, 0)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}], " ", SuperscriptBox[ RowBox[{ SuperscriptBox["k", "\[Prime]", MultilineFunction->None], "(", "z3", ")"}], "2"]}], "+", RowBox[{ RowBox[{ SuperscriptBox["xse1", TagBox[\((0, 0, 1)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}], " ", RowBox[{ SuperscriptBox["k", "\[Prime]", MultilineFunction->None], "(", "z3", ")"}]}], "+", RowBox[{"2", " ", \(k(z3)\), " ", RowBox[{ SuperscriptBox["xse2", TagBox[\((1, 0, 1)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}], " ", RowBox[{ SuperscriptBox["k", "\[Prime]", MultilineFunction->None], "(", "z3", ")"}]}], "+", RowBox[{\(k(z3)\), " ", RowBox[{ SuperscriptBox["xse1", TagBox[\((0, 0, 2)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}]}]}], "==", "0"}]}, { RowBox[{ RowBox[{ RowBox[{"2", " ", RowBox[{ SuperscriptBox["xse2", TagBox[\((1, 0, 1)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}], " ", \(\(k(z3)\)\^2\)}], "+", RowBox[{"2", " ", RowBox[{ SuperscriptBox["xse1", TagBox[\((0, 0, 1)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}], " ", \(k(z3)\)}], "+", RowBox[{"2", " ", RowBox[{ SuperscriptBox["k", "\[Prime]", MultilineFunction->None], "(", "z3", ")"}], " ", RowBox[{ SuperscriptBox["xse2", TagBox[\((1, 0, 0)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}], " ", \(k(z3)\)}]}], "==", "0"}]}, { RowBox[{ RowBox[{ RowBox[{ RowBox[{ SuperscriptBox["xse2", TagBox[\((0, 0, 1)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}], " ", SuperscriptBox[ RowBox[{ SuperscriptBox["k", "\[Prime]", MultilineFunction->None], "(", "z3", ")"}], "2"]}], "+", RowBox[{\(k(z3)\), " ", RowBox[{ SuperscriptBox["xse2", TagBox[\((0, 0, 2)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}], " ", RowBox[{ SuperscriptBox["k", "\[Prime]", MultilineFunction->None], "(", "z3", ")"}]}]}], "==", "0"}]}, { RowBox[{ RowBox[{"2", " ", \(k(z3)\), " ", RowBox[{ SuperscriptBox["xse2", TagBox[\((0, 0, 1)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}]}], "==", "0"}]}, { RowBox[{ RowBox[{ RowBox[{ RowBox[{ SuperscriptBox["xse2", TagBox[\((0, 0, 2)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}], " ", \(\(k(z3)\)\^2\)}], "+", RowBox[{ RowBox[{ SuperscriptBox["k", "\[Prime]", MultilineFunction->None], "(", "z3", ")"}], " ", RowBox[{ SuperscriptBox["xse2", TagBox[\((0, 0, 1)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}], " ", \(k(z3)\)}]}], "==", "0"}]}, { RowBox[{ RowBox[{ RowBox[{ SuperscriptBox["eta1", TagBox[\((0, 1, 0)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}], "-", RowBox[{\(k(z3)\), " ", RowBox[{ SuperscriptBox["eta1", TagBox[\((2, 0, 0)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}]}]}], "==", "0"}]}, { RowBox[{ RowBox[{ RowBox[{"-", RowBox[{ SuperscriptBox["xse1", TagBox[\((0, 1, 0)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}]}], "-", RowBox[{"2", " ", RowBox[{ SuperscriptBox["k", "\[Prime]", MultilineFunction->None], "(", "z3", ")"}], " ", RowBox[{ SuperscriptBox["eta1", TagBox[\((1, 0, 0)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}]}], "-", RowBox[{"2", " ", \(k(z3)\), " ", RowBox[{ SuperscriptBox["eta1", TagBox[\((1, 0, 1)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}]}], "+", RowBox[{\(k(z3)\), " ", RowBox[{ SuperscriptBox["xse1", TagBox[\((2, 0, 0)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}]}]}], "==", "0"}]}, { RowBox[{ RowBox[{"2", " ", \(k(z3)\), " ", RowBox[{ SuperscriptBox["xse2", TagBox[\((1, 0, 0)\), Derivative], MultilineFunction->None], "(", \(z1, z2, z3\), ")"}]}], "==", "0"}]} }, GridBaseline->Top, ColumnAlignments->{Left}], ColumnForm[ { Equal[ Plus[ Times[ -1, eta1[ z1, z2, z3], Derivative[ 2][ k][ z3]], Times[ -1, Derivative[ 1][ k][ z3], Derivative[ 0, 0, 1][ eta1][ z1, z2, z3]], Times[ -1, k[ z3], Derivative[ 0, 0, 2][ eta1][ z1, z2, z3]], Times[ -1, Derivative[ 1][ k][ z3], Derivative[ 0, 1, 0][ xse2][ z1, z2, z3]], Times[ 2, Derivative[ 1][ k][ z3], Derivative[ 1, 0, 0][ xse1][ z1, z2, z3]], Times[ 2, k[ z3], Derivative[ 1, 0, 1][ xse1][ z1, z2, z3]], Times[ k[ z3], Derivative[ 1][ k][ z3], Derivative[ 2, 0, 0][ xse2][ z1, z2, z3]]], 0], Equal[ Plus[ Times[ -1, eta1[ z1, z2, z3], Derivative[ 1][ k][ z3]], Times[ -1, k[ z3], Derivative[ 0, 1, 0][ xse2][ z1, z2, z3]], Times[ 2, k[ z3], Derivative[ 1, 0, 0][ xse1][ z1, z2, z3]], Times[ Power[ k[ z3], 2], Derivative[ 2, 0, 0][ xse2][ z1, z2, z3]]], 0], Equal[ Plus[ Times[ Derivative[ 1][ k][ z3], Derivative[ 0, 0, 1][ xse1][ z1, z2, z3]], Times[ k[ z3], Derivative[ 0, 0, 2][ xse1][ z1, z2, z3]], Times[ 2, Power[ Derivative[ 1][ k][ z3], 2], Derivative[ 1, 0, 0][ xse2][ z1, z2, z3]], Times[ 2, k[ z3], Derivative[ 1][ k][ z3], Derivative[ 1, 0, 1][ xse2][ z1, z2, z3]]], 0], Equal[ Plus[ Times[ 2, k[ z3], Derivative[ 0, 0, 1][ xse1][ z1, z2, z3]], Times[ 2, k[ z3], Derivative[ 1][ k][ z3], Derivative[ 1, 0, 0][ xse2][ z1, z2, z3]], Times[ 2, Power[ k[ z3], 2], Derivative[ 1, 0, 1][ xse2][ z1, z2, z3]]], 0], Equal[ Plus[ Times[ Power[ Derivative[ 1][ k][ z3], 2], Derivative[ 0, 0, 1][ xse2][ z1, z2, z3]], Times[ k[ z3], Derivative[ 1][ k][ z3], Derivative[ 0, 0, 2][ xse2][ z1, z2, z3]]], 0], Equal[ Times[ 2, k[ z3], Derivative[ 0, 0, 1][ xse2][ z1, z2, z3]], 0], Equal[ Plus[ Times[ k[ z3], Derivative[ 1][ k][ z3], Derivative[ 0, 0, 1][ xse2][ z1, z2, z3]], Times[ Power[ k[ z3], 2], Derivative[ 0, 0, 2][ xse2][ z1, z2, z3]]], 0], Equal[ Plus[ Derivative[ 0, 1, 0][ eta1][ z1, z2, z3], Times[ -1, k[ z3], Derivative[ 2, 0, 0][ eta1][ z1, z2, z3]]], 0], Equal[ Plus[ Times[ -1, Derivative[ 0, 1, 0][ xse1][ z1, z2, z3]], Times[ -2, Derivative[ 1][ k][ z3], Derivative[ 1, 0, 0][ eta1][ z1, z2, z3]], Times[ -2, k[ z3], Derivative[ 1, 0, 1][ eta1][ z1, z2, z3]], Times[ k[ z3], Derivative[ 2, 0, 0][ xse1][ z1, z2, z3]]], 0], Equal[ Times[ 2, k[ z3], Derivative[ 1, 0, 0][ xse2][ z1, z2, z3]], 0]}, Left, Below], Editable->False], TraditionalForm]], "Output"] }, Open ]], Cell["\<\ Now solve the determining equations in terms of multivariable \ polynomials of a selected order. The Mathematica function Solve uses Gaussian \ elimination to solve a large number of linear equations for the polynomial \ coefficients. The time roughly follows time/timeref=((number of equations)/(number of equationsref))^n where the exponent is between 2.4 and 2.7. The Mathematica function Timing \ outputs the time required for the SolveDeterminingEquations function to \ execute.\ \>", "Text"], Cell[CellGroupData[{ Cell[BoxData[ \(Timing[ SolveDeterminingEquations[independentvariables, dependentvariables, rorder, xseon, zdeterminingequations, order = 3]]\)], "Input"], Cell[BoxData[ InterpretationBox["\<\"The number of unknown polynomial coefficients = \ \\!\\(60\\)\"\>", StringForm[ "The number of unknown polynomial coefficients = ``", 60], Editable->False]], "Print"], Cell[BoxData[ InterpretationBox["\<\"The number of equations for the polynomial \ coefficients = \\!\\(119\\)\"\>", StringForm[ "The number of equations for the polynomial coefficients = ``", 119], Editable->False]], "Print"], Cell[BoxData[ \("SolveDeterminingEquations has finished executing. You can look at the \ output in the tables xsefunctions and etafunctions. Each entry in these \ tables is an infinitesimal function in string format expressed in terms of \ z-variables and the group parameters. The output can also be viewed with the \ group parameters stripped away by looking at the table infinitesimalgroups. \ In either case you may wish to convert the z-variables to conventional \ variables using the table ztableofrules. Keep in mind that this function \ only finds solutions of the determining equations that are of algebraic form. \ The determining equations may admit solutions that involve transcendental \ functions and/or integrals. Note that arbitrary functions may appear in the \ infinitesimals and that these can be detected by running the package function \ SolveDeterminingEquations for several polynomial orders. If terms of ever \ increasing order appear, then an arbitrary function is indicated."\)], "Print"], Cell[BoxData[ \({0.7`\ Second, Null}\)], "Output"] }, Open ]], Cell[CellGroupData[{ Cell[BoxData[ \(infinitesimalgroupsxy = infinitesimalgroups /. {z1 \[Rule] x, z2 \[Rule] t, z3 \[Rule] u}\)], "Input"], Cell[BoxData[ \({{{1, 0}, {0}}, {{0, 1}, {0}}, {{x\/2, t}, {0}}}\)], "Output"] }, Open ]], Cell[CellGroupData[{ Cell[BoxData[ \(ColumnForm[infinitesimalgroupsxy]\)], "Input"], Cell[BoxData[ InterpretationBox[GridBox[{ {\({{1, 0}, {0}}\)}, {\({{0, 1}, {0}}\)}, {\({{x\/2, t}, {0}}\)} }, GridBaseline->{Baseline, {1, 1}}, ColumnAlignments->{Left}], ColumnForm[ {{{1, 0}, {0}}, {{0, 1}, {0}}, {{ Times[ Rational[ 1, 2], x], t}, {0}}}], Editable->False]], "Output"] }, Open ]], Cell[CellGroupData[{ Cell[BoxData[ \(MakeCommutatorTable[independentvariables, dependentvariables, infinitesimalgroupsxy]\)], "Input"], Cell[BoxData[ \("MakeCommutatorTable has finished executing. You can look at the output \ in the table commutatortable. To present the output in the most readable form \ you may want view it as a matrix using MatrixForm[commutatortable]. \ Occasionally the entries in the commutatortable will have terms that cancel. \ To get rid of these terms use the function Simplify before viewing the \ table."\)], "Print"] }, Open ]], Cell[CellGroupData[{ Cell[BoxData[ \(MatrixForm[commutatortable]\)], "Input"], Cell[BoxData[ InterpretationBox[ RowBox[{"(", "\[NoBreak]", GridBox[{ { RowBox[{"(", "\[NoBreak]", GridBox[{ {\({0, 0}\)}, {\({0}\)} }], "\[NoBreak]", ")"}], RowBox[{"(", "\[NoBreak]", GridBox[{ {\({0, 0}\)}, {\({0}\)} }], "\[NoBreak]", ")"}], RowBox[{"(", "\[NoBreak]", GridBox[{ {\({1\/2, 0}\)}, {\({0}\)} }], "\[NoBreak]", ")"}]}, { RowBox[{"(", "\[NoBreak]", GridBox[{ {\({0, 0}\)}, {\({0}\)} }], "\[NoBreak]", ")"}], RowBox[{"(", "\[NoBreak]", GridBox[{ {\({0, 0}\)}, {\({0}\)} }], "\[NoBreak]", ")"}], RowBox[{"(", "\[NoBreak]", GridBox[{ {\({0, 1}\)}, {\({0}\)} }], "\[NoBreak]", ")"}]}, { RowBox[{"(", "\[NoBreak]", GridBox[{ {\({\(-\(1\/2\)\), 0}\)}, {\({0}\)} }], "\[NoBreak]", ")"}], RowBox[{"(", "\[NoBreak]", GridBox[{ {\({0, \(-1\)}\)}, {\({0}\)} }], "\[NoBreak]", ")"}], RowBox[{"(", "\[NoBreak]", GridBox[{ {\({0, 0}\)}, {\({0}\)} }], "\[NoBreak]", ")"}]} }], "\[NoBreak]", ")"}], MatrixForm[ {{{{0, 0}, {0}}, {{0, 0}, {0}}, {{ Rational[ 1, 2], 0}, {0}}}, {{{0, 0}, {0}}, {{0, 0}, {0}}, {{0, 1}, { 0}}}, {{{ Rational[ -1, 2], 0}, {0}}, {{0, -1}, {0}}, {{0, 0}, { 0}}}}]]], "Output"] }, Open ]], Cell[CellGroupData[{ Cell[BoxData[ \(MaxMemoryUsed[\ ]\)], "Input"], Cell[BoxData[ \(8424108\)], "Output"] }, Open ]] }, FrontEndVersion->"4.0 for Macintosh", ScreenRectangle->{{0, 1024}, {0, 748}}, WindowToolbars->{}, CellGrouping->Manual, WindowSize->{717, 674}, WindowMargins->{{Automatic, 99}, {Automatic, 17}}, PrintingCopies->1, PrintingPageRange->{1, Automatic}, PrivateNotebookOptions->{"ColorPalette"->{RGBColor, -1}}, ShowCellLabel->True, ShowCellTags->False, RenderingOptions->{"ObjectDithering"->True, "RasterDithering"->False}, Magnification->1.25, StyleDefinitions -> "Default.nb", MacintoshSystemPageSetup->"\<\ 0080009H0UP0000068dB`?oHofXIX1=F;B<5:0?l00;m009H0UP0000068dB`0B` 02d5X5k/02H80@4101P00BL?00400CZiCX0000000000P0010000020D00000000 000000?l1BP00000000004T400002004\>" ] (*********************************************************************** Cached data follows. If you edit this Notebook file directly, not using Mathematica, you must remove the line containing CacheID at the top of the file. The cache data will then be recreated when you save this file from within Mathematica. ***********************************************************************) (*CellTagsOutline CellTagsIndex->{} *) (*CellTagsIndex CellTagsIndex->{} *) (*NotebookFileOutline Notebook[{ Cell[1717, 49, 340, 6, 149, "Text"], Cell[2060, 57, 87, 3, 36, "Text"], Cell[2150, 62, 52, 1, 33, "Input"], Cell[2205, 65, 203, 3, 55, "Text"], Cell[2411, 70, 79, 1, 33, "Input"], Cell[2493, 73, 165, 3, 36, "Text"], Cell[2661, 78, 128, 3, 52, "Input"], Cell[2792, 83, 259, 4, 55, "Text"], Cell[3054, 89, 145, 3, 71, "Input"], Cell[3202, 94, 132, 2, 36, "Text"], Cell[3337, 98, 79, 1, 33, "Input"], Cell[3419, 101, 130, 2, 36, "Text"], Cell[3552, 105, 68, 1, 33, "Input"], Cell[3623, 108, 230, 4, 55, "Text"], Cell[3856, 114, 61, 1, 33, "Input"], Cell[3920, 117, 154, 3, 36, "Text"], Cell[4077, 122, 48, 1, 33, "Input"], Cell[4128, 125, 387, 6, 74, "Text"], Cell[4518, 133, 48, 1, 33, "Input"], Cell[4569, 136, 511, 7, 93, "Text"], Cell[5083, 145, 47, 1, 33, "Input"], Cell[5133, 148, 578, 8, 112, "Text"], Cell[5714, 158, 55, 1, 33, "Input"], Cell[5772, 161, 270, 4, 55, "Text"], Cell[CellGroupData[{ Cell[6067, 169, 210, 3, 71, "Input"], Cell[6280, 174, 920, 13, 294, "Print"] }, Open ]], Cell[CellGroupData[{ Cell[7237, 192, 57, 1, 33, "Input"], Cell[7297, 195, 120, 2, 52, "Output"] }, Open ]], Cell[CellGroupData[{ Cell[7454, 202, 52, 1, 33, "Input"], Cell[7509, 205, 1345, 35, 63, "Output"] }, Open ]], Cell[CellGroupData[{ Cell[8891, 245, 242, 4, 55, "Text"], Cell[9136, 251, 46, 1, 33, "Input"], Cell[9185, 254, 82, 1, 33, "Output"] }, Open ]], Cell[CellGroupData[{ Cell[9304, 260, 250, 4, 55, "Text"], Cell[9557, 266, 54, 1, 33, "Input"], Cell[9614, 269, 1802, 29, 584, "Output"] }, Open ]], Cell[CellGroupData[{ Cell[11453, 303, 138, 2, 52, "Input"], Cell[11594, 307, 16061, 395, 276, "Output"] }, Open ]], Cell[27670, 705, 510, 11, 169, "Text"], Cell[CellGroupData[{ Cell[28205, 720, 173, 3, 71, "Input"], Cell[28381, 725, 219, 4, 28, "Print"], Cell[28603, 731, 248, 5, 28, "Print"], Cell[28854, 738, 1020, 13, 332, "Print"], Cell[29877, 753, 54, 1, 33, "Output"] }, Open ]], Cell[CellGroupData[{ Cell[29968, 759, 140, 3, 33, "Input"], Cell[30111, 764, 82, 1, 48, "Output"] }, Open ]], Cell[CellGroupData[{ Cell[30230, 770, 66, 1, 33, "Input"], Cell[30299, 773, 376, 11, 80, "Output"] }, Open ]], Cell[CellGroupData[{ Cell[30712, 789, 124, 2, 52, "Input"], Cell[30839, 793, 416, 6, 123, "Print"] }, Open ]], Cell[CellGroupData[{ Cell[31292, 804, 60, 1, 33, "Input"], Cell[31355, 807, 1866, 47, 165, "Output"] }, Open ]], Cell[CellGroupData[{ Cell[33258, 859, 50, 1, 33, "Input"], Cell[33311, 862, 41, 1, 33, "Output"] }, Open ]] } ] *) (*********************************************************************** End of Mathematica Notebook file. ***********************************************************************)