【基础篇】-tensor(张量)_tensor.div-程序员宅基地

技术标签: # Pytorch笔记  

【基础】-tensor(张量)

一.创建一个tensor

1.只分配空间

x1 = torch.Tensor(5, 3)          # 数据是随机的,只是分配了可见,没有初始化,所及数据是对应空间里的数据
print(x1)

输出:

tensor([[7.3470e-39, 8.9082e-39, 8.9082e-39],
        [1.0194e-38, 9.1837e-39, 4.6837e-39],
        [9.2755e-39, 1.0837e-38, 8.4490e-39],
        [9.9184e-39, 9.9184e-39, 9.0000e-39],
        [1.0561e-38, 1.0653e-38, 4.1327e-39]])

2.0-1分布

x2 = torch.rand(5, 3)            # 使用[0,1]分布(默认的)随机初始化数据,构建(5, 3)shape的数组
print(x2)

输出:

tensor([[0.0786, 0.0817, 0.5277],
        [0.3758, 0.9402, 0.2716],
        [0.0723, 0.3258, 0.7880],
        [0.9141, 0.7395, 0.1126],
        [0.9843, 0.5128, 0.9107]])

3.直接创建

x3 = torch.tensor([ [1,2,3,4],
                    [5,6,7,8]])
print(x3)

输出:

tensor([[1, 2, 3, 4],
        [5, 6, 7, 8]])

4.同一个数值

x4 = torch.full((5, 3), 6)
print(x4)

输出:

tensor([[6., 6., 6.],
        [6., 6., 6.],
        [6., 6., 6.],
        [6., 6., 6.],
        [6., 6., 6.]])

5.在一个区间内按一定步长

x5 = torch.arange(0, 100, 10)     # 从0到99,按步长为10进行生成
print(x5)

输出:

tensor([ 0, 10, 20, 30, 40, 50, 60, 70, 80, 90])

或者:
在一定区间内均匀生成多少份,步长自动计算

x6 = torch.linspace(0, 100, 10)   # 在0到100均匀生成10份
print(x6)

输出:

tensor([  0.0000,  11.1111,  22.2222,  33.3333,  44.4444,  55.5556,  66.6667,
         77.7778,  88.8889, 100.0000])

这里可见看出来使用torch.linspace包含end,0到100分成10个数,相对于在0到100的线段上均匀定9个点,100/9 = 11.111111······,所以,步长为11.11111.
如果生成11份,步长就为10了。
输出:

tensor([  0.,  10.,  20.,  30.,  40.,  50.,  60.,  70.,  80.,  90., 100.])

6.特殊矩阵

# 特殊矩阵
x7 = torch.zeros(5, 3)          # 全0矩阵
print(x7)

x8 = torch.ones(5, 3)           # 全1矩阵
print(x8)

x9 = torch.eye(3, 3)            # 单位阵
print(x9)

x10 = torch.eye(5, 3)           # 当输入shape不是方阵时,一部分是单位阵,多出来的部分为0
print(x10)

输出:

tensor([[0., 0., 0.],
        [0., 0., 0.],
        [0., 0., 0.],
        [0., 0., 0.],
        [0., 0., 0.]])
        
tensor([[1., 1., 1.],
        [1., 1., 1.],
        [1., 1., 1.],
        [1., 1., 1.],
        [1., 1., 1.]])
        
tensor([[1., 0., 0.],
        [0., 1., 0.],
        [0., 0., 1.]])
        
tensor([[1., 0., 0.],
        [0., 1., 0.],
        [0., 0., 1.],
        [0., 0., 0.],
        [0., 0., 0.]])

7.生成一个与已知tensor的shape相同的tensor

x11 = torch.rand_like(x10)
print(x11)

输出:

tensor([[0.2761, 0.7960, 0.0800],
        [0.3035, 0.3525, 0.5574],
        [0.3570, 0.5426, 0.4790],
        [0.3504, 0.3996, 0.1984],
        [0.5939, 0.3260, 0.6721]])

8.从numpy转

x12 = np.random.rand(5, 3)
print(x12)
x12 = torch.from_numpy(x12)
print(x12)

输出:

[[0.14858865 0.18512316 0.97759539]
 [0.96559993 0.75191884 0.1561388 ]
 [0.71575248 0.88542421 0.29086326]
 [0.67362585 0.00512253 0.34022816]
 [0.69759491 0.25110932 0.71962754]]
tensor([[0.1486, 0.1851, 0.9776],
        [0.9656, 0.7519, 0.1561],
        [0.7158, 0.8854, 0.2909],
        [0.6736, 0.0051, 0.3402],
        [0.6976, 0.2511, 0.7196]], dtype=torch.float64)

二.tensor的属性

x2 = torch.rand(5, 3)            # 使用[0,1]分布(默认的)随机初始化数据,构建(5, 3)shape的数组
print(x2)
print(x2.size())   # (列,行)
print(x2.shape)    # (列, 行)
print(x2.dtype)    # 数据类型

输出:

tensor([[0.6725, 0.6270, 0.0352],
        [0.0420, 0.4865, 0.7263],
        [0.9950, 0.3957, 0.3868],
        [0.3802, 0.3337, 0.0465],
        [0.0089, 0.7211, 0.1279]])
torch.Size([5, 3])
torch.Size([5, 3])
torch.float32

三.tensor的操作

1.加
import torch

x1 = torch.randint(0, 10, (5, 3), dtype=torch.float)
print(x1)

x2 = torch.eye(5, 3)
print(x2)

# 1
print(x1 + x2)
# 2
print(torch.add(x1, x2))
# 3
print(x1.add(x2))
# 4
sum = torch.Tensor(5, 3)     # 预先分配空间
torch.add(x1, x2, out=sum)       # 加的结果保存在sum里
print(sum)

输出:

tensor([[5., 5., 8.],
        [9., 3., 8.],
        [9., 8., 3.],
        [5., 5., 6.],
        [6., 9., 5.]])
        
tensor([[1., 0., 0.],
        [0., 1., 0.],
        [0., 0., 1.],
        [0., 0., 0.],
        [0., 0., 0.]])
        
tensor([[6., 5., 8.],
        [9., 4., 8.],
        [9., 8., 4.],
        [5., 5., 6.],
        [6., 9., 5.]])
        
tensor([[6., 5., 8.],
        [9., 4., 8.],
        [9., 8., 4.],
        [5., 5., 6.],
        [6., 9., 5.]])
        
tensor([[6., 5., 8.],
        [9., 4., 8.],
        [9., 8., 4.],
        [5., 5., 6.],
        [6., 9., 5.]])
        
tensor([[6., 5., 8.],
        [9., 4., 8.],
        [9., 8., 4.],
        [5., 5., 6.],
        [6., 9., 5.]])
tensor1.add()和tensor1.add_()的区别

这个算是和python的特性一致,不加下划线的第一种就是普通的加法,不会改变tensor1的内容。而加了下划线,即第二种,加的结果会赋值给tensor1。
例子:

print(x1.add(x2))
print(x1)
print(x1.add_(x2))
print(x1)

输出:

tensor([[5., 8., 9.],
        [2., 4., 3.],
        [6., 2., 9.],
        [3., 1., 3.],
        [8., 5., 9.]])
        
tensor([[4., 8., 9.],
        [2., 3., 3.],
        [6., 2., 8.],
        [3., 1., 3.],
        [8., 5., 9.]])
        
tensor([[5., 8., 9.],
        [2., 4., 3.],
        [6., 2., 9.],
        [3., 1., 3.],
        [8., 5., 9.]])
        
tensor([[5., 8., 9.],
        [2., 4., 3.],
        [6., 2., 9.],
        [3., 1., 3.],
        [8., 5., 9.]])
其余运算

其他的减法,乘法,除法均可使用:-,*,/。同时也可以使用

  • torch.sub() 减法
  • torch.mul() 乘法,只是简单的对应位置相乘,不是矩阵的乘法
  • torch.div() 除法,对应位置相除

或者

  • tensor1.sub(tensor2)
  • tensor1.mul(tensor2)
  • tensor.div(tensor2)
    上面三种加也可以加下划线,和add的例子相同。

其中,如果被除数为0,会出现这样的结果:

tensor([[9., inf, inf],
        [inf, 6., inf],
        [inf, inf, 0.],
        [nan, inf, inf],
        [inf, inf, inf]])

上面的三种运算中torch.sub()这种也都可以添加out=.

此外,还有很多其他的运算,基本都比较简单。

可能的一些错误
RuntimeError: expected backend CPU and dtype Float but got backend CPU and dtype Long

这种情况,根据提示信息就是数据的类型不对。
一般可以在创建tensor的时候添加dtype=torch.float类似的语句来改。也可以使用tensor1.float()来修改

查看tensor的数据类型时:使用tensor1.dtype

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_40802676/article/details/104231745

智能推荐

svn 分支(branch)和标签(tag)管理-程序员宅基地

文章浏览阅读1.4w次,点赞12次,收藏61次。svn的分支管理_svn 分支

Python 入门的60个基础练习_练习python基础语法-程序员宅基地

文章浏览阅读4.2w次,点赞329次,收藏2.7k次。Python 入门的60个基础练习_练习python基础语法

iOS6和iOS7代码的适配(2)——status bar_ios7 statusbar-程序员宅基地

文章浏览阅读1w次。用Xcode5运行一下应用,第一个看到的就是status bar的变化。在iOS6中,status bar是系统在处理,应用_ios7 statusbar

gdb调试时No symbol "var" defined in current context && No Register_no registers调试显示-程序员宅基地

文章浏览阅读2.1k次。问题描述:,在gdb调试程序输出变量:p var,会提示No symbol "var" in current context.原因:程序编译时开启了优化选项,那么在用GDB调试被优化过的程序时,可能会发生某些变量不能访问,或是取值错误码的情况。这个是很正常的,因为优化程序会删改程序,整理程序的语句顺序,剔除一些无意义的变量等,所以在GDB调试这种程序时,运行时的指令和你所编写指_no registers调试显示

IDGeneratorUtil 主键id生成工具类_idgeneratorutils.generateid()-程序员宅基地

文章浏览阅读3.4k次。import java.util.Random;import org.drools.util.UUIDGenerator;/** * * * 类名称:GenerateIdUtil * 类描述: 主键生成工具类 * @author chenly * 创建时间:Jul 10, 2012 8:10:43 AM * 修改人: * 修改时间:Jul 10, 2012 8..._idgeneratorutils.generateid()

关于汇编 BX 和 BLX 跳转指令_汇编blx-程序员宅基地

文章浏览阅读5k次。BX:跳转到寄存器reg给出的目的地址处,如:BX R2BLX:跳转到寄存区reg给出的目的地址处并将返回地址存储到LR(R14)使用这两个指令时有一点特别需要注意:跳转的目的地址必须是奇数,若不是奇数则在后面加1,如某函数的起始地址是0x80000f00,则要跳转到此函数则应该跳转到0x80000f01处!否则会进入硬件错误中断!..._汇编blx

随便推点

java.lang.ClassNotFoundException: org.springframework.core.io.Resource 解决办法-程序员宅基地

文章浏览阅读1.7w次。问题描述: 在使用maven依赖项spring MVC、Hibernate和Struts2构建REST web项目之后,我将项目进行打包 “ProcjectName.war”,并通过tomcat manager html页面将其上传到 Linux 的tomcat 服务器,它可以正常工作。但是当我尝试在本地tomcat服务器 (Windows平台)上部署war时,我从tomcat catali..._org.springframework.core.io.resource

添加远程github仓库时报错 Warning: Permanently added the RSA host key for IP address 52.74.223.119_cmd warning: permanently added-程序员宅基地

文章浏览阅读9.7k次。1.问题展示2.解决方案1.任意窗口, 打开git bash2.命令行界面, 输入cd C:3.cat ~/.ssh/id_rsa.pub正常下面应该显示一大串公钥如果没有,显示如下图, 则进行下一步, 创建公钥4.创建公钥, 输入 ssh-keygen5.然后一直下一步, 直到出现6.再次输入cat ~/.ssh/id_rsa.pub下面一大串数字便是公钥,复制这些字符串, 打开github, 点击头像, 打开settings, 打开SSH and GPG Keys_cmd warning: permanently added

SQL*Plus 使用技巧1-程序员宅基地

文章浏览阅读154次。[code="java"]1. SQL/Plus 常用命令 a. help [topic] 查看命令的使用方法,topic表示需要查看的命令名称。 如: help desc; b. host 该命令可以从SQL*Plus环境切换到操作系统环境,以便执行操作系统命名。 c. host [command] 在sql*plus环境中执行操作系统命令,如:host notepad.exe..._sql+plus的使用方法

域控服务器搭建与管理论文,校园网络服务器的配置与管理 毕业论文.doc-程序员宅基地

文章浏览阅读441次。该文档均来自互联网,如果侵犯了您的个人权益,请联系我们将立即删除!**学校毕 业 论 文**学校园网络服务器的配置与管理姓 名: **学 号: **指导老师:系 名:专 业: 计算机网络技术班 级:二0一一年十二月十五日摘 要随着网络技术的不断发展和Internet的日益普及,许多学校都建立了校园网络并投入使用,这无疑对加快信息处理,提高工作效..._服务器配置与应用论文

mysql单实例多库与多实例单库_数据库单实例和多实例-程序员宅基地

文章浏览阅读1k次。一、单实例多库:一个mysql实例,创建多个数据目录。规划:实例路径:/usr/local/mysql数据目录路径:(1)/usr/local/mysql/data(2)/usr/local/mysql/data2步骤:安装mysql。配置my.cnf文件。初始化各个数据库。用mysqld_multi启动。1、安装mysql。平常安装。2、m..._数据库单实例和多实例

MFC解决找不到MFC90.DLL的问题_microsoft v90.debugmfc-程序员宅基地

文章浏览阅读6.3k次。今天装了第三方的MFC软件库Xtreme ToolkitPro v15.0.1,听说搞MFC的人都知道它的强大,我刚学习,所以装了一个,然后想运行一下它自带的例子看看。出现一个“找不到mfc90.dll“的问题,百度一下,记录如下:vs2008已经打过sp1补丁,编译C++程序会提示找不到mfc90.dll文件的错误,但是如果是release版的话就能正常运行csdn看到解决方案,粘贴_microsoft v90.debugmfc