using NDEigensystem to solve the Mathieu equation Announcing the arrival of Valued Associate #679: Cesar Manara Unicorn Meta Zoo #1: Why another podcast?How to correctly use DSolve when the force is an impulse (dirac delta) and initial conditions are not zeroIndexing of Large Autonomous System of Equations for Use in NDSolveSolve Laplace equation using NDSolveFEM Solution desired for “Plate with orifice” deflection: Application of Boundary Conditions and use of RegionsSolving an ODE using shooting methodHow to rescale the independent variable?Trouble with shooting method for a 4th-order stiff ODEFinding eigenvalues for Laplacian operator for 3D shape with Neumann boundary conditionsHow do you find the eigenvalues of a PDE (Dynamic Euler-Bernoulli beam)?Using NDEigensystem to solve coupled eigenvalue problem
My admission is revoked after accepting the admission offer
 
 Is it appropriate to mention a relatable company blog post when you're asked about the company?
 
 How long can a nation maintain a technological edge over the rest of the world?
 
 Where to find documentation for `whois` command options?
 
 Bright yellow or light yellow?
 
 How to translate "red flag" into Spanish?
 
 Is it OK if I do not take the receipt in Germany?
 
 Why isn't everyone flabbergasted about Bran's "gift"?
 
 Putting Ant-Man on house arrest
 
 How was Lagrange appointed professor of mathematics so early?
 
 Suing a Police Officer Instead of the Police Department
 
 Does Prince Arnaud cause someone holding the Princess to lose?
 
 "Working on a knee"
 
 Why do people think Winterfell crypts is the safest place for women, children and old people?
 
 Writing a T-SQL stored procedure to receive 4 numbers and insert them into a table
 
 How can I wire a 9-position switch so that each position turns on one more LED than the one before?
 
 Like totally amazing interchangeable sister outfit accessory swapping or whatever
 
 How did Elite on the NES work?
 
 What was Apollo 13's "Little Jolt" after MECO?
 
 Why is arima in R one time step off?
 
 Could a cockatrice have parasitic embryos?
 
 Processing ADC conversion result: DMA vs Processor Registers
 
 Philosophers who were composers?
 
 In search of the origins of term censor, I hit a dead end stuck with the greek term, to censor, λογοκρίνω
using NDEigensystem to solve the Mathieu equation
Announcing the arrival of Valued Associate #679: Cesar Manara
Unicorn Meta Zoo #1: Why another podcast?How to correctly use DSolve when the force is an impulse (dirac delta) and initial conditions are not zeroIndexing of Large Autonomous System of Equations for Use in NDSolveSolve Laplace equation using NDSolveFEM Solution desired for “Plate with orifice” deflection: Application of Boundary Conditions and use of RegionsSolving an ODE using shooting methodHow to rescale the independent variable?Trouble with shooting method for a 4th-order stiff ODEFinding eigenvalues for Laplacian operator for 3D shape with Neumann boundary conditionsHow do you find the eigenvalues of a PDE (Dynamic Euler-Bernoulli beam)?Using NDEigensystem to solve coupled eigenvalue problem
$begingroup$
To be able to apply the differentialequation capabilities of Mathematica to my graduate thesis, I am trying to apply NDEigensystem to an eigenproblem whose solution I know, but I am having some trouble doing so.
As a test problem, I am using an algebraic version of the Mathieu equation,
$$(1-zeta^2)w^primeprime-zeta w^prime+left(a+2q-4qzeta^2right)w=0$$
For this example I set $q=4/3$ and take only the first three eigenpairs:
m = 3; q = 4/3;
op = -(1 - ζ^2) u''[ζ] + ζ u'[ζ] + 2 q (2 ζ^2 - 1) u[ζ];
bc = DirichletCondition[u[ζ] == 0, True];
λ, fl = NDEigensystem[op, bc, u, ζ, 0, 1, m];
I chose the Mathieu equation as a nontrivial example as Mathematica already has a function for it's evaluation:
λt = Table[MathieuCharacteristicB[2 k, q], k, m];
flt = Table[With[j = j,
MathieuS[MathieuCharacteristicB[2 k, q], q, ArcCos[#]] &], k, m];
The problem is, I do not get the expected eigenvalues!
λ
(* 4.0708, 17.3259, 39.1877 *)
N[λt]
(* 3.85298, 16.0581, 36.0254 *)
And of course, plotting shows that the eigenequation is not satisfied at all:
With[u = fl[[1]], b = λ[[1]],
 Plot[(1 - ζ^2) u''[ζ] - ζ u'[ζ] + (b + 2 q - 4 q ζ^2) u[ζ], ζ, 0, 1]]
With[u = flt[[1]], b = λt[[1]],
 Plot[(1 - ζ^2) u''[ζ] - ζ u'[ζ] + (b + 2 q - 4 q ζ^2) u[ζ], ζ, 0, 1]]
What was wrong with my attempt? If I can get this example to work, I should be able to apply it to my actual, more complicated problem, so any Good Ideas would be welcome.
differential-equations finite-element-method
New contributor
宮川園子 is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.
$endgroup$
add a comment |
$begingroup$
To be able to apply the differentialequation capabilities of Mathematica to my graduate thesis, I am trying to apply NDEigensystem to an eigenproblem whose solution I know, but I am having some trouble doing so.
As a test problem, I am using an algebraic version of the Mathieu equation,
$$(1-zeta^2)w^primeprime-zeta w^prime+left(a+2q-4qzeta^2right)w=0$$
For this example I set $q=4/3$ and take only the first three eigenpairs:
m = 3; q = 4/3;
op = -(1 - ζ^2) u''[ζ] + ζ u'[ζ] + 2 q (2 ζ^2 - 1) u[ζ];
bc = DirichletCondition[u[ζ] == 0, True];
λ, fl = NDEigensystem[op, bc, u, ζ, 0, 1, m];
I chose the Mathieu equation as a nontrivial example as Mathematica already has a function for it's evaluation:
λt = Table[MathieuCharacteristicB[2 k, q], k, m];
flt = Table[With[j = j,
MathieuS[MathieuCharacteristicB[2 k, q], q, ArcCos[#]] &], k, m];
The problem is, I do not get the expected eigenvalues!
λ
(* 4.0708, 17.3259, 39.1877 *)
N[λt]
(* 3.85298, 16.0581, 36.0254 *)
And of course, plotting shows that the eigenequation is not satisfied at all:
With[u = fl[[1]], b = λ[[1]],
 Plot[(1 - ζ^2) u''[ζ] - ζ u'[ζ] + (b + 2 q - 4 q ζ^2) u[ζ], ζ, 0, 1]]
With[u = flt[[1]], b = λt[[1]],
 Plot[(1 - ζ^2) u''[ζ] - ζ u'[ζ] + (b + 2 q - 4 q ζ^2) u[ζ], ζ, 0, 1]]
What was wrong with my attempt? If I can get this example to work, I should be able to apply it to my actual, more complicated problem, so any Good Ideas would be welcome.
differential-equations finite-element-method
New contributor
宮川園子 is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.
$endgroup$
add a comment |
$begingroup$
To be able to apply the differentialequation capabilities of Mathematica to my graduate thesis, I am trying to apply NDEigensystem to an eigenproblem whose solution I know, but I am having some trouble doing so.
As a test problem, I am using an algebraic version of the Mathieu equation,
$$(1-zeta^2)w^primeprime-zeta w^prime+left(a+2q-4qzeta^2right)w=0$$
For this example I set $q=4/3$ and take only the first three eigenpairs:
m = 3; q = 4/3;
op = -(1 - ζ^2) u''[ζ] + ζ u'[ζ] + 2 q (2 ζ^2 - 1) u[ζ];
bc = DirichletCondition[u[ζ] == 0, True];
λ, fl = NDEigensystem[op, bc, u, ζ, 0, 1, m];
I chose the Mathieu equation as a nontrivial example as Mathematica already has a function for it's evaluation:
λt = Table[MathieuCharacteristicB[2 k, q], k, m];
flt = Table[With[j = j,
MathieuS[MathieuCharacteristicB[2 k, q], q, ArcCos[#]] &], k, m];
The problem is, I do not get the expected eigenvalues!
λ
(* 4.0708, 17.3259, 39.1877 *)
N[λt]
(* 3.85298, 16.0581, 36.0254 *)
And of course, plotting shows that the eigenequation is not satisfied at all:
With[u = fl[[1]], b = λ[[1]],
 Plot[(1 - ζ^2) u''[ζ] - ζ u'[ζ] + (b + 2 q - 4 q ζ^2) u[ζ], ζ, 0, 1]]
With[u = flt[[1]], b = λt[[1]],
 Plot[(1 - ζ^2) u''[ζ] - ζ u'[ζ] + (b + 2 q - 4 q ζ^2) u[ζ], ζ, 0, 1]]
What was wrong with my attempt? If I can get this example to work, I should be able to apply it to my actual, more complicated problem, so any Good Ideas would be welcome.
differential-equations finite-element-method
New contributor
宮川園子 is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.
$endgroup$
To be able to apply the differentialequation capabilities of Mathematica to my graduate thesis, I am trying to apply NDEigensystem to an eigenproblem whose solution I know, but I am having some trouble doing so.
As a test problem, I am using an algebraic version of the Mathieu equation,
$$(1-zeta^2)w^primeprime-zeta w^prime+left(a+2q-4qzeta^2right)w=0$$
For this example I set $q=4/3$ and take only the first three eigenpairs:
m = 3; q = 4/3;
op = -(1 - ζ^2) u''[ζ] + ζ u'[ζ] + 2 q (2 ζ^2 - 1) u[ζ];
bc = DirichletCondition[u[ζ] == 0, True];
λ, fl = NDEigensystem[op, bc, u, ζ, 0, 1, m];
I chose the Mathieu equation as a nontrivial example as Mathematica already has a function for it's evaluation:
λt = Table[MathieuCharacteristicB[2 k, q], k, m];
flt = Table[With[j = j,
MathieuS[MathieuCharacteristicB[2 k, q], q, ArcCos[#]] &], k, m];
The problem is, I do not get the expected eigenvalues!
λ
(* 4.0708, 17.3259, 39.1877 *)
N[λt]
(* 3.85298, 16.0581, 36.0254 *)
And of course, plotting shows that the eigenequation is not satisfied at all:
With[u = fl[[1]], b = λ[[1]],
 Plot[(1 - ζ^2) u''[ζ] - ζ u'[ζ] + (b + 2 q - 4 q ζ^2) u[ζ], ζ, 0, 1]]
With[u = flt[[1]], b = λt[[1]],
 Plot[(1 - ζ^2) u''[ζ] - ζ u'[ζ] + (b + 2 q - 4 q ζ^2) u[ζ], ζ, 0, 1]]
What was wrong with my attempt? If I can get this example to work, I should be able to apply it to my actual, more complicated problem, so any Good Ideas would be welcome.
differential-equations finite-element-method
differential-equations finite-element-method
New contributor
宮川園子 is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.
New contributor
宮川園子 is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.
edited 38 mins ago


user21
20.9k55998
20.9k55998
New contributor
宮川園子 is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.
asked 2 hours ago
宮川園子宮川園子
161
161
New contributor
宮川園子 is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.
New contributor
宮川園子 is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.
宮川園子 is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.
add a comment |
add a comment |
 2 Answers
 2
 
active
oldest
votes
$begingroup$
If you refine the mesh, you will get closer:
m = 3; q = 4/3;
op = -(1 - [Zeta]^2) u''[[Zeta]] + [Zeta] u'[[Zeta]] + 
 2 q (2 [Zeta]^2 - 1) u[[Zeta]];
bc = DirichletCondition[u[[Zeta]] == 0, True];
[Lambda], fl = 
 NDEigensystem[op, bc, u, [Zeta], 0, 1, m, 
 Method -> "PDEDiscretization" -> "FiniteElement", "MeshOptions" 
-> "MaxCellMeasure" -> 0.00001];
[Lambda]
3.855, 16.074, 36.064
[Lambda]t = Table[MathieuCharacteristicB[2 k, q], k, m];
flt = Table[
 With[j = j, 
 MathieuS[MathieuCharacteristicB[2 k, q], q, ArcCos[#]] &], k, m];
[Lambda]t // N
3.852, 16.058, 36.025
$endgroup$
add a comment |
$begingroup$
It looks to me like NDEigensystem is struggling with the singularity at $zeta=1$, as does the method that I'm going to show. But perhaps it'll be useful for you, at least as a cross-check. 
I have a package for numerically calculating solutions of eigenvalue problems using the Evans function via the method of compound matrices, which is hosted on github. See my answers to other questions, the example notebook on the github or this introduction for some more details.
First we install the package (only need to do this the first time):
Needs["PacletManager`"]
PacletInstall["CompoundMatrixMethod", 
 "Site" -> "http://raw.githubusercontent.com/paclets/Repository/master"]
Then we first need to turn the ODEs into a matrix form $mathbfy'=mathbfA cdot mathbfy$, using my function ToMatrixSystem:
Needs["CompoundMatrixMethod`"]
sys[ζend_] = ToMatrixSystem[op == a u[ζ], u[0] == 0, u[ζend] == 0, u, ζ, 0, ζend, a]
Now the function Evans will calculate the Evans function (also known as the Miss-Distance function) for any given value of $a$ and $zeta_end$; this is an analytic function whose roots coincide with eigenvalues of the original equation.
Plugging in $zeta_end = 1$ fails due to the singularity, but you can try moving the endpoint slightly away:
FindRoot[Evans[a, sys[1 - 10^-3]], a, 3]
(* a -> 4.00335 *)
Moving the endpoint closer approaches the correct value, but I can't get the exact value with this method.
FindRoot[Evans[a, sys[1 - 10^-10], WorkingPrecision -> 30], a, 3, 
 WorkingPrecision -> 30] // Quiet
(* a -> 3.85301 *)
You can see the same effect for the other roots.
$endgroup$
add a comment |
 Your Answer
 
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "387"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
宮川園子 is a new contributor. Be nice, and check out our Code of Conduct.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmathematica.stackexchange.com%2fquestions%2f196891%2fusing-ndeigensystem-to-solve-the-mathieu-equation%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
 2 Answers
 2
 
active
oldest
votes
 2 Answers
 2
 
active
oldest
votes
active
oldest
votes
active
oldest
votes
$begingroup$
If you refine the mesh, you will get closer:
m = 3; q = 4/3;
op = -(1 - [Zeta]^2) u''[[Zeta]] + [Zeta] u'[[Zeta]] + 
 2 q (2 [Zeta]^2 - 1) u[[Zeta]];
bc = DirichletCondition[u[[Zeta]] == 0, True];
[Lambda], fl = 
 NDEigensystem[op, bc, u, [Zeta], 0, 1, m, 
 Method -> "PDEDiscretization" -> "FiniteElement", "MeshOptions" 
-> "MaxCellMeasure" -> 0.00001];
[Lambda]
3.855, 16.074, 36.064
[Lambda]t = Table[MathieuCharacteristicB[2 k, q], k, m];
flt = Table[
 With[j = j, 
 MathieuS[MathieuCharacteristicB[2 k, q], q, ArcCos[#]] &], k, m];
[Lambda]t // N
3.852, 16.058, 36.025
$endgroup$
add a comment |
$begingroup$
If you refine the mesh, you will get closer:
m = 3; q = 4/3;
op = -(1 - [Zeta]^2) u''[[Zeta]] + [Zeta] u'[[Zeta]] + 
 2 q (2 [Zeta]^2 - 1) u[[Zeta]];
bc = DirichletCondition[u[[Zeta]] == 0, True];
[Lambda], fl = 
 NDEigensystem[op, bc, u, [Zeta], 0, 1, m, 
 Method -> "PDEDiscretization" -> "FiniteElement", "MeshOptions" 
-> "MaxCellMeasure" -> 0.00001];
[Lambda]
3.855, 16.074, 36.064
[Lambda]t = Table[MathieuCharacteristicB[2 k, q], k, m];
flt = Table[
 With[j = j, 
 MathieuS[MathieuCharacteristicB[2 k, q], q, ArcCos[#]] &], k, m];
[Lambda]t // N
3.852, 16.058, 36.025
$endgroup$
add a comment |
$begingroup$
If you refine the mesh, you will get closer:
m = 3; q = 4/3;
op = -(1 - [Zeta]^2) u''[[Zeta]] + [Zeta] u'[[Zeta]] + 
 2 q (2 [Zeta]^2 - 1) u[[Zeta]];
bc = DirichletCondition[u[[Zeta]] == 0, True];
[Lambda], fl = 
 NDEigensystem[op, bc, u, [Zeta], 0, 1, m, 
 Method -> "PDEDiscretization" -> "FiniteElement", "MeshOptions" 
-> "MaxCellMeasure" -> 0.00001];
[Lambda]
3.855, 16.074, 36.064
[Lambda]t = Table[MathieuCharacteristicB[2 k, q], k, m];
flt = Table[
 With[j = j, 
 MathieuS[MathieuCharacteristicB[2 k, q], q, ArcCos[#]] &], k, m];
[Lambda]t // N
3.852, 16.058, 36.025
$endgroup$
If you refine the mesh, you will get closer:
m = 3; q = 4/3;
op = -(1 - [Zeta]^2) u''[[Zeta]] + [Zeta] u'[[Zeta]] + 
 2 q (2 [Zeta]^2 - 1) u[[Zeta]];
bc = DirichletCondition[u[[Zeta]] == 0, True];
[Lambda], fl = 
 NDEigensystem[op, bc, u, [Zeta], 0, 1, m, 
 Method -> "PDEDiscretization" -> "FiniteElement", "MeshOptions" 
-> "MaxCellMeasure" -> 0.00001];
[Lambda]
3.855, 16.074, 36.064
[Lambda]t = Table[MathieuCharacteristicB[2 k, q], k, m];
flt = Table[
 With[j = j, 
 MathieuS[MathieuCharacteristicB[2 k, q], q, ArcCos[#]] &], k, m];
[Lambda]t // N
3.852, 16.058, 36.025
answered 34 mins ago


user21user21
20.9k55998
20.9k55998
add a comment |
add a comment |
$begingroup$
It looks to me like NDEigensystem is struggling with the singularity at $zeta=1$, as does the method that I'm going to show. But perhaps it'll be useful for you, at least as a cross-check. 
I have a package for numerically calculating solutions of eigenvalue problems using the Evans function via the method of compound matrices, which is hosted on github. See my answers to other questions, the example notebook on the github or this introduction for some more details.
First we install the package (only need to do this the first time):
Needs["PacletManager`"]
PacletInstall["CompoundMatrixMethod", 
 "Site" -> "http://raw.githubusercontent.com/paclets/Repository/master"]
Then we first need to turn the ODEs into a matrix form $mathbfy'=mathbfA cdot mathbfy$, using my function ToMatrixSystem:
Needs["CompoundMatrixMethod`"]
sys[ζend_] = ToMatrixSystem[op == a u[ζ], u[0] == 0, u[ζend] == 0, u, ζ, 0, ζend, a]
Now the function Evans will calculate the Evans function (also known as the Miss-Distance function) for any given value of $a$ and $zeta_end$; this is an analytic function whose roots coincide with eigenvalues of the original equation.
Plugging in $zeta_end = 1$ fails due to the singularity, but you can try moving the endpoint slightly away:
FindRoot[Evans[a, sys[1 - 10^-3]], a, 3]
(* a -> 4.00335 *)
Moving the endpoint closer approaches the correct value, but I can't get the exact value with this method.
FindRoot[Evans[a, sys[1 - 10^-10], WorkingPrecision -> 30], a, 3, 
 WorkingPrecision -> 30] // Quiet
(* a -> 3.85301 *)
You can see the same effect for the other roots.
$endgroup$
add a comment |
$begingroup$
It looks to me like NDEigensystem is struggling with the singularity at $zeta=1$, as does the method that I'm going to show. But perhaps it'll be useful for you, at least as a cross-check. 
I have a package for numerically calculating solutions of eigenvalue problems using the Evans function via the method of compound matrices, which is hosted on github. See my answers to other questions, the example notebook on the github or this introduction for some more details.
First we install the package (only need to do this the first time):
Needs["PacletManager`"]
PacletInstall["CompoundMatrixMethod", 
 "Site" -> "http://raw.githubusercontent.com/paclets/Repository/master"]
Then we first need to turn the ODEs into a matrix form $mathbfy'=mathbfA cdot mathbfy$, using my function ToMatrixSystem:
Needs["CompoundMatrixMethod`"]
sys[ζend_] = ToMatrixSystem[op == a u[ζ], u[0] == 0, u[ζend] == 0, u, ζ, 0, ζend, a]
Now the function Evans will calculate the Evans function (also known as the Miss-Distance function) for any given value of $a$ and $zeta_end$; this is an analytic function whose roots coincide with eigenvalues of the original equation.
Plugging in $zeta_end = 1$ fails due to the singularity, but you can try moving the endpoint slightly away:
FindRoot[Evans[a, sys[1 - 10^-3]], a, 3]
(* a -> 4.00335 *)
Moving the endpoint closer approaches the correct value, but I can't get the exact value with this method.
FindRoot[Evans[a, sys[1 - 10^-10], WorkingPrecision -> 30], a, 3, 
 WorkingPrecision -> 30] // Quiet
(* a -> 3.85301 *)
You can see the same effect for the other roots.
$endgroup$
add a comment |
$begingroup$
It looks to me like NDEigensystem is struggling with the singularity at $zeta=1$, as does the method that I'm going to show. But perhaps it'll be useful for you, at least as a cross-check. 
I have a package for numerically calculating solutions of eigenvalue problems using the Evans function via the method of compound matrices, which is hosted on github. See my answers to other questions, the example notebook on the github or this introduction for some more details.
First we install the package (only need to do this the first time):
Needs["PacletManager`"]
PacletInstall["CompoundMatrixMethod", 
 "Site" -> "http://raw.githubusercontent.com/paclets/Repository/master"]
Then we first need to turn the ODEs into a matrix form $mathbfy'=mathbfA cdot mathbfy$, using my function ToMatrixSystem:
Needs["CompoundMatrixMethod`"]
sys[ζend_] = ToMatrixSystem[op == a u[ζ], u[0] == 0, u[ζend] == 0, u, ζ, 0, ζend, a]
Now the function Evans will calculate the Evans function (also known as the Miss-Distance function) for any given value of $a$ and $zeta_end$; this is an analytic function whose roots coincide with eigenvalues of the original equation.
Plugging in $zeta_end = 1$ fails due to the singularity, but you can try moving the endpoint slightly away:
FindRoot[Evans[a, sys[1 - 10^-3]], a, 3]
(* a -> 4.00335 *)
Moving the endpoint closer approaches the correct value, but I can't get the exact value with this method.
FindRoot[Evans[a, sys[1 - 10^-10], WorkingPrecision -> 30], a, 3, 
 WorkingPrecision -> 30] // Quiet
(* a -> 3.85301 *)
You can see the same effect for the other roots.
$endgroup$
It looks to me like NDEigensystem is struggling with the singularity at $zeta=1$, as does the method that I'm going to show. But perhaps it'll be useful for you, at least as a cross-check. 
I have a package for numerically calculating solutions of eigenvalue problems using the Evans function via the method of compound matrices, which is hosted on github. See my answers to other questions, the example notebook on the github or this introduction for some more details.
First we install the package (only need to do this the first time):
Needs["PacletManager`"]
PacletInstall["CompoundMatrixMethod", 
 "Site" -> "http://raw.githubusercontent.com/paclets/Repository/master"]
Then we first need to turn the ODEs into a matrix form $mathbfy'=mathbfA cdot mathbfy$, using my function ToMatrixSystem:
Needs["CompoundMatrixMethod`"]
sys[ζend_] = ToMatrixSystem[op == a u[ζ], u[0] == 0, u[ζend] == 0, u, ζ, 0, ζend, a]
Now the function Evans will calculate the Evans function (also known as the Miss-Distance function) for any given value of $a$ and $zeta_end$; this is an analytic function whose roots coincide with eigenvalues of the original equation.
Plugging in $zeta_end = 1$ fails due to the singularity, but you can try moving the endpoint slightly away:
FindRoot[Evans[a, sys[1 - 10^-3]], a, 3]
(* a -> 4.00335 *)
Moving the endpoint closer approaches the correct value, but I can't get the exact value with this method.
FindRoot[Evans[a, sys[1 - 10^-10], WorkingPrecision -> 30], a, 3, 
 WorkingPrecision -> 30] // Quiet
(* a -> 3.85301 *)
You can see the same effect for the other roots.
answered 16 mins ago


KraZugKraZug
3,48821130
3,48821130
add a comment |
add a comment |
宮川園子 is a new contributor. Be nice, and check out our Code of Conduct.
宮川園子 is a new contributor. Be nice, and check out our Code of Conduct.
宮川園子 is a new contributor. Be nice, and check out our Code of Conduct.
宮川園子 is a new contributor. Be nice, and check out our Code of Conduct.
Thanks for contributing an answer to Mathematica Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
Use MathJax to format equations. MathJax reference.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmathematica.stackexchange.com%2fquestions%2f196891%2fusing-ndeigensystem-to-solve-the-mathieu-equation%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown