我运行在numpy
qr factorization
返回的ndarrays
,即Q
和R
列表:除去零线2-d numpy的阵列
>>> [q,r] = np.linalg.qr(np.array([1,0,0,0,1,1,1,1,1]).reshape(3,3))
R
是一个二维阵列,具有枢转零线在底部(甚至证明了我的测试集中的所有示例):
>>> print r
[[ 1.41421356 0.70710678 0.70710678]
[ 0. 1.22474487 1.22474487]
[ 0. 0. 0. ]]
。现在,我想在两个矩阵R_~
分R
:
[[ 1.41421356 0.70710678 0.70710678]
[ 0. 1.22474487 1.22474487]]
和R_0
:
[[ 0. 0. 0. ]]
(提取出所有的零线)。它似乎接近这个解决方案:deleting rows in numpy array。
编辑:
更有趣:np.linalg.qr()
返回一个n x n
- 矩阵。不是,我本来期望:
A := n x m
Q := n x m
R := n x m
如果axis = 0会怎样? – denfromufa
@denfromufa'axis = 0'会删除全零*列*。 – ecatmur
这是很明显的,有什么问题是这个过滤不能像'axis = 0'那样应用,而是需要转置 – denfromufa