pytorch中函数tensor.numpy()的数据类型实例分析
导读:本文共1072.5字符,通常情况下阅读需要4分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要: 函数tensor.numpy()的数据类型今天写代码的时候,要统计一下标签数据里出现的类别总数和要分类的分类数是不是一致的。我的做法是把tensor类型的数据转变成list,然后用Counter函数做统计。代码如下:fromcollectionsimportCounterList_counter=Counter(List1)#List1就是待统计的数据,是一... ...
目录
(为您整理了一些要点),点击可以直达。函数tensor.numpy()的数据类型
今天写代码的时候,要统计一下标签数据里出现的类别总数和要分类的分类数是不是一致的。
我的做法是把tensor类型的数据转变成list,然后用Counter函数做统计。
代码如下:
fromcollectionsimportCounterList_counter=Counter(List1)#List1就是待统计的数据,是一维的列表。生成的List_counter是一个字典,键是数据,#对应的值是数据出现的频率
在做这个统计的时候,突然发现,我的数据是float的类型,这是不应该出现的,因为标签数据在处理的时候都是整型数据。
经过一番查找后,发现是tensor.numpy()返回值数据类型的原因。这个函数的返回值是float类型的
tensor数据和numpy数据转换中注意的一个问题
在pytorch中,把numpy.array数据转换到张量tensor数据的常用函数是torch.from_numpy(array)或者torch.Tensor(array)
第一种函数更常用,然而在pytorch0.4中已经舍弃了这种函数
下面一个简单的编程实验说明这两种方法的区别
实验在pytorch0.4框架下进行
运行程序之后,结果是
可以看出修改数组a的元素值,张量b的元素值也改变了,但是张量c却不变。
修改张量c的元素值,数组a和张量b的元素值都不变。
这说明torch.from_numpy(array)是做数组的浅拷贝,torch.Tensor(array)是做数组的深拷贝
</div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
pytorch中函数tensor.numpy()的数据类型实例分析的详细内容,希望对您有所帮助,信息来源于网络。