当前位置:
首页
文章
后端
详情

pytorch怎么用?Python深度学习初探

对于python最近最火的方向很多小伙伴都会脱口而出——机器学习,而深度学习作为机器学习的一部分python也适用于此。python深度学习里面最出名的库/框架应该算pytorch了,接下来这篇文章小编带你了解一下pytorch怎么用吧。

    一、Tensor

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

    0阶张量:标量、常数、0-D Tensor;1阶张量:向量、1-D Tensor;2阶张量:矩阵、2-D Tensor;……

    二、Pytorch如何创建张量

    2.1 创建张量

    import torch
    	
    	t = torch.Tensor([1, 2, 3])
    	print(t)

    创建张量

    2.2 tensor与ndarray的关系

    两者之间可以相互转化

    import torch
    import numpy as np
    
    t1 = np.array(torch.Tensor([[1, 2, 3],
            [1, 2, 3]]))
    t2 = torch.Tensor(np.array([[1, 2, 3],
            [1, 2, 3]]))
    

    运行结果:

    运行结果

    2.3 常用api

    torch.empty(x,y)

    创建x行y列为空的tensor。

    置空

    torch.ones([x, y])

    创建x行y列全为1的tensor。

    置1

    torch.zeros([x,y])

    创建x行y列全为0的temsor。

    置零

    zeros与empty的区别

    后者的数据类型是不固定的。

    torch.rand(x, y)

    创建3行4列的随机数,随机数是0-1。

    随机矩阵


    torch.randint(low, high, size)

    创建一个size的tensor,随机数为low到high之间。

    随机定区间矩阵

    torch.randn([x, y])

    创建一个x行y列的tensor,随机数的分布式均值为0,方差1。

    2.4 常用方法

    item()

    获取tensor中的元素,注意只有一个元素的时候才可以用。

    获取元素


    numpy()

    转化成ndarray类型。

    转化为其他类型

    size()

    获取tensor的形状

    获取大小

    view()

    浅拷贝,tensor的形状改变

    可以传参,表示获取第几个。若参数为-1,表示不确定,与另一个参数的乘积等于原始形状的乘积。 例如:原始形状为8,则view(-1,2)view(4, 2); 参数只有-1,表示一维。

    浅拷贝

    dim()

    获取维度。

    获取维度

    max()

    获取最大值。

    获取最大值

    t()

    转置。

    转置矩阵

    transpose(x,y)

    x,y是size里面返回的形状相换。

    形状变换

    permute()

    传入size()返回的形状的顺序。

    返回形状数据

    transpose与permute的区别

    前者传入列即可相互交换;后者传入列会根据传入的顺序来进行转化,且需要传入所有列数的索引。

    取值[第一阶, 第二阶,……]

    一个逗号隔开代表一个阶乘冒号代表全取

    取值

    赋值[第一阶, 第二阶,……]

    直接赋值即可

    赋值


    三、数据类型


    数据类型

    3.1 获取数据类型

    tensor.dtype

    获取数据类型

    获取数据类型

    设置数据类型

    注意使用Tensor()不能指定数据类型。

    设置数据类型

    type()

    修改数据类型。

    修改数据类型

    四、tensor的其他操作

    4.1 相加

    torch.add(x, y)

    将x和y相加

    矩阵相加

    直接相加

    直接相加

    tensor.add()

    使用add_() 可相加后直接保存在tensor中

    矩阵相加

    4.2 tensor与数字的操作

    tensor + 数值

    矩阵加法

    五、CUDA中的tensor

    CUDA (Compute Unified Device Architecture),是NVIDIA推出的运算平台。CUDATM是一种由NVIDIA推出的通用并行计算架构,该架构使GPU能够解决复杂的计算问题。
    torch.cuda这个模块增加了对CUDA tensor的支持,能够在cpu和gpu上使用相同的方法操作tensor通过.to方法能够把一个tensor转移到另外一个设备(比如从CPU转到GPU)

    可以使用torch.cuda.is_available()判断电脑是否支持GPU

    到此这篇pytorch怎么用的文章就介绍到这了,值得一提的是,本文力求精简所以在一些详细的地方并没有深入介绍,如果需要相应的收藏可以关注W3Cschool搜索相关的手册。


    免责申明:本站发布的内容(图片、视频和文字)以转载和分享为主,文章观点不代表本站立场,如涉及侵权请联系站长邮箱:xbc-online@qq.com进行反馈,一经查实,将立刻删除涉嫌侵权内容。

    同类热门文章

    深入了解C++中的new操作符:使用具体实例学习

    C++中的new操作符是动态分配内存的主要手段之一。在程序运行时,我们可能需要动态地创建和销毁对象,而new就是为此提供了便利。但是,使用new也常常会引发一些问题,如内存泄漏、空指针等等。因此,本文将通过具体的示例,深入介绍C++中的new操作符,帮助读者更好地掌握其使用。

    
深入了解C++中的new操作符:使用具体实例学习

    怎么用Java反射获取包下所有类? 详细代码实例操作

    Java的反射机制就是在运行状态下,对于任何一个类,它能知道这个类的所有属性和方法;对于任何一个对象,都能调用这个对象的任意一个方法。本篇文章将通过具体的代码示例,展示如何通过Java反射来获取包下的所有类。

    
怎么用Java反射获取包下所有类? 详细代码实例操作

    了解Java中的volati关键字的作用 以及具体使用方法

    本篇文章将和大家分享一下Java当中的volatile关键字,下面将为各位小伙伴讲述volatile关键字的作用以及它的具体使用方法。

    
了解Java中的volati关键字的作用 以及具体使用方法

    Java Map 所有的值转为String类型

    可以使用 Java 8 中的 Map.replaceAll() 方法将所有的值转为 String 类型: 上面的代码会将 map 中所有的值都转为 String 类型。 HashMap 是 Java

    Java Map 所有的值转为String类型

    员工线上学习考试系统

    有点播,直播,在线支付,三级分销等功能,可以对学员学习情况的监督监控,有源码,可二次开发。支持外网和局域网私有化部署,经过测试源码完整可用!1、视频点播:视频播放,图文资料,课件下载,章节试学,限时免

    员工线上学习考试系统