can‘t convert cuda:0 device type tensor to numpy.Use Tensor.cpu

can‘t convert cuda:0 device type tensor to numpy.Use Tensor.cpu,第1张

源代码:

# 训练曲线
result1 = [100 - i['train'] for i in statistics]
result2 = [100 - i['valid'] for i in statistics]
plt.figure(figsize = (10, 7))
plt.plot(result1, label = 'Training')
plt.plot(result2, label = 'Validation')
plt.xlabel('Step')
plt.ylabel('Error Rate')
plt.legend()

报错信息:

 

错误内容是无法正常的画图,这个错误信息和上面那个加.cpu()的相同,但是解决方法略有不同,我在网上找了很多的方法,但是都没有找到合适的解决方案,网上大多都是在讲加个.cpu(),但是就这个画图程序来说,无法找到合适的加.cpu()的地方。


究其原因,还是没有真正理解程序的意思。


首先打印下被遍历的statistics,看下这里面有什么东西。


如上图,可以发现statistic本身是一个列表,而里面的元素确是字典,字典里的train,valid所对应的value是torch的tensor,所以才会出现错误。


更改如下:

# 训练曲线
result1 = [100 - i['train'].cpu() for i in statistics]
result2 = [100 - i['valid'].cpu() for i in statistics]
plt.figure(figsize = (10, 7))
plt.plot(result1, label = 'Training')
plt.plot(result2, label = 'Validation')
plt.xlabel('Step')
plt.ylabel('Error Rate')
plt.legend()

 在i['train']和i['valid']的后面添加.cpu(),再次点击运行,即可正常运行程序。


 

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/570862.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-09
下一篇 2022-04-09

发表评论

登录后才能评论

评论列表(0条)

保存