NumPy 矩陣乘法的實現示例
NumPy 支持的幾類矩陣乘法也很重要。
元素級乘法
你已看過瞭一些元素級乘法。你可以使用 multiply 函數或 * 運算符來實現。回顧一下,它看起來是這樣的:
m = np.array([[1,2,3],[4,5,6]]) m # 顯示以下結果: # array([[1, 2, 3], # [4, 5, 6]]) n = m * 0.25 n # 顯示以下結果: # array([[ 0.25, 0.5 , 0.75], # [ 1. , 1.25, 1.5 ]]) m * n # 顯示以下結果: # array([[ 0.25, 1. , 2.25], # [ 4. , 6.25, 9. ]]) np.multiply(m, n) # 相當於 m * n # 顯示以下結果: # array([[ 0.25, 1. , 2.25], # [ 4. , 6.25, 9. ]])
矩陣乘積
要獲得矩陣乘積,你可以使用 NumPy 的 matmul 函數。
如果你有兼容的形狀,那就像這樣簡單:
a = np.array([[1,2,3,4],[5,6,7,8]]) a # 顯示以下結果: # array([[1, 2, 3, 4], # [5, 6, 7, 8]]) a.shape # 顯示以下結果: # (2, 4) b = np.array([[1,2,3],[4,5,6],[7,8,9],[10,11,12]]) b # 顯示以下結果: # array([[ 1, 2, 3], # [ 4, 5, 6], # [ 7, 8, 9], # [10, 11, 12]]) b.shape # 顯示以下結果: # (4, 3) c = np.matmul(a, b) c # 顯示以下結果: # array([[ 70, 80, 90], # [158, 184, 210]]) c.shape # 顯示以下結果: # (2, 3)
如果你的矩陣具有不兼容的形狀,則會出現以下錯誤:
np.matmul(b, a) # 顯示以下錯誤: # ValueError: shapes (4,3) and (2,4) not aligned: 3 (dim 1) != 2 (dim 0)
NumPy 的 dot 函數
有時候,在你以為要用 matmul 函數的地方,你可能會看到 NumPy 的 dot 函數。事實證明,如果矩陣是二維的,那麼 dot 和 matmul 函數的結果是相同的。
所以這兩個結果是等價的:
a = np.array([[1,2],[3,4]]) a # 顯示以下結果: # array([[1, 2], # [3, 4]]) np.dot(a,a) # 顯示以下結果: # array([[ 7, 10], # [15, 22]]) a.dot(a) # you can call你可以直接對 `ndarray` 調用 `dot` # 顯示以下結果: # array([[ 7, 10], # [15, 22]]) np.matmul(a,a) # array([[ 7, 10], # [15, 22]])
雖然這兩個函數對於二維數據返回相同的結果,但在用於其他數據形狀時,你應該謹慎選擇。你可以在 matmul和 dot 文檔中詳細瞭解它們的差異,並找到其他 NumPy 函數的鏈接。
到此這篇關於NumPy 矩陣乘法的實現示例的文章就介紹到這瞭,更多相關NumPy 矩陣乘法內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Python Numpy中ndarray的常見操作
- 玩數據必備Python庫之numpy使用詳解
- Python機器學習三大件之一numpy
- Python數據分析之Numpy庫的使用詳解
- python3 numpy中數組相乘np.dot(a,b)運算的規則說明