Eig takes too long

조회 수: 17 (최근 30일)
bil
bil 2022년 6월 16일
답변: Walter Roberson 2022년 6월 16일
Hi All,
I am currently trying to find the eigenvectors for this 5x5 matrix but Matlab seems to be taking incredibly long to do so:
syms a b c d e f g h k l
p2 = [0 1/(a)^3 1/(b)^3 1/(c)^3 1/(d)^3;
1/(a)^3 0 1/(e)^3 1/(f)^3 1/(g)^3;
1/(b)^3 1/(e)^3 0 1/(h)^3 1/(k)^3;
1/(c)^3 1/(f)^3 1/(h)^3 0 1/(l)^3;
1/(d)^3 1/(g)^3 1/(k)^3 1/(l)^3 0];
[V,D]=eig(p2);
We can assume here that none of the variables are 0.
Does anyone have any suggestions or advice that can help speed up this calculation if that is even possible?
(I need to keep the matrix in symbolic form because I will need to manipulate the variable directly in a later calculation).
Thank you!

답변 (2개)

Matt J
Matt J 2022년 6월 16일
편집: Matt J 2022년 6월 16일
Does anyone have any suggestions or advice that can help speed up this calculation if that is even possible?
I don't think the calculation itself is possible. A symbolic solution would mean finding the roots of a 5th order characteristic polynomial, which is theoretically known to have no analytical solutions,
I need to keep the matrix in symbolic form because I will need to manipulate the variable directly in a later calculation
That doesn't explain why you need sym. Please clarify.
  댓글 수: 2
bil
bil 2022년 6월 16일
Hi, the reason I need to maintain everything in symbolic form is because I need to solve a second order ODE. The situation is described below.
Basically I need to solve (1), which generates 5 coupled ODEs for each R_{n}=x_{n}. The issue is that I need to take the partial derivative of the overlap term, which necessarily requires me to find the eigenvectors of this matrix symbolically (unless there is a numerical way to do this).
Matt J
Matt J 2022년 6월 16일
There are numerical ODE functions in Matlab,
Is there a reason one of them wouldn't apply?

댓글을 달려면 로그인하십시오.


Walter Roberson
Walter Roberson 2022년 6월 16일
syms M [5 5];
M = M - diag(diag(M));
[V, D] = eig(M);
When that eventually finishes (which will take a while), you can subs() actual expressions in place of symvars(M). Expect the subs() to take a while too.
Abandon hope of simplify() the results. And do not be surprised if it involves root() of a polynomial of degree 5.
...Prepare for the possibility that the results will be too large to be of any practical use.

카테고리

Help CenterFile Exchange에서 Linear Algebra에 대해 자세히 알아보기

제품


릴리스

R2021b

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by