NumPy中array和matrix用于矩阵乘法时的区别
在NumPy中,array用于表示通用的N维数组,matrix则特定用于线性代数计算。array和matrix都可以用来表示矩阵,二者在进行乘法操作时,有一些不同之处。
使用二维的array时,运算符* 用于计算逐元素相相乘,函数dot() 用于计算矩阵相乘,例子如:
import numpy as np a = np.array([[1, 2], [3, 4]]) b = np.array([[5, 6], [7, 8]]) print 'a * b = \n', a * b print 'np.dot(a, b) = \n', np.dot(a, b)
运行结果为:
a * b = [[ 5 12] [21 32]] np.dot(a, b) = [[19 22] [43 50]]
可见,当a和b为array时,a * b 计算了a和b的数量积(对应Matlab的a .* b ),dot(a, b) 计算了a和b的矢量积(对应Matlab的a * b )。
与array不同的是,使用matrix时,运算符* 用于计算矩阵相乘,函数multiply() 用于计算逐元素相乘,例子如:
import numpy as np a = np.mat('1 2; 3 4') b = np.mat('5 6; 7 8'); print 'a * b = \n', a * b print 'np.multiply(a, b) = \n', np.multiply(a, b)
运行结果为:
a * b = [[19 22] [43 50]] np.multiply(a, b) = [[ 5 12] [21 32]]
可见,当使用matrix时,无论是生成矩阵还是计算,Numpy的风格和Matlab更加贴近,降低了语言切换时的负担。