解决tensor的shape不为1,如何转移到CPU的问题

1 问题

  1. 如果tensor的shape不是1,那么怎么转移到CPU呢?

2 方法

(1)首先如果tensor的shape不是1,那就是是一个二维张量,我们可以使用 .to(device)方法将其移动到特定的设备上。在这种情况下,我们可以将它移动到 CPU 上,如下所示:

tensor = tensor.to('cpu')

这将返回一个在 CPU 上的新的 Tensor 对象。如果原始 Tensor 已经在 CPU 上,那么这个操作不会有任何影响,并且返回的仍然是原始的 Tensor 对象。

需要注意的是,.to(device) 方法也可以以其他设备作为参数,如 `'cuda'`(如果可用)或其他设备的名称,这样可以将 Tensor 移动到相应的设备上。

(2)那么如果是二维张量我们应该怎么计算它的batch_correct值呢?

如果是一个二维张量,其中每行代表一个样本的预测结果,每列代表一个类别的预测概率,你可以使用以下代码来计算批次中预测正确的样本数量:

batch_predictions = pred.argmax(dim=1) 获取每个样本预测结果概率最高的类别索引

batch_correct = (batch_predictions == y).sum().item() 计算预测正确的样本数量

通过pred.argmax(dim=1),我们获取每个样本预测结果概率最高的类别的索引,得到一个一维张量 batch_predictions。然后,使用 (batch_predictions == y)将预测结果与真实标签进行比较,生成一个布尔值张量,其中 True表示预测正确,False表示预测错误。

最后,使用 .sum().item()方法对布尔值张量进行求和,计算出预测正确的样本数量,并使用 .item() 方法将结果转换为 Python 标量类型,以方便获取具体的数值。

3 结语

对于如果tensor的shape不是1,我们需要使用.to(device)方法将其移动到cpu上,这样不会有任何影响,并且返回的仍然是原始的 Tensor 对象。,并且我们也可以通过pred.argmax(dim=1),我们获取每个样本预测结果概率最高的类别的索引,得到一个一维张量 batch_predictions。用(batch_predictions == y)将预测结果与真实标签进行比较,生成一个布尔值张量,其中 True表示预测正确,False表示预测错误。使用 .sum().item()方法对布尔值张量进行求和,计算出预测正确的样本数量,并使用 .item() 方法将结果转换为 Python 标量类型,以方便获取具体的数值。就可以计算出batch_correct值。

相关推荐
Echo_NGC2237几秒前
【FFmpeg 使用指南】Part 3:码率控制策略与质量评估体系
人工智能·ffmpeg·视频·码率
Z9fish5 分钟前
sse哈工大C语言编程练习20
c语言·开发语言·算法
纤纡.10 分钟前
PyTorch 入门精讲:从框架选择到 MNIST 手写数字识别实战
人工智能·pytorch·python
晓131310 分钟前
第六章 【C语言篇:结构体&位运算】 结构体、位运算全面解析
c语言·算法
大大大反派11 分钟前
CANN 生态中的自动化部署引擎:深入 `mindx-sdk` 项目构建端到端 AI 应用
运维·人工智能·自动化
程序猿追12 分钟前
深度解读 AIR (AI Runtime):揭秘 CANN 极致算力编排与调度的核心引擎
人工智能
iAkuya16 分钟前
(leetcode)力扣100 61分割回文串(回溯,动归)
算法·leetcode·职场和发展
2601_9495936517 分钟前
深入解析CANN-acl应用层接口:构建高效的AI应用开发框架
数据库·人工智能
●VON19 分钟前
CANN安全与隐私:从模型加固到数据合规的全栈防护实战
人工智能·安全
梵刹古音19 分钟前
【C语言】 指针与数据结构操作
c语言·数据结构·算法