pytorch报错RuntimeError: expected device cpu and dtype Float but got device cpu and dtype Long

本文解决了一个常见的PyTorch编程问题,当尝试使用整数类型的SCORES与浮点数类型的prob进行操作时,会遇到类型不匹配的错误。通过将SCORES转换为浮点数类型,可以避免此类运行时错误。
部署运行你感兴趣的模型镜像

prob * SCORES 报错:
RuntimeError: expected device cpu and dtype Float but got device cpu and dtype Long
其中prob和SCORES的数据及类型是:
SCORES = torch.tensor([[1, 2, 3, 4, 5]])
In [71]: prob
Out[71]: 
tensor([[0.2000, 0.2000, 0.2000, 0.2000, 0.2000],
        [0.2001, 0.2002, 0.1998, 0.2001, 0.1998],
        [0.2000, 0.2000, 0.2000, 0.2000, 0.2000],
        ...,
        [0.2000, 0.2000, 0.2000, 0.2000, 0.2000],
        [0.2000, 0.2000, 0.2000, 0.2000, 0.2000],
        [0.1999, 0.2000, 0.2000, 0.2000, 0.2000]], grad_fn=<SoftmaxBackward>)
 
解决方法:
将SCORES由整数类型改为float类型:
SCORES = torch.tensor([[1., 2., 3., 4., 5.]])
或者:
SCORES = SCORES.float()
 

您可能感兴趣的与本文相关的镜像

PyTorch 2.5

PyTorch 2.5

PyTorch
Cuda

PyTorch 是一个开源的 Python 机器学习库,基于 Torch 库,底层由 C++ 实现,应用于人工智能领域,如计算机视觉和自然语言处理

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值