热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

PyTorch入门使用

1.张量Tensor张量是一个统称,其中包括很多类型:0阶张量:标量、常数,0-DTensor1阶张量:向量&

1. 张量 Tensor


张量是一个统称,其中包括很多类型:

0 阶张量:标量、常数,0-D Tensor

1 阶张量:向量,1-D Tensor

2 阶张量:矩阵,2-D Tensor

3 阶张量

...

n 阶张量



2. PyTorch 中张量的创建


使用 python 中的列表或序列创建张量


import torcha = torch.tensor([[1, -1], [2, 3]])
print(a, type(a))# 输出结果
tensor([[ 1, -1],[ 2, 3]])

使用 numpy 中的数组创建张量


import torch
import numpy as npa = torch.tensor(np.array([[1, -1], [2, 3]]))
print(a, type(a))# 输出结果
tensor([[ 1, -1],[ 2, 3]], dtype=torch.int32)

使用 torch 中的 api 创建张量


# 创建3x4的空张量,用无用数据填充
torch.empty(3, 4)
# 创建3x4的全是1的张量
torch.ones([3, 4])
# 创建3x4的全是0的张量
torch.zeros([3, 4])
# 创建3x4的全是随机数的张量,随机区间[0, 1)
torch.rand([3, 4])
# 创建3x4的随机整数张量,随机区间[low, high)
torch.randint(low=0, high=10, size=[3, 4])
# 创建3x4的随机数张量,随机值得分布均值为0,方差为1
torch.randn([3, 4])


3. PyTorch 中的常用方法


tensor.item()   从张量中获取数据(当张量中仅有一个数据可用)


import torch
import numpy as npa = torch.tensor(np.arange(1))
print(a)
print(a.item())# 输出结果
tensor([0], dtype=torch.int32)
0

转化为 numpy 数组


import torch
import numpy as npa = torch.tensor(np.array([[1, -1], [2, 3]]))
print(a)
print(a.numpy())# 输出结果
tensor([[ 1, -1],[ 2, 3]], dtype=torch.int32)
[[ 1 -1][ 2 3]]

tensor.size()   获取张量形状


import torch
import numpy as npa = torch.tensor(np.array([[1, -1], [2, 3]]))
print(a)
print(a.size())# 输出结果
tensor([[ 1, -1],[ 2, 3]], dtype=torch.int32)
torch.Size([2, 2])

tensor.view()   改变张量形状,浅拷贝,仅仅改变形状


import torch
import numpy as npa = torch.tensor(np.array([[1, -1], [2, 3]]))
print(a)
b = a.view((1, 4))
print(b)# 输出结果
tensor([[ 1, -1],[ 2, 3]], dtype=torch.int32)
tensor([[ 1, -1, 2, 3]], dtype=torch.int32)

tensor.dim()   获取维数

tensor.max()   获取最大值

tensor.min()   获取最小值

tensor.std()   获取标准差

tensor.t() / tensor.transpose()  转置


import torch
import numpy as npa = torch.tensor(np.array([[1, -1], [2, 3]]))
print(a)
print(a.dim())
print(a.max())
print(a.t())# 输出结果
tensor([[ 1, -1],[ 2, 3]], dtype=torch.int32)
2
tensor(3, dtype=torch.int32)
tensor([[ 1, 2],[-1, 3]], dtype=torch.int32)

tensor[1, 3]   获取张量中第一行第三列的值(从 0 行 0 列开始)

tensor[1, 3]=100   对张量中第一行第三列的位置赋值 100

tensor[1, 2, 0]   切片


import torch
import numpy as npa = torch.tensor(np.array([[1, -1], [2, 3]]))
print(a[1, 0])
a[1, 0] = 100
print(a)# 输出结果
tensor(2, dtype=torch.int32)
tensor([[ 1, -1],[100, 3]], dtype=torch.int32)

4. Tensor 的数据类型


常用的不同数据类型的 Tensor,有 32 位的浮点型 torch.FloatTensor,   64 位浮点型 torch.DoubleTensor,   16 位整形 torch.ShortTensor,    32 位整形 torch.IntTensor 和 64 位整形 torch.LongTensor。


关于数据类型的常用方法:


tensor.dtype   获取张量的数据类型


import torch
import numpy as npa = torch.tensor(np.array([[1, -1], [2, 3]]))
print(a, a.dtype)# 输出结果
tensor([[ 1, -1],[ 2, 3]], dtype=torch.int32) torch.int32

创建张量时指定数据类型


import torch
import numpy as npa = torch.tensor(np.array([[1, -1], [2, 3]]), dtype=torch.float32)
print(a, a.dtype)# 输出结果
tensor([[ 1., -1.],[ 2., 3.]]) torch.float32

修改数据类型


import torch
import numpy as npa = torch.tensor(np.array([[1, -1], [2, 3]]), dtype=torch.int32)
print(a, a.dtype)
a = a.type(torch.float)
print(a, a.dtype)# 输出结果
tensor([[ 1, -1],[ 2, 3]], dtype=torch.int32) torch.int32
tensor([[ 1., -1.],[ 2., 3.]]) torch.float32

 


推荐阅读
  • 本文介绍了Python对Excel文件的读取方法,包括模块的安装和使用。通过安装xlrd、xlwt、xlutils、pyExcelerator等模块,可以实现对Excel文件的读取和处理。具体的读取方法包括打开excel文件、抓取所有sheet的名称、定位到指定的表单等。本文提供了两种定位表单的方式,并给出了相应的代码示例。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • Python瓦片图下载、合并、绘图、标记的代码示例
    本文提供了Python瓦片图下载、合并、绘图、标记的代码示例,包括下载代码、多线程下载、图像处理等功能。通过参考geoserver,使用PIL、cv2、numpy、gdal、osr等库实现了瓦片图的下载、合并、绘图和标记功能。代码示例详细介绍了各个功能的实现方法,供读者参考使用。 ... [详细]
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
  • Day2列表、字典、集合操作详解
    本文详细介绍了列表、字典、集合的操作方法,包括定义列表、访问列表元素、字符串操作、字典操作、集合操作、文件操作、字符编码与转码等内容。内容详实,适合初学者参考。 ... [详细]
  • 基于dlib的人脸68特征点提取(眨眼张嘴检测)python版本
    文章目录引言开发环境和库流程设计张嘴和闭眼的检测引言(1)利用Dlib官方训练好的模型“shape_predictor_68_face_landmarks.dat”进行68个点标定 ... [详细]
  • 十大经典排序算法动图演示+Python实现
    本文介绍了十大经典排序算法的原理、演示和Python实现。排序算法分为内部排序和外部排序,常见的内部排序算法有插入排序、希尔排序、选择排序、冒泡排序、归并排序、快速排序、堆排序、基数排序等。文章还解释了时间复杂度和稳定性的概念,并提供了相关的名词解释。 ... [详细]
  • Python使用Pillow包生成验证码图片的方法
    本文介绍了使用Python中的Pillow包生成验证码图片的方法。通过随机生成数字和符号,并添加干扰象素,生成一幅验证码图片。需要配置好Python环境,并安装Pillow库。代码实现包括导入Pillow包和随机模块,定义随机生成字母、数字和字体颜色的函数。 ... [详细]
  • 超级简单加解密工具的方案和功能
    本文介绍了一个超级简单的加解密工具的方案和功能。该工具可以读取文件头,并根据特定长度进行加密,加密后将加密部分写入源文件。同时,该工具也支持解密操作。加密和解密过程是可逆的。本文还提到了一些相关的功能和使用方法,并给出了Python代码示例。 ... [详细]
  • 本文介绍了贝叶斯垃圾邮件分类的机器学习代码,代码来源于https://www.cnblogs.com/huangyc/p/10327209.html,并对代码进行了简介。朴素贝叶斯分类器训练函数包括求p(Ci)和基于词汇表的p(w|Ci)。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
author-avatar
灬哭着说再见灬
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有