How to compute interior eigenvectors that exclude certain eigenvalues?

12 visualizaciones (últimos 30 días)
I have a FEM matrix equation of the form:
(K - T)*x = T*b
Where T is a mass matrix and K is a stiffness matrix. I am using matlab's eigs function to compute the eigenvalues and eigenvectors of this system in a generalized eigenvalue problem where A = K-T and B = T.
The expected eigenspectrum is a flat line at and then a linearly increasing slope for . It seems as if avoiding the computation of eigenvectors siginificantly increases the speed of the eigs function. I currently try to avoid the computation by using the sigma option for eigs. Is there a better way to exclude certain eigenvalues from the eigs computation?
  6 comentarios
Matt J
Matt J el 12 de Nov. de 2021
But once you've done your piecewise linear fit to the spectrum, you should be able to avoid processing lambda=-1. Just set sigma and k to include only lambda>-1. Isn't that what you are already doing, and if so what's wrong with it?
Lucas Banting
Lucas Banting el 12 de Nov. de 2021
I was basically wondering if there was an eigenvalue algorithm where I could just specify as inputs (a, b) to compute all eigen values within the range (a, b).

Iniciar sesión para comentar.

Respuesta aceptada

Matt J
Matt J el 14 de Nov. de 2021
Editada: Matt J el 14 de Nov. de 2021
I was basically wondering if there was an eigenvalue algorithm where I could just specify as inputs (a, b) to compute all eigen values within the range (a, b).
It doesn't appear that there is, however, a faster way to compute the lambda=-1 eigenvectors might be to recognize that they are the null vectors of K, and so you can do,
[~,S,nullVectors]=svds(K,800,'smallest');
Not only should this find you the lambda=-1 eigenvectors, but also inspection of diag(S) should also tell you were the up-slope in your attached figure begins.
Together with the maximum eigenvectors,
eigmax=eigs(A,B,10,'largestabs')
you should be able to fit the slope more accurately than with sigma=30.
  1 comentario
Lucas Banting
Lucas Banting el 15 de Nov. de 2021
Thanks for your help. The solution I ended up using was limiting the MaxIterations and SubspaceDimension parameters, the eigenvectors associated with the nullspace of K converge last so they are just not computed in this case.

Iniciar sesión para comentar.

Más respuestas (1)

Matt J
Matt J el 12 de Nov. de 2021
If you'll be computing the majority of the eigenvalues anyway, it would be faster to use eig() than eigs().
  1 comentario
Lucas Banting
Lucas Banting el 12 de Nov. de 2021
The image I shared was only a portion of the eigen spectrum, the size of the matrices are practically one to two orders of magnitude larger than the number of needed eigenvectors.

Iniciar sesión para comentar.

Categorías

Más información sobre Linear Algebra en Help Center y File Exchange.

Productos


Versión

R2020b

Community Treasure Hunt

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

Start Hunting!

Translated by