Pytorch学习要点整理

本文总结了PyTorch的学习要点,包括官方教程的精华内容和中文教程的亮点。阐述了PyTorch的动态计算图优势、与TensorFlow的差异,以及张量操作、自动求导的使用。还介绍了空间变换器网络、注意力机制的实现,并讨论了图像尺寸处理的方法。此外,提到了预训练模型的使用和多GPU训练策略。
摘要由CSDN通过智能技术生成

Pytorch学习要点整理

PyTorch是一个基于Torch的Python开源机器学习库,用于自然语言处理等应用程序。它主要由Facebookd的人工智能小组开发,不仅能够实现强大的GPU加速,同时还支持动态神经网络,这一点是现在很多主流框架如TensorFlow都不支持的。 PyTorch提供了两个高级功能:
1.具有强大的GPU加速的张量计算(如Numpy)
2.包含自动求导系统的深度神经网络 除了Facebook之外,Twitter、GMU和Salesforce等机构都采用了PyTorch。

TensorFlow和Pytorch的区别
(1)tensorflow是基于静态图的,静态图是先定义在运行,一次定义多次运行(当然TensorFlow开始也使用动态计算图)
(2)Pytorch则是基于动态计算图是在运行过程中被定义的,在运行的时候构建,可以多次构建多次运行。

  • 当修改numpy数组之后,与之关联的tensor也会相应的被修改
    通过.numpy将Pytorch中的tensor转换成numpy中的数组,通过Torch.Tensor将Numpy数组转换为Torch Tensor

  • 怎么用autograd
    (1)跟踪Tensor上的所有操作:设置属性requires_grad= True
    (2)自动计算所有梯度:调用.backward()
    (3) 停止跟踪Tensor 方式1:调用detach()方式2:代码块with torch. no grad
    (4) 若Tensor不仅仅是标量,则需要指定gradient参数来指定张量的形式

一、官方教程内容总结

官方教程
1.Any operation that mutates a tensor in-place is post-fixed with an . For example: x.copy(y), x.t_(), will change x.
只要是原地操作张亮一般都是加一个下划线。
2.如果resize或者reshape一个tensor的话可以使用torch.view

x = torch.randn(4, 4)
y = x.view(16)
z = x.view(-1, 8)
  1. 如果torch是在cpu上&
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值