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

相关文章

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

解决IDEA报错:编码GBK的不可映射字符问题

《解决IDEA报错:编码GBK的不可映射字符问题》:本文主要介绍解决IDEA报错:编码GBK的不可映射字符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录IDEA报错:编码GBK的不可映射字符终端软件问题描述原因分析解决方案方法1:将命令改为方法2:右下jav

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

MyBatis模糊查询报错:ParserException: not supported.pos 问题解决

《MyBatis模糊查询报错:ParserException:notsupported.pos问题解决》本文主要介绍了MyBatis模糊查询报错:ParserException:notsuppo... 目录问题描述问题根源错误SQL解析逻辑深层原因分析三种解决方案方案一:使用CONCAT函数(推荐)方案二:

Python中的Walrus运算符分析示例详解

《Python中的Walrus运算符分析示例详解》Python中的Walrus运算符(:=)是Python3.8引入的一个新特性,允许在表达式中同时赋值和返回值,它的核心作用是减少重复计算,提升代码简... 目录1. 在循环中避免重复计算2. 在条件判断中同时赋值变量3. 在列表推导式或字典推导式中简化逻辑