numpy.tensordot#
- numpy.tensordot(a, b, axes=2)[源代码]#
沿指定轴计算张量点积.
给定两个张量 a 和 b ,以及包含两个类数组对象的类数组对象
(a_axes, b_axes),对由a_axes和b_axes指定的轴上的 a 和 b 的元素(分量)的乘积求和. 第三个参数可以是单个非负整数类标量N;如果是这种情况,则 a 的最后N个维度和 b 的前N个维度将被求和.- 参数:
- a, barray_like
要进行“点积”的张量.
- axesint 或 (2,) array_like
integer_like 如果是 int N,则按顺序对 a 的最后 N 个轴和 b 的前 N 个轴求和. 对应轴的大小必须匹配.
(2,) array_like 或者,是要在其上求和的轴的列表,第一个序列应用于 a ,第二个应用于 b . 两个元素 array_like 的长度必须相同.
- 返回:
- outputndarray
输入的张量点积.
注释
- 三个常见的用例是:
axes = 0:张量积 \(a\otimes b\)axes = 1:张量点积 \(a\cdot b\)axes = 2:(默认)张量双重收缩 \(a:b\)
当 axes 是 integer_like 时,评估的轴序列将是:从 a 的倒数第 N 个轴到倒数第一个轴,以及从 b 的第 0 个轴到第 (N-1) 个轴. 例如,
axes = 2等于axes = [[-2, -1], [0, 1]]. 当 N-1 小于 0,或者 -N 大于 -1 时, a 和 b 的元素被定义为 axes .当有多个轴需要求和–并且它们不是 a ( b ) 的最后(第一个)轴–参数 axes 应由两个相同长度的序列组成,第一个要求和的轴在两个序列中都首先给出,第二个轴其次,依此类推. 该计算可以参考
numpy.einsum.结果的形状由第一个张量的非收缩轴组成,后跟第二个张量的非收缩轴.
示例
关于 integer_like 的示例:
>>> a_0 = np.array([[1, 2], [3, 4]]) >>> b_0 = np.array([[5, 6], [7, 8]]) >>> c_0 = np.tensordot(a_0, b_0, axes=0) >>> c_0.shape (2, 2, 2, 2) >>> c_0 array([[[[ 5, 6], [ 7, 8]], [[10, 12], [14, 16]]], [[[15, 18], [21, 24]], [[20, 24], [28, 32]]]])
关于 array_like 的示例:
>>> a = np.arange(60.).reshape(3,4,5) >>> b = np.arange(24.).reshape(4,3,2) >>> c = np.tensordot(a,b, axes=([1,0],[0,1])) >>> c.shape (5, 2) >>> c array([[4400., 4730.], [4532., 4874.], [4664., 5018.], [4796., 5162.], [4928., 5306.]])
一种较慢但等效的计算相同结果的方法…
>>> d = np.zeros((5,2)) >>> for i in range(5): ... for j in range(2): ... for k in range(3): ... for n in range(4): ... d[i,j] += a[k,n,i] * b[n,k,j] >>> c == d array([[ True, True], [ True, True], [ True, True], [ True, True], [ True, True]])
利用 + 和 的重载的扩展示例:
>>> a = np.array(range(1, 9)) >>> a.shape = (2, 2, 2) >>> A = np.array(('a', 'b', 'c', 'd'), dtype=object) >>> A.shape = (2, 2) >>> a; A array([[[1, 2], [3, 4]], [[5, 6], [7, 8]]]) array([['a', 'b'], ['c', 'd']], dtype=object)
>>> np.tensordot(a, A) # third argument default is 2 for double-contraction array(['abbcccdddd', 'aaaaabbbbbbcccccccdddddddd'], dtype=object)
>>> np.tensordot(a, A, 1) array([[['acc', 'bdd'], ['aaacccc', 'bbbdddd']], [['aaaaacccccc', 'bbbbbdddddd'], ['aaaaaaacccccccc', 'bbbbbbbdddddddd']]], dtype=object)
>>> np.tensordot(a, A, 0) # tensor product (result too long to incl.) array([[[[['a', 'b'], ['c', 'd']], ...
>>> np.tensordot(a, A, (0, 1)) array([[['abbbbb', 'cddddd'], ['aabbbbbb', 'ccdddddd']], [['aaabbbbbbb', 'cccddddddd'], ['aaaabbbbbbbb', 'ccccdddddddd']]], dtype=object)
>>> np.tensordot(a, A, (2, 1)) array([[['abb', 'cdd'], ['aaabbbb', 'cccdddd']], [['aaaaabbbbbb', 'cccccdddddd'], ['aaaaaaabbbbbbbb', 'cccccccdddddddd']]], dtype=object)
>>> np.tensordot(a, A, ((0, 1), (0, 1))) array(['abbbcccccddddddd', 'aabbbbccccccdddddddd'], dtype=object)
>>> np.tensordot(a, A, ((2, 1), (1, 0))) array(['acccbbdddd', 'aaaaacccccccbbbbbbdddddddd'], dtype=object)