What is the fastest way to compute the first eigenvector?

13 vues (au cours des 30 derniers jours)
Shojiro SHIBAYAMA
Shojiro SHIBAYAMA le 10 Juin 2019
Commenté : gonzalo Mier le 3 Avr 2020
I'd like to know a way to compute the first eigenvector (the eigenvector with the largest eigenvalue) of a matrix A. Now I am using eig function.
[V, D] = eig(A);
However, this computes all eigenvectors of A, resulting in slow computation.
Does anyone know if there is a fastest way to compute the eigenvector? Thank you in advance.

Réponse acceptée

gonzalo Mier
gonzalo Mier le 10 Juin 2019
Read about eigs
  4 commentaires
Shojiro SHIBAYAMA
Shojiro SHIBAYAMA le 10 Fév 2020
Modifié(e) : Shojiro SHIBAYAMA le 10 Fév 2020
Wow thank you for the fruitful reply. I also have saw the results:
>> A=randn(100, 10);
>> AtA = A'*A;
>> rank(AtA)
10
>> tic;for i = 1:1000; eig(AtA);end; toc;
Elapsed time is 0.000973 seconds.
>> tic;for i = 1:1000; eigs(AtA);end; toc;
Elapsed time is 0.247325 seconds.
I am going to replace eigs with eig.
gonzalo Mier
gonzalo Mier le 3 Avr 2020
Really interesting! Thank you for contribute

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur Logical dans Help Center et File Exchange

Produits

Community Treasure Hunt

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

Start Hunting!

Translated by