PyTorch基本数据类型(一)


Posted in Python onMay 22, 2019

PyTorch基础入门一:PyTorch基本数据类型

1)Tensor(张量)

Pytorch里面处理的最基本的操作对象就是Tensor(张量),它表示的其实就是一个多维矩阵,并有矩阵相关的运算操作。在使用上和numpy是对应的,它和numpy唯一的不同就是,pytorch可以在GPU上运行,而numpy不可以。所以,我们也可以使用Tensor来代替numpy的使用。当然,二者也可以相互转换。

Tensor的基本数据类型有五种:

  • 32位浮点型:torch.FloatTensor。pyorch.Tensor()默认的就是这种类型。
  • 64位整型:torch.LongTensor。
  • 32位整型:torch.IntTensor。
  • 16位整型:torch.ShortTensor。
  • 64位浮点型:torch.DoubleTensor。

那么如何定义Tensor张量呢?其实定义的方式和numpy一样,直接传入相应的矩阵即可即可。下面就定义了一个三行两列的矩阵:

import torch
# 导包
 
a = torch.Tensor([[1, 2], [3, 4], [5, 6]])
print(a)

不过在项目之中,更多的做法是以特殊值或者随机值初始化一个矩阵,就像下面这样:

import torch
 
# 定义一个3行2列的全为0的矩阵
b = torch.zeros((3, 2))
 
# 定义一个3行2列的随机值矩阵
c = torch.randn((3, 2))
 
# 定义一个3行2列全为1的矩阵
d = torch.ones((3, 2))
 
print(b)
print(c)
print(d)

Tensor和numpy.ndarray之间还可以相互转换,其方式如下:

  • Numpy转化为Tensor:torch.from_numpy(numpy矩阵)
  • Tensor转化为numpy:Tensor矩阵.numpy()

范例如下:

import torch
import numpy as np
 
# 定义一个3行2列的全为0的矩阵
b = torch.randn((3, 2))
 
# tensor转化为numpy
numpy_b = b.numpy()
print(numpy_b)
 
# numpy转化为tensor
numpy_e = np.array([[1, 2], [3, 4], [5, 6]])
torch_e = torch.from_numpy(numpy_e)
 
print(numpy_e)
print(torch_e)

之前说过,numpy与Tensor最大的区别就是在对GPU的支持上。Tensor只需要调用cuda()函数就可以将其转化为能在GPU上运行的类型。

我们可以通过torch.cuda.is_available()函数来判断当前的环境是否支持GPU,如果支持,则返回True。所以,为保险起见,在项目代码中一般采取“先判断,后使用”的策略来保证代码的正常运行,其基本结构如下:

import torch
 
# 定义一个3行2列的全为0的矩阵
tmp = torch.randn((3, 2))
 
# 如果支持GPU,则定义为GPU类型
if torch.cuda.is_available():
  inputs = tmp.cuda()
# 否则,定义为一般的Tensor类型
else:
  inputs = tmp

2)Variable(变量)

Pytorch里面的Variable类型数据功能更加强大,相当于是在Tensor外层套了一个壳子,这个壳子赋予了前向传播,反向传播,自动求导等功能,在计算图的构建中起的很重要的作用。Variable的结构图如下:

PyTorch基本数据类型(一)

其中最重要的两个属性是:data和grad。Data表示该变量保存的实际数据,通过该属性可以访问到它所保存的原始张量类型,而关于该 variable(变量)的梯度会被累计到.grad 上去。

在使用Variable的时候需要从torch.autograd中导入。下面通过一个例子来看一下它自动求导的过程:

import torch
from torch.autograd import Variable
 
# 定义三个Variable变量
x = Variable(torch.Tensor([1, 2, 3]), requires_grad=True)
w = Variable(torch.Tensor([2, 3, 4]), requires_grad=True)
b = Variable(torch.Tensor([3, 4, 5]), requires_grad=True)
 
# 构建计算图,公式为:y = w * x^2 + b
y = w * x * x + b
 
# 自动求导,计算梯度
y.backward(torch.Tensor([1, 1, 1]))
 
print(x.grad)
print(w.grad)
print(b.grad)

上述代码的计算图为y = w * x^2 + b。对x, w, b分别求偏导为:x.grad = 2wx,w.grad=x^2,b.grad=1。代值检验可得计算结果是正确的。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python中的__SLOTS__属性使用示例
Feb 18 Python
Python中的字符串替换操作示例
Jun 27 Python
Python进阶篇之字典操作总结
Nov 16 Python
在 Python 应用中使用 MongoDB的方法
Jan 05 Python
python遍历文件夹下所有excel文件
Jan 03 Python
python字符串的方法与操作大全
Jan 30 Python
更新修改后的Python模块方法
Mar 03 Python
Python编程中类与类的关系详解
Aug 08 Python
python Qt5实现窗体跟踪鼠标移动
Dec 13 Python
Keras中的多分类损失函数用法categorical_crossentropy
Jun 11 Python
Python基于xlrd模块处理合并单元格
Jul 28 Python
Python获取字典中某个key的value
Apr 13 Python
PyTorch搭建多项式回归模型(三)
May 22 #Python
pytorch使用Variable实现线性回归
May 21 #Python
Python面向对象进阶学习
May 21 #Python
谈一谈基于python的面向对象编程基础
May 21 #Python
python字符串和常用数据结构知识总结
May 21 #Python
Opencv实现抠图背景图替换功能
May 21 #Python
python多进程读图提取特征存npy
May 21 #Python
You might like
用PHP+java实现自动新闻滚动窗口
2006/10/09 PHP
不用数据库的多用户文件自由上传投票系统(3)
2006/10/09 PHP
一个用javascript写的select支持上下键、首字母筛选以及回车取值的功能
2009/09/09 Javascript
Javascript学习笔记7 原型链的原理
2010/01/11 Javascript
浅析JQuery UI Dialog的样式设置问题
2013/12/18 Javascript
js创建表单元素并使用submit进行提交
2014/08/14 Javascript
javascript面向对象之this关键词用法分析
2015/01/13 Javascript
Linux下为Node.js程序配置MySQL或Oracle数据库的方法
2016/03/19 Javascript
JavaScript  cookie 跨域访问之广告推广
2016/04/20 Javascript
使用Promise解决多层异步调用的简单学习心得
2016/05/17 Javascript
Vue和Bootstrap的整合思路详解
2017/06/30 Javascript
JavaScript实现图片切换效果
2017/08/12 Javascript
详细分析JS函数去抖和节流
2017/12/05 Javascript
Vue 中使用vue2-highcharts实现top功能的示例
2018/03/05 Javascript
node版本管理工具n包使用教程详解
2018/11/09 Javascript
nodejs异步编程基础之回调函数用法分析
2018/12/26 NodeJs
浅谈JavaScript面向对象--继承
2019/03/20 Javascript
小程序如何使用分包加载的实现方法
2019/05/22 Javascript
在SAE上部署Python的Django框架的一些问题汇总
2015/05/30 Python
基于Python Shell获取hostname和fqdn释疑
2016/01/25 Python
python实现字符串连接的三种方法及其效率、适用场景详解
2017/01/13 Python
python实现关键词提取的示例讲解
2018/04/28 Python
如何在Django配置文件里配置session链接
2019/08/06 Python
Staples加拿大官方网站:办公用品一站式采购
2016/09/25 全球购物
P D PAOLA意大利官网:西班牙著名的珠宝首饰品牌
2019/09/24 全球购物
C#基础面试题
2016/10/17 面试题
幼儿教师思想汇报
2014/01/10 职场文书
新员工欢迎词
2014/01/12 职场文书
城市轨道交通工程职业规划书范文
2014/01/18 职场文书
贸易跟单员英文求职信
2014/04/19 职场文书
庆七一活动总结
2014/08/27 职场文书
2014年世界艾滋病日演讲稿
2014/11/28 职场文书
五年级作文之成长
2019/09/16 职场文书
对讲机的最大通讯距离是多少
2022/02/18 无线电
Win10鼠标轨迹怎么开 Win10显示鼠标轨迹方法
2022/04/06 数码科技
Python 装饰器(decorator)常用的创建方式及解析
2022/04/24 Python