解决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值。

相关推荐
yuanyuan2o210 小时前
【深度学习】ResNet
人工智能·深度学习
HyperAI超神经10 小时前
覆盖天体物理/地球科学/流变学/声学等19种场景,Polymathic AI构建1.3B模型实现精确连续介质仿真
人工智能·深度学习·学习·算法·机器学习·ai编程·vllm
小陈phd10 小时前
系统测试与落地优化:问题案例、性能调优与扩展方向
人工智能·自然语言处理
模型时代10 小时前
伯明翰Oracle项目遭遇数据清洗难题和资源短缺困境
人工智能
大黄说说10 小时前
TensorRTSharp 实战指南:用 C# 驱动 GPU,实现毫秒级 AI 推理
开发语言·人工智能·c#
执着25910 小时前
力扣hot100 - 144、二叉树的前序遍历
数据结构·算法·leetcode
范纹杉想快点毕业10 小时前
嵌入式系统架构之道:告别“意大利面条”,拥抱状态机与事件驱动
java·开发语言·c++·嵌入式硬件·算法·架构·mfc
沐泽__10 小时前
Flask简介
后端·python·flask
近津薪荼10 小时前
递归专题(4)——两两交换链表中的节点
数据结构·c++·学习·算法·链表
王锋(oxwangfeng)10 小时前
基于 DINO 与 Chinese-CLIP 的自动驾驶语义检索系统架构
人工智能·机器学习·自动驾驶