np.linalg.svdを使わずnp.linalg.eig で特異値分解を行おうとしております。
eigとsvdで行った場合、特異ベクトルの符合が揃いません。
eigのみで汎用的に特異値分解ができるように実装するのは出来ないのでしょうか。
python
1import numpy as np 2A = np.array([[2,4,1,3],[1,5,3,2],[5,7,0,7]]) 3 4#比較のためSVDでの実装 5u, s, v = np.linalg.svd(A,full_matrices=False) 6 7#svd:u - eig:u_vec 8#svd:s - eig:sigma 9#svd:v - eig:v_vec 10 11#左特異ベクトルと固有値 12vals,vec = np.linalg.eig(A@A.T) 13#エルミネート行列ではないがeighで行うとSVDと同じになる 14idx = np.argsort(vals)[::-1] 15 16sigma = np.diag(np.sqrt(vals[idx])) 17sigma = np.nan_to_num(sigma,0) 18s = np.diag(s) 19 20print('EIG_∑\n',sigma) 21print('SVD_∑\n',s) 22 23#左特異ベクトル 24u_vec = vec[:,idx] 25print('\nEig_左特異ベクトル\n' , u_vec) 26print('SVD_左特異ベクトル\n' , u) 27 28 29#右特異ベクトル 30vals,vec = np.linalg.eig(A.T@A) 31#エルミネート行列ではないがeighで行うとSVDと同じになる 32idx = np.argsort(vals)[::-1] 33v_vec = vec[:,idx].T 34v_vec = v_vec[:3,:] 35print('\nEig_右特異ベクトル\n' , v_vec) 36print('SVD_右特異ベクトル\n' , v) 37 38#元配列に戻す 39print('\n元配列A:\n',A) 40print('\nSVD:\n' + str(np.round(u@s@v,2))) 41print('\nEIG:\n' + str(np.round(u_vec@sigma@v_vec,2)))
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/06/13 05:41