torch.linalg.multi_dot¶
- torch.linalg.multi_dot(tensors, *, out=None)¶
透過重新排列乘法順序來有效地將兩個或多個矩陣相乘,以執行最少的算術運算。
支援 float、double、cfloat 和 cdouble 等資料類型輸入。此函數不支援批次輸入。
tensors
中的每個張量都必須是 2D 的,除了第一個和最後一個可以是 1D 的。如果第一個張量是形狀為 (n,) 的 1D 向量,則將其視為形狀為 (1, n) 的行向量;類似地,如果最後一個張量是形狀為 (n,) 的 1D 向量,則將其視為形狀為 (n, 1) 的列向量。如果第一個和最後一個張量是矩陣,則輸出將是矩陣。但是,如果其中一個是 1D 向量,則輸出將是 1D 向量。
與 numpy.linalg.multi_dot 的差異
與 numpy.linalg.multi_dot 不同,第一個和最後一個張量必須是 1D 或 2D 的,而 NumPy 允許它們是 nD 的
警告
此函數不進行廣播 (broadcast)。
注意
此函數透過在計算最佳矩陣乘法順序後,鏈接
torch.mm()
呼叫來實現。注意
將形狀為 (a, b) 和 (b, c) 的兩個矩陣相乘的成本為 a * b * c。給定矩陣 A、B、C,其形狀分別為 (10, 100)、(100, 5)、(5, 50),我們可以如下計算不同乘法順序的成本
在這種情況下,先將 A 和 B 相乘,然後再乘以 C 快 10 倍。
- 參數
tensors (Sequence[Tensor]) – 要相乘的兩個或更多張量。第一個和最後一個張量可以是 1D 或 2D。其他每個張量都必須是 2D。
- 關鍵字參數
out (Tensor, optional) – 輸出張量。如果為 None,則忽略。預設值:None。
範例
>>> from torch.linalg import multi_dot >>> multi_dot([torch.tensor([1, 2]), torch.tensor([2, 3])]) tensor(8) >>> multi_dot([torch.tensor([[1, 2]]), torch.tensor([2, 3])]) tensor([8]) >>> multi_dot([torch.tensor([[1, 2]]), torch.tensor([[2], [3]])]) tensor([[8]]) >>> A = torch.arange(2 * 3).view(2, 3) >>> B = torch.arange(3 * 2).view(3, 2) >>> C = torch.arange(2 * 2).view(2, 2) >>> multi_dot((A, B, C)) tensor([[ 26, 49], [ 80, 148]])