How to compute interior eigenvectors that exclude certain eigenvalues?

12 vues (au cours des 30 derniers jours)
Lucas Banting
Lucas Banting le 12 Nov 2021
Commenté : Lucas Banting le 15 Nov 2021
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 commentaires
Matt J
Matt J le 12 Nov 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 le 12 Nov 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).

Connectez-vous pour commenter.

Réponse acceptée

Matt J
Matt J le 14 Nov 2021
Modifié(e) : Matt J le 14 Nov 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 commentaire
Lucas Banting
Lucas Banting le 15 Nov 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.

Connectez-vous pour commenter.

Plus de réponses (1)

Matt J
Matt J le 12 Nov 2021
If you'll be computing the majority of the eigenvalues anyway, it would be faster to use eig() than eigs().
  1 commentaire
Lucas Banting
Lucas Banting le 12 Nov 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.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Linear Algebra dans Help Center et File Exchange

Produits


Version

R2020b

Community Treasure Hunt

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

Start Hunting!

Translated by