首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >对python浮点数和pytorch整数进行乘法和幂运算

对python浮点数和pytorch整数进行乘法和幂运算
EN

Stack Overflow用户
提问于 2020-01-21 00:35:07
回答 1查看 291关注 0票数 3

为什么python float乘以torch.long会得到torch.float,而用torch.long给float赋权则会得到torch.long?

代码语言:javascript
复制
>>> a = 0.9
>>> b = torch.tensor(2, dtype=torch.long)

>>> foo = a * b
>>> print(foo, foo.dtype)
tensor(1.8000) torch.float32

>>> bar = a ** b 
>>> print(bar, bar.dtype)
tensor(0) torch.int64
EN

回答 1

Stack Overflow用户

发布于 2020-01-21 23:50:52

这看起来像是一个bug,可能是pytorch将**绑定到__rpow____pow__的方式。

例如,如果你尝试了0.9 - torch.tensor(2),因为0.9不是一个张量,所以它会被解释为torch.tensor(2).__rsub__(0.9),它可以正常工作。**的行为与此相同,但torch.tensor(2).__rpow__(0.9)错误地返回了数据类型为int64的tensor(0)

同时,您可以使用torch.tensor(0.9) ** torch.tensor(2)

提交了一个错误:https://github.com/pytorch/pytorch/issues/32436

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59827509

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档