Skip to main content

Problem of `Integrate` and `DSolve` with inhomogeneous Legendre differential equation


I have the following inhomogeneous Legendre differential equation $(m=n=2)$:


 deq=(6 - 4/(1 - z^2)) h2[z] - 
2 z Derivative[1][h2][z] + (1 - z^2) Derivative[2][h2][z] == (
6 (-1 + z + z^2) μ^2)/(M^4 (-1 + z^2)^2) + (

3 μ^2 Log[(-1 + z)/(1 + z)])/(M^4 (-1 + z))

where the variable $z>1$. I can not get Mathematica to give me the simplest/correct solutions. I think it has to do with those logarithms. I know that the homogeneous solution is


solH=A*LegendreQ[2,2,3,z]+B*LegendreP[2,2,3,z]

I need mathematica's type 3 Legendre functions because for $z>1$ the type 3 functions are on the right branch. With DSolve however I can only get the expanded forms of type 1:


DSolve[deq[[1]] == 0, h2[z], z]

gives back


 {h2[z] -> -3 (-1 + z^2) C[1] + C[2] (((1 - z^2) (5 z - 3 z^3))/(-1 + z^2)^2 + 

3 (1 - z^2) (-(1/2) Log[1 - z] + 1/2 Log[1 + z]))}

which is not real for $z>1$. Is there a way to tell DSolve to work with $z>1$ or to search for real solutions under that assumption? $Assumptions={z>1} alone does not do the trick.


Apart from that I have a bigger problem with the particular solution: DSolve[deq, h2[z], z][[1]] gives a ridiculous partial solution which is incredibly long and complex. I want a real particular solution; I want a solution that is real for all $z>1$. I know from literature that there is one (plugging that one in proves that it is indeed one):


{h2p[z] -> -3 μ^2/(16 M^4) (6 z^2 + 3 z - 6 - (4 z^2 + 2 z)/(z^2 - 1)) - 3 μ^2/(32 M^4) (3 z^2 - 8 z - 3 - 8/(z^2 - 1)) Log[(z - 1)/(z + 1)] + 3 μ^2/(16 M^4) (z^2 - 1) Log[(z - 1)/(z + 1)]^2}

Again is there a way to tell DSolve to produce a real solution for $z>1$? I also tried constructing that particular solution using the Variation of Parameters method


WLQ223LP223 = 
Wronskian[{LegendreQ[2, 2, 3, z], LegendreP[2, 2, 3, z]}, z]
-LegendreQ[2, 2, 3, z]*

Integrate[deq[[2]]*LegendreP[2, 2, 3, z]/WLQ223LP223, z] +
LegendreP[2, 2, 3, z]*
Integrate[deq[[2]]*LegendreQ[2, 2, 3, z]/WLQ223LP223, z] //
FunctionExpand // Simplify

Mathematica finds an analytical solutions but they do not reduce to the particular solution I want: the involved integrals become very lengthy and again complex.


Anyone around here who has some experience with such differential equations in Mathematica?


I send the problem to a friend who has Maple and Maple's dsolve finds the "correct"/simple partial solution, when one prepends assume(z > 1). It does so using the Variation of Parameters method and the solutions of the homogeneous equation.



Answer



Personally, I prefer @corey979's approach (+1), but with the following tweaks.



solExpr = 
Assuming[z > 1 && M ∈ Reals && μ ∈ Reals,
DSolveValue[deq, h2[z], z] /. {Log[-1 + z^2] -> Log[-1 + z] + Log[1 + z],
Log[(-1 + z)/(1 + z)] -> Log[-1 + z] - Log[1 + z]} // Re //
ComplexExpand[#, TargetFunctions -> {Re, Im}] & // Simplify
];

sol = h2 -> Function @@ {z, solExpr}

Mathematica graphics



deq /. sol // Simplify[#, z > 1 && M ∈ Reals && μ ∈ Reals] &
(* True *)

Plot[h2[z] /. sol /. {M -> 1, μ -> 1, C[1] -> -1, C[2] -> 1},
{z, 1, 5}]

Mathematica graphics


The main tweaks are including all assumptions to make all parameters real in both DSolve and Simplify and the use of TargetFunctions. It's also easier to simplify an algebraic expression; hence DSolveValue[]. The rules


{Log[-1 + z^2] -> Log[-1 + z] + Log[1 + z], 
Log[(-1 + z)/(1 + z)] -> Log[-1 + z] - Log[1 + z]}


help with simplification; they are not important and may be omitted.


The main reason I prefer this is that the real and imaginary parts are independently solutions of a real ODE, a key point made by corey979. It just seems a simpler approach, when it simplifies down nicely. In this case it does, and we get a general solution that spans the solution space.


Comments

Popular posts from this blog

front end - keyboard shortcut to invoke Insert new matrix

I frequently need to type in some matrices, and the menu command Insert > Table/Matrix > New... allows matrices with lines drawn between columns and rows, which is very helpful. I would like to make a keyboard shortcut for it, but cannot find the relevant frontend token command (4209405) for it. Since the FullForm[] and InputForm[] of matrices with lines drawn between rows and columns is the same as those without lines, it's hard to do this via 3rd party system-wide text expanders (e.g. autohotkey or atext on mac). How does one assign a keyboard shortcut for the menu item Insert > Table/Matrix > New... , preferably using only mathematica? Thanks! Answer In the MenuSetup.tr (for linux located in the $InstallationDirectory/SystemFiles/FrontEnd/TextResources/X/ directory), I changed the line MenuItem["&New...", "CreateGridBoxDialog"] to read MenuItem["&New...", "CreateGridBoxDialog", MenuKey["m", Modifiers-...

How to thread a list

I have data in format data = {{a1, a2}, {b1, b2}, {c1, c2}, {d1, d2}} Tableform: I want to thread it to : tdata = {{{a1, b1}, {a2, b2}}, {{a1, c1}, {a2, c2}}, {{a1, d1}, {a2, d2}}} Tableform: And I would like to do better then pseudofunction[n_] := Transpose[{data2[[1]], data2[[n]]}]; SetAttributes[pseudofunction, Listable]; Range[2, 4] // pseudofunction Here is my benchmark data, where data3 is normal sample of real data. data3 = Drop[ExcelWorkBook[[Column1 ;; Column4]], None, 1]; data2 = {a #, b #, c #, d #} & /@ Range[1, 10^5]; data = RandomReal[{0, 1}, {10^6, 4}]; Here is my benchmark code kptnw[list_] := Transpose[{Table[First@#, {Length@# - 1}], Rest@#}, {3, 1, 2}] &@list kptnw2[list_] := Transpose[{ConstantArray[First@#, Length@# - 1], Rest@#}, {3, 1, 2}] &@list OleksandrR[list_] := Flatten[Outer[List, List@First[list], Rest[list], 1], {{2}, {1, 4}}] paradox2[list_] := Partition[Riffle[list[[1]], #], 2] & /@ Drop[list, 1] RM[list_] := FoldList[Transpose[{First@li...

plotting - How to draw lines between specified dots on ListPlot?

I would like to create a plot where I have unconnected dots and some connected. So far, I have figured out how to draw the dots. My code is the following: ListPlot[{{1, 1}, {2, 2}, {3, 3}, {4, 4}, {1, 4}, {2, 5}, {3, 6}, {4, 7}, {1, 7}, {2, 8}, {3, 9}, {4, 10}, {1, 10}, {2, 11}, {3, 12}, {4,13}, {2.5, 7}}, Ticks -> {{1, 2, 3, 4}, None}, AxesStyle -> Thin, TicksStyle -> Directive[Black, Bold, 12], Mesh -> Full] I have thought using ListLinePlot command, but I don't know how to specify to the command to draw only selected lines between the dots. Do have any suggestions/hints on how to do that? Thank you. Answer One possibility would be to use Epilog with Line : ListPlot[ {{1, 1}, {2, 2}, {3, 3}, {4, 4}, {1, 4}, {2, 5}, {3, 6}, {4, 7}, {1, 7}, {2, 8}, {3, 9}, {4, 10}, {1, 10}, {2, 11}, {3, 12}, {4, 13}, {2.5, 7}}, Ticks -> {{1, 2, 3, 4}, None}, AxesStyle -> Thin, TicksStyle -> Directive[Black, Bold, 12], Mesh -> Full, Epilog -> { Line[ ...