Matlabで関数を使用します:
[V,D] = eig(C);
VとDは常に昇順でソートされていることがわかります。それはいつもそれが好きですか、それとも私が値を取得した後にそれらをソートする必要がV
ありD
ますか?
Matlabで関数を使用します:
[V,D] = eig(C);
VとDは常に昇順でソートされていることがわかります。それはいつもそれが好きですか、それとも私が値を取得した後にそれらをソートする必要がV
ありD
ますか?
ソートされた昇順の値を保証したい場合は、追加の値を実行してください
if ~issorted(diag(D))
[V,D] = eig(A);
[D,I] = sort(diag(D));
V = V(:, I);
end
好きなように並べ替えます。
または、次を使用しますeigs
。
[V,D] = eigs(A,size(A,1)-1)
Vは、関連する固有値の順序に対応する場合を除いて、どの順序でもソートされません。しかし、おそらくあなたはそれを意味していませんでした。
固有値は降順である傾向がありますが、これはまったく保証されていません。最大のものは上にあるアルゴリズムから滴り落ちる傾向があるため、それらは整然としている傾向があります。Eigには、その事実を保証するための最後のソートはありません。
固有問題のシーケンスを取得するように設計された固有シャッフルツールを指摘し、固有値(および対応する固有ベクトル)を並べ替えて、シーケンスに沿って一貫性を保つようにします。
確かに降順でそれらが本当に必要な場合は、その事実を確認するためにソートを実行してください。ベクトルも同じ順序で並べ替えることを確認してください。