如果你想将一个向量添加到矩阵中,可以通过选择它应该放置的位置来实现:
In [155]: ma = np.matrix(
...: [[ 1., 1., 1.],
...: [ 1., 1., 1.],
...: [ 1., 1., 1.]])
In [156]: mb = np.matrix([[1,2,3]])
In [157]: ma[1] += mb # second row
In [158]: ma
Out[158]:
matrix([[ 1., 1., 1.],
[ 2., 3., 4.],
[ 1., 1., 1.]])
In [159]: ma[:,1] += mb.T # second column
In [160]: ma
Out[160]:
matrix([[ 1., 2., 1.],
[ 2., 5., 4.],
[ 1., 4., 1.]])
但是我想提醒您,您并没有使用所述的numpy.matrix
。实际上,您正在使用numpy.ndarray
,因为np.ones
返回一个ndarray
而不是一个matrix
。
添加仍然是相同的,但创建一些矩阵,您会发现它们的行为不同:
In [161]: ma*mb
---------------------------------------------------------------------------
ValueError Traceback (most recent call last)
ValueError: matrices are not aligned
In [162]: mb*ma
Out[162]: matrix([[ 6., 6., 6.]])
In [163]: ma*mb.T
Out[163]:
matrix([[ 6.],
[ 6.],
[ 6.]])
In [164]: aa = np.ones((3,3))
In [165]: ab = np.arange(1,4)
In [166]: aa*ab
Out[166]:
array([[ 1., 2., 3.],
[ 1., 2., 3.],
[ 1., 2., 3.]])
In [167]: ab*aa
Out[167]:
array([[ 1., 2., 3.],
[ 1., 2., 3.],
[ 1., 2., 3.]])