import numpy as np
A = np.matrix([[1, 2, 3],
[4, 5, 6],
[7, 8, 9],
[10, 11, 12]])
u, s, vt = np.linalg.svd(A)
print (np.dot(u, np.dot(np.diag(s), vt)))
我使用numpy创建矩阵,它显示了下面的脚本错误。在
ValueError: shapes (4,4) and (3,) not aligned: 4 (dim 1) != 3 (dim 0)
Tags:
如果在SVD之后添加}返回3x3矩阵。因此,为什么不能计算
print(u.shape, s.shape, vt.shape)
,您将看到u
是4x4矩阵,而{u
的点积。将np.linalg.svd
的full_matrices
选项设置为False
,将返回一个4x3矩阵,并允许计算点积。一、 e对于你的具体问题,这样做是否正确是另一回事。在
你试图在两个不相容的矩阵之间做点积。
u
(其形状为(4x4))的列数不等于np.dot(np.diag(s), vt)
(其形状为(3x3))的行数相关问题 更多 >
编程相关推荐