【Pytorch学习笔记(二)】张量的创建(补充)

一、知识回顾

我们在博客《张量的创建与访问》中已经讨论了一些张量的创建方法如torch.CharTensor()、torch.FloatTensor()以及torch.zeros()等张量创建方法,但由于其仅仅介绍了cpu版本torch下张量的创建方法和只有具体数据类型张量,本节内容旨在补充gpu版本torch下张量的创建以及更一般的张量的创建方法。

二、torch.Tensor()与torch.tensor()

pytorch中可用torch.Tensor()和torch.tensor()来创建一般的张量,二者的区别在于前者是一个 ,代表PyTorch底层的张量操作和方法;后者是一个函数 ,用于创建张量对象[1],torch.Tensor()传入的参数可以是具体的张量数据,也可以是张量的shape;torch.tensor()传入的数据只能是具体的张量。

复制代码
#创建一个张量a和张量b(分别用torch.Tensor()与torch.tensor())
ta = torch.Tensor(3, 4)
tb = torch.tensor([[1, 2], [3, 4]])
#分别输出tb,ta并查看其数据类型
print(f"ta的数据类型是{ta.dtype}\n ta张量为:{ta}")
print(f"tb的数据类型是{tb.dtype}\n ta张量为:{tb}")

上述代码的运行结果为:

由此可见torch.Tensor(shape)会默认创建一个32位浮点数据类型的张量,而torch.tensor()会依据输入的数据来自动生成数据类型。

三、初始化一个张量方法(部分)[2]

(一)直接传入具体张量数据

本文第二项中提到的初始化张量方法即为直接传入具体张量数据的方法, 此外,torch.tensor()还支持将numpy数据和其它tensor数据转换为张量,本文将逐一介绍。

(二)将numpy数组转换为张量

具体方法如下:

复制代码
#创建一个numpy数组
np_array = np.array([[1, 2], [3, 4]])
#将numpy数组转换为张量
tc = torch.from_numpy(np_array)

(三)将其它张量转换为特定张量

pytorch可以将张量a转换为全零、全一或随机张量,具体代码法如下

复制代码
#创建一个张量a和张量b
ta = torch.tensor([[1, 2], [3, 4]])
tb = torch.Tensor(3, 4)
#将张量a转换为全零或全一张量,将张量b转化为随机张量
tzero = torch.zeros_like(ta)
tone = torch.ones_like(ta)
trandn = torch.randn_like(tb)
print(f"转化过后的张量为\n{tzero}\n{tone}\n{trandn}")

上述代码运行结果为:

值得注意的是: zeros_like()和ones_like()方法可以转化Tensor()类和tensor()方法初始化的张量,而randn_like()方法只能转化Tensor()类初始化的张量。

四、创建gpu版本的张量与tensor()方法详解

(一)创建gpu版本的张量

《张量的创建与访问》中已经介绍了cpu版本的不同数据类型的张量的创建,gpu版本的张量创建方法与之类似:

复制代码
ta  = torch.cuda.CharTensor([[1, 2], [3, 4]])
print(f"gpu版本的张量\n{ta}")

(二)tensor()方法详解

前面我们已经提到tensor()方法本质是是一个函数,它的可传入参数为tensor(data, dtype=*, device='cuda/cpu'),其中data即为需要传入的数据,dtype为想要生成的张量中的元素的数据类型,device则指定是用cpu还是gpu计算。

当我们想初始化一个gpu版本的元素数据类型为float的张量时,我们就可以用如下代码实现:

复制代码
data = [[1.1, 2.4], [3.3, 5.3]]
ta = torch.tensor(data, dtype=float, device='cuda')
print(ta)
相关推荐
_Kayo_4 小时前
node.js 学习笔记3 HTTP
笔记·学习
CCCC13101637 小时前
嵌入式学习(day 28)线程
jvm·学习
星星火柴9368 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
小狗爱吃黄桃罐头8 小时前
正点原子【第四期】Linux之驱动开发篇学习笔记-1.1 Linux驱动开发与裸机开发的区别
linux·驱动开发·学习
艾莉丝努力练剑9 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
武昌库里写JAVA10 小时前
JAVA面试汇总(四)JVM(一)
java·vue.js·spring boot·sql·学习
Cx330❀10 小时前
【数据结构初阶】--排序(五):计数排序,排序算法复杂度对比和稳定性分析
c语言·数据结构·经验分享·笔记·算法·排序算法
杜子不疼.10 小时前
《Python学习之字典(一):基础操作与核心用法》
开发语言·python·学习
小幽余生不加糖11 小时前
电路方案分析(二十二)适用于音频应用的25-50W反激电源方案
人工智能·笔记·学习·音视频
..过云雨11 小时前
01.【数据结构-C语言】数据结构概念&算法效率(时间复杂度和空间复杂度)
c语言·数据结构·笔记·学习