张量乘积运算实例

2024-09-06 14:12
文章标签 实例 运算 张量 乘积

本文主要是介绍张量乘积运算实例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

a = torch.tensor([[1, 2, 2], [3, 4, 4]])
b = torch.tensor([[1, 2, 2], [3, 4, 4], [5, 6, 6]])

张量a的维度是2x3,张量b的维度是3x3。根据矩阵乘法的规则,a的列数(3)与b的行数(3)相等,所以这两个张量可以进行矩阵乘法运算。

矩阵乘法的结果c的维度将是a的行数乘以b的列数,即2x3矩阵乘以3x3矩阵将得到一个2x3的矩阵。

矩阵乘法的计算方式是: 对于结果矩阵c中的每一个元素c[i][j],它是通过取a的第i行与b的第j列的对应元素的乘积之和得到的。

具体计算如下:

[0][0] = a[0][0]*b[0][0] + a[0][1]*b[1][0] + a[0][2]*b[2][0] = 1*1 + 2*3 + 2*5 = 1 + 6 + 10 = 17 c[0][1] = a[0][0]*b[0][1] + a[0][1]*b[1][1] + a[0][2]*b[2][1] = 1*2 + 2*4 + 2*6 = 2 + 8 + 12 = 22 c0][2] = a[0][0]*b[0][2] + a[0][1]*b[1][2] + a[0][2]*b[2][2] = 1*2 + 2*4 + 2*6 = 2 + 8 + 12 = 22 c[1][0] = a[1][0]*b[0][0] + a[1][1]*b[1][0] + a[1][2]*b[2][0] = 3*1 + 4*3 + 4*5 = 3 + 12 + 20 = 35 c[1][1] = a[1][0]*b[0][1] + a[1][1]*b[1][1] + a[1][2]*b[2][1] = 3*2 + 4*4 + 4*6 = 6 + 16 + 24 = 46 c[1][2] = a[1][0]*b[0][2] + a[1][1]*b[1][2] + a[1][2]*b[2][2] = 3*2 + 4*4 + 4*6 = 6 + 16 + 24 = 46 

所以,结果矩阵c将会是:

[[17, 22, 22], [35, 46, 46]] 

实例2:

a = torch.tensor([[1, 2, 2], [3, 4, 4]])

b = torch.tensor([[1, 2, 2,3], [3, 4, 4,5], [5, 6, 6,6]])

张量a的维度仍然是2x3,但是张量b的维度现在是3x4(因为每一行有4个元素)。矩阵乘法的规则仍然适用,即第一个张量的列数必须等于第二个张量的行数。

由于a的列数(3)与b的行数(3)相等,这两个张量可以进行矩阵乘法运算。结果矩阵c的维度将是a的行数乘以b的列数,即2x4的矩阵。

矩阵乘法的计算方式与之前相同,对于结果矩阵c中的每一个元素c[i][j],它是通过取a的第i行与b的第j列的对应元素的乘积之和得到的。

具体计算如下:

c[0][0] = a[0][0]*b[0][0] + a[0][1]*b[1][0] + a[0][2]*b[2][0] = 1*1 + 2*3 + 2*5 = 1 + 6 + 10 = 17 
c[0][1] = a[0][0]*b[0][1] + a[0][1]*b[1][1] + a[0][2]*b[2][1] = 1*2 + 2*4 + 2*6 = 2 + 8 + 12 = 22 
c[0][2] = a[0][0]*b[0][2] + a[0][1]*b[1][2] + a[0][2]*b[2][2] = 1*2 + 2*4 + 2*6 = 2 + 8 + 12 = 22 
c[0][3] = a[0][0]*b[0][3] + a[0][1]*b[1][3] + a[0][2]*b[2][3] = 1*3 + 2*5 + 2*6 = 3 + 10 + 12 = 25 
c[1][0] = a[1][0]*b[0][0] + a[1][1]*b[1][0] + a[1][2]*b[2][0] = 3*1 + 4*3 + 4*5 = 3 + 12 + 20 = 35c[1][1] = a[1][0]*b[0][1] + a[1][1]*b[1][1] + a[1][2]*b[2][1] = 3*2 + 4*4 + 4*6 = 6 + 16 + 24 = 46c[1][2] = a[1][0]*b[0][2] + a[1][1]*b[1][2] + a[1][2]*b[2][2] = 3*2 + 4*4 + 4*6 = 6 + 16 + 24 = 46 
c[1][3] = a[1][0]*b[0][3] + a[1][1]*b[1][3] + a[1][2]*b[2][3] = 3*3 + 4*5 + 4*6 = 9 + 20 + 24 = 53 

所以,结果矩阵c将会是:

[17, 22, 22, 25], [35, 46, 46, 53]]

实例3:

  如果是mul运算呢?a和b两个张量必须形状相同,例如都是2*3,则对应的行和列分别乘积运算,得到的张量c还是2*3

例如 a = torch.tensor([[1, 2, 3], [3, 4, 5]])
   b = torch.tensor([[5, 6, 7], [7, 8, 9]])

   c=torch.mul(a,b)

使用mul操作符进行逐元素乘法的结果将会是:

[1*5, 2*6, 3*7], [3*7, 4*8, 5*9]]

也就是c[i][j]=a[i][j]*b[i][j]

这篇关于张量乘积运算实例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142225

相关文章

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析

《Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析》InstantiationAwareBeanPostProcessor是Spring... 目录一、什么是InstantiationAwareBeanPostProcessor?二、核心方法解

java String.join()方法实例详解

《javaString.join()方法实例详解》String.join()是Java提供的一个实用方法,用于将多个字符串按照指定的分隔符连接成一个字符串,这一方法是Java8中引入的,极大地简化了... 目录bVARxMJava String.join() 方法详解1. 方法定义2. 基本用法2.1 拼接

C/C++中OpenCV 矩阵运算的实现

《C/C++中OpenCV矩阵运算的实现》本文主要介绍了C/C++中OpenCV矩阵运算的实现,包括基本算术运算(标量与矩阵)、矩阵乘法、转置、逆矩阵、行列式、迹、范数等操作,感兴趣的可以了解一下... 目录矩阵的创建与初始化创建矩阵访问矩阵元素基本的算术运算 ➕➖✖️➗矩阵与标量运算矩阵与矩阵运算 (逐元

Linux lvm实例之如何创建一个专用于MySQL数据存储的LVM卷组

《Linuxlvm实例之如何创建一个专用于MySQL数据存储的LVM卷组》:本文主要介绍使用Linux创建一个专用于MySQL数据存储的LVM卷组的实例,具有很好的参考价值,希望对大家有所帮助,... 目录在Centos 7上创建卷China编程组并配置mysql数据目录1. 检查现有磁盘2. 创建物理卷3. 创

Java List排序实例代码详解

《JavaList排序实例代码详解》:本文主要介绍JavaList排序的相关资料,Java排序方法包括自然排序、自定义排序、Lambda简化及多条件排序,实现灵活且代码简洁,文中通过代码介绍的... 目录一、自然排序二、自定义排序规则三、使用 Lambda 表达式简化 Comparator四、多条件排序五、

Java实例化对象的​7种方式详解

《Java实例化对象的​7种方式详解》在Java中,实例化对象的方式有多种,具体取决于场景需求和设计模式,本文整理了7种常用的方法,文中的示例代码讲解详细,有需要的可以了解下... 目录1. ​new 关键字(直接构造)​2. ​反射(Reflection)​​3. ​克隆(Clone)​​4. ​反序列化