- 调用
torch.einsum('i, ijk, j->jk', c_ws, u_minus_c, trainCellVol)时, 提示了如下错误
File "/Users/yczhang/opt/anaconda3/envs/fealpy/lib/python3.8/site-packages/torch/functional.py", line 241, in einsum
return torch._C._VariableFunctions.einsum(equation, operands)
RuntimeError: Expected object of scalar type Double but got scalar type Float for argument #2 'mat2' in call to _th_mm_out
根据错误的提示, 可能是 c_ws, u_minus_c, trainCellVol 的数据类型不一致造成的.
并注意, pytorch 中的 Tensor 数据 float64 是 double ,而 float32 是标准的 float.
然后查看下各数据的类型:
c_ws.type()
'torch.DoubleTensor'
u_minus_c.type()
'torch.FloatTensor'
trainCellVol.type()
'torch.DoubleTensor'
那么, 将 c_ws.float(), 或将 u_minus_c.double() 是都可以的, 即下面的两种方式:
a0 = torch.einsum('i, ijk, j->jk', c_ws, u_minus_c.double(), trainCellVol)
a0 = torch.einsum('i, ijk, j->jk', c_ws.float(), u_minus_c, trainCellVol)
- pytorch 查看模型结构 网络参数
最后
以上就是魔幻枕头最近收集整理的关于PyTorch 中遇到的问题的全部内容,更多相关PyTorch内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复