PyTorch使用常见异常和解决办法汇总

1.使用conda安装PyTorch后同时在Jupyter导入失败No module named ‘torch’

通过Conda安装PyTorch,同时在Jupyter中导入PyTorch,会报错No module named 'torch'
分析:
原因就是在使用Jupyter Notebook的时候,加载的仍然是默认的Python Kernel。
解决:
(1)在Conda中切换到安装PyTorch的虚拟环境,然后执行conda install nb_conda_kernels安装Jupyter内核切换工具。
安装完成后,再重启Jupyter Notebook,在新建脚本时就能选择Kernal:
new script choose kernal
也可以对建好的文件切换Kernal:
script change kernal

2.PyTorch使用张量时报错expected scalar type Double but found Float

有时候,使用张量Tensor会报错:

RuntimeError: expected scalar type Double but found Float

分析:
这是因为张量的数据类型不正确。
解决:
此时需要先进行类型转换,将数据类型转为float32,再进行操作,如下:

tensor = tensor.to(torch.float32)

3.PyTorch创建Embedding时报错IndexError: index out of range in self

PyTorch中很多时候都会用到Embedding嵌入,特别是在NLP任务中,用于存储一个简单的存储固定大小的词典的嵌入向量的查找表,按时在创建EMbedding时有时候会出错,如下:

  File "E:\Anaconda3\envs\pytorchbase\Lib\site-packages\torch\nn\modules\module.py", line 1102, in _call_impl
    return forward_call(*input, **kwargs)
  File "E:\Anaconda3\envs\pytorchbase\Lib\site-packages\torch\nn\modules\sparse.py", line 158, in forward
    return F.embedding(
  File "E:\Anaconda3\envs\pytorchbase\Lib\site-packages\torch\nn\functional.py", line 2044, in embedding
    return torch.embedding(weight, input, padding_idx, scale_grad_by_freq, sparse)
IndexError: index out of range in self

分析:
这是因为num_embeddings(词典的词个数)不够大,进行词嵌入的时候字典从1, …, n,映射所有的词(或者字)num_embeddings =n是够用的,但是会考虑pad,pad默认一般是0,所以我们会重新处理一下映射字典0, 1, 2, …, n一共n+1个值,此时num_embeddings=n+1才够映射。
解决:
修改参数num_embeddings的值为实际词个数+1即可解决这个问题。

PyTorch Geometric是一个基于PyTorch的几何深度学习扩展库,它提供了许多用于处理图形、点云和其他几何数据的函数和类。如果你在安装PyTorch Geometric时遇到了问题,可以尝试以下几种解决方法: 1. 检查Python版本:PyTorch Geometric只支持Python 3.6、3.7和3.8版本。如果你的Python版本不在这个范围内,建议升级或降级到支持的版本。 2. 检查PyTorch版本:PyTorch Geometric要求PyTorch版本大于等于1.6。可以通过以下命令检查PyTorch版本:`import torch; print(torch.__version__)`。如果版本低于1.6,可以通过以下命令升级:`pip install torch -U`。 3. 安装依赖库:PyTorch Geometric有一些依赖库需要安装。可以尝试通过以下命令安装所有依赖库:`pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-${TORCH}+${CUDA}.html`、`pip install torch-sparse -f https://pytorch-geometric.com/whl/torch-${TORCH}+${CUDA}.html`、`pip install torch-cluster -f https://pytorch-geometric.com/whl/torch-${TORCH}+${CUDA}.html`、`pip install torch-spline-conv -f https://pytorch-geometric.com/whl/torch-${TORCH}+${CUDA}.html`、`pip install torch-geometric`。 4. 检查CUDA版本:如果你使用的是GPU版的PyTorchPyTorch Geometric,需要检查CUDA版本是否与PyTorch版本匹配。可以通过以下命令检查CUDA版本:`nvcc --version`。如果CUDA版本不匹配,可以尝试升级或降级到与PyTorch版本匹配的CUDA版本。 如果以上方法都不能解决问题,可以尝试在GitHub上提出问题,或者参考PyTorch Geometric的官方文档:https://pytorch-geometric.readthedocs.io/en/latest/notes/installation.html
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

东哥说AI

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值