How to perform a sparse eigendecomposition in order to compute only the eigenvectors of smallest eigenvalues?
1 回表示 (過去 30 日間)
古いコメントを表示
I have a large n * n sparse matrix called L. k is a given value. I am supposed to do this:
"perform a sparse eigendecomposition of the Laplacian L that computes only the eigenvectors associated with the k smallest-magnitude eigenvalues."
data:image/s3,"s3://crabby-images/e2de0/e2de0be96207ad610a6f98c0d6201f972a138e3d" alt=""
How can I do this?
This is what I have tried:
d = diag(eigs(L,k,'smallestabs'));
===============================================================
And then I am supposed to do this:
"Then project matrix V (vertex positions) onto the basis spanned by these eigenvectors and reconstruct a filtered V called V_new (version of the mesh)."
data:image/s3,"s3://crabby-images/c14d5/c14d5b3d2a7d7e283a4d2abe8a0d8db94bbb3a25" alt=""
P is not important here. I just want the new V based on the D matrix. Basically I want to claculate this:
data:image/s3,"s3://crabby-images/21c36/21c3644acca1a9e67ae0aa723aed16a3b19e827d" alt=""
I have tried this:
pd = padarray(diag(d),[n-k,n-k],0,'post');
V_new = V * pd * V'
But seems not to be working, because the resulting V_new is very different than V.
How can I do this?
0 件のコメント
回答 (0 件)
参考
カテゴリ
Help Center および File Exchange で Triangulation Representation についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!