Jeśli chcesz dodać wektor do macierzy, można to zrobić wybierając gdzie powinien iść:
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.]])
Ale chciałbym was ostrzec, że nie używają numpy.matrix
, jak podano. W rzeczywistości używasz numpy.ndarray
, ponieważ np.ones
zwraca ndarray
, a nie matrix
.
dodanie jest wciąż ten sam, ale stworzyć kilka matryc, a przekonasz się, że zachowują się one inaczej:
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.]])
Thanks to wszystko wyjaśnia. Jeszcze nie zrozumiałem tej koncepcji, mimo że komunikat o błędzie już na mnie wskazywał: "ValueError: operandy nie mogły być transmitowane razem z kształtami ..." – andershqst