pytorch(python)中遇到的问题(三)Python的.sort()方法和sorted()比较;Pytorch里addmm()和addmm_();torch.stack()

2023-12-31 18:18

本文主要是介绍pytorch(python)中遇到的问题(三)Python的.sort()方法和sorted()比较;Pytorch里addmm()和addmm_();torch.stack(),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 1.Python的.sort()方法和sorted()比较
      • 1.1Python的.sort()方法
      • 1.2Python的sorted()方法
    • 2.Pytorch里addmm()和addmm_()
    • 3. torch.stack()

1.Python的.sort()方法和sorted()比较

  1. 1.1Python的.sort()方法

使用方式是:列表.sort(),作用是将原来的列表正序排序,所以它是对原来的列表进行的操作,不会产生一个新列表,例如:

import  random
numList=[]
print(numList)
for i in range(10):numList.append(random.randrange(1,10))# 不包括10
print("未排序的列表:",numList)
# numList.sort()执行过程是将列表拍完序后又赋值给了原列表
numList.sort()
print("排序后列表:",numList)
# 无法将numList.sort()赋值给一个新列表,以为它并不返回一个新列表
numList=numList.sort()
print("无法赋值给新列表的的结果:",numList)

输出结果为:
在这里插入图片描述

  1. 1.2Python的sorted()方法

sorted(列表),是Python内置函数,该函数对原列表不会产生影响,只是在原来列表的基础上,产生一个有序的新列表,可以复制一个列表名。

import  random
numList=[]
print(numList)
for i in range(10):numList.append(random.randrange(1,10))# 不包括10
print("未排序的列表:",numList)sorted(numList)
print("sorted排序后的数组,不会对原列表有任何影响:",numList)
getList=sorted(numList)
print("sorted获得的新的列表:",getList)

结果为:

在这里插入图片描述

2.Pytorch里addmm()和addmm_()

这里参考的是https://blog.csdn.net/qq_36556893/article/details/90638449

函数解释:在torch/_C/_VariableFunctions.py的有该定义,意义就是实现一下公式:
在这里插入图片描述
换句话说,就是需要传入5个参数,mat里的每个元素乘以beta,mat1和mat2进行矩阵乘法(左行乘右列)后再乘以alpha,最后将这2个结果加在一起。

def addmm(self, beta=1, mat, alpha=1, mat1, mat2, out=None): # real signature unknown; restored from __doc__        Example::>>> M = torch.randn(2, 3)>>> mat1 = torch.randn(2, 3)>>> mat2 = torch.randn(3, 3)>>> torch.addmm(M, mat1, mat2)tensor([[-4.8716,  1.4671, -1.3746],[ 0.7573, -3.9555, -2.8681]])pass

首先介绍一下两矩阵相乘:
在这里插入图片描述
得到的结果为:
在这里插入图片描述

  1. 不加参数形式为:
 torch.addmm(input, mat1, mat2) = inputs.addmm(mat1, mat2)

完成的公式为:

1 × inputs + 1 ×(inputs_t @ inputs_t)

  1. 另外加上一个参数beta的形式:
 '''1 * inputs + 1 * (inputs_t @ inputs_t)'''
g = inputs.addmm(1, inputs_t, inputs_t)
'''2 * inputs + 1 * (inputs_t @ inputs_t)'''
g2 = inputs.addmm(2, inputs_t, inputs_t)

加一个参数,实际上是添加了beta这个参数

完成的公式为:

g = 1 × inputs + 1 ×(inputs_t @ inputs_t)

g2 = 2 × inputs + 1 ×(inputs_t @ inputs_t)

  1. 再加上一个参数了alpha的表示形式为:
'''h = 1 * inputs + 1 * (inputs_t @ inputs_t)'''
h = inputs.addmm(1, 1, inputs_t, inputs_t)
'''h12 = 1 * inputs + 2 * (inputs_t @ inputs_t)'''
h12 = inputs.addmm(1, 2, inputs_t, inputs_t)
'''h21 = 2 * inputs + 1 * (inputs_t @ inputs_t)'''
h21 = inputs.addmm(2, 1, inputs_t, inputs_t)

再加一个参数,实际上是添加了alpha这个参数

完成的公式为:

h = 1 × inputs + 1 ×(inputs_t @ inputs_t)

h12 = 1 × inputs + 2 ×(inputs_t @ inputs_t)

h21 = 2 × inputs + 1 ×(inputs_t @ inputs_t)

addmm_()的操作和addmm()函数功能相同,区别就是addmm_()有inplace的操作,也就是在原对象基础上进行修改,即把改变之后的变量再赋给原来的变量。例如:
inputs的值变成了改变之后的值,不用再去写 某个变量=addmm_() 了,因为inputs就是改变之后的变量!

3. torch.stack()

对于torch.stack()用法,d=torch.stack( (a,b,c) ,dim = 2)
首先定义三个矩阵
在这里插入图片描述
如果我想把这三个tensor的最后一个维度的元素相叠加,形成一个新的tensor

输入 d=torch.stack( (a,b,c) ,dim = 2)

然后看一下操作后的结果

n=torch.stack((a,b,c),dim = 0)
print('n',n)
m=torch.stack((a,b,c),dim = 1)
print('m',m)
d=torch.stack( (a,b,c) ,dim = 2)
print('d',d)

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
从上面我们可以看到结果,由结果可知:
stack函数中 dim=2,也即第三个维度,即最终的生成结果位于第三个维度,而不是说原来的元素是第三个维度。
pytorch中维度的命名是从0开始的

对于三维矩阵将最后一个维度还有另外一种写法,写dim=-1,不管你原来是啥,我就指定最后一个维度:
在这里插入图片描述
也就是说无论是矩阵是几维的,dim=-1就是最后一维,dim=-2就是倒数第二维,
在这里插入图片描述

参考:1.https://blog.csdn.net/qq_36556893/article/details/90638449

这篇关于pytorch(python)中遇到的问题(三)Python的.sort()方法和sorted()比较;Pytorch里addmm()和addmm_();torch.stack()的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

java导出pdf文件的详细实现方法

《java导出pdf文件的详细实现方法》:本文主要介绍java导出pdf文件的详细实现方法,包括制作模板、获取中文字体文件、实现后端服务以及前端发起请求并生成下载链接,需要的朋友可以参考下... 目录使用注意点包含内容1、制作pdf模板2、获取pdf导出中文需要的文件3、实现4、前端发起请求并生成下载链接使

讯飞webapi语音识别接口调用示例代码(python)

《讯飞webapi语音识别接口调用示例代码(python)》:本文主要介绍如何使用Python3调用讯飞WebAPI语音识别接口,重点解决了在处理语音识别结果时判断是否为最后一帧的问题,通过运行代... 目录前言一、环境二、引入库三、代码实例四、运行结果五、总结前言基于python3 讯飞webAPI语音

基于Python开发PDF转PNG的可视化工具

《基于Python开发PDF转PNG的可视化工具》在数字文档处理领域,PDF到图像格式的转换是常见需求,本文介绍如何利用Python的PyMuPDF库和Tkinter框架开发一个带图形界面的PDF转P... 目录一、引言二、功能特性三、技术架构1. 技术栈组成2. 系统架构javascript设计3.效果图

Linux虚拟机不显示IP地址的解决方法(亲测有效)

《Linux虚拟机不显示IP地址的解决方法(亲测有效)》本文主要介绍了通过VMware新装的Linux系统没有IP地址的解决方法,主要步骤包括:关闭虚拟机、打开VM虚拟网络编辑器、还原VMnet8或修... 目录前言步骤0.问题情况1.关闭虚拟机2.China编程打开VM虚拟网络编辑器3.1 方法一:点击还原VM

Flask解决指定端口无法生效问题

《Flask解决指定端口无法生效问题》文章讲述了在使用PyCharm开发Flask应用时,启动地址与手动指定的IP端口不一致的问题,通过修改PyCharm的运行配置,将Flask项目的运行模式从Fla... 目录android问题重现解决方案问题重现手动指定的IP端口是app.run(host='0.0.

Android WebView无法加载H5页面的常见问题和解决方法

《AndroidWebView无法加载H5页面的常见问题和解决方法》AndroidWebView是一种视图组件,使得Android应用能够显示网页内容,它基于Chromium,具备现代浏览器的许多功... 目录1. WebView 简介2. 常见问题3. 网络权限设置4. 启用 JavaScript5. D

Python如何在Word中生成多种不同类型的图表

《Python如何在Word中生成多种不同类型的图表》Word文档中插入图表不仅能直观呈现数据,还能提升文档的可读性和专业性,本文将介绍如何使用Python在Word文档中创建和自定义各种图表,需要的... 目录在Word中创建柱形图在Word中创建条形图在Word中创建折线图在Word中创建饼图在Word

Seata之分布式事务问题及解决方案

《Seata之分布式事务问题及解决方案》:本文主要介绍Seata之分布式事务问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Seata–分布式事务解决方案简介同类产品对比环境搭建1.微服务2.SQL3.seata-server4.微服务配置事务模式1

Java捕获ThreadPoolExecutor内部线程异常的四种方法

《Java捕获ThreadPoolExecutor内部线程异常的四种方法》这篇文章主要为大家详细介绍了Java捕获ThreadPoolExecutor内部线程异常的四种方法,文中的示例代码讲解详细,感... 目录方案 1方案 2方案 3方案 4结论方案 1使用 execute + try-catch 记录

Python Excel实现自动添加编号

《PythonExcel实现自动添加编号》这篇文章主要为大家详细介绍了如何使用Python在Excel中实现自动添加编号效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、背景介绍2、库的安装3、核心代码4、完整代码1、背景介绍简单的说,就是在Excel中有一列h=会有重复