使用pytorch实现transformer中的atten mask时,生成的mask矩阵为0,1阵,类型为torch.unit8。这时在使用masked_fill_函数对seq进行mask时会出现警告(版本较高的torch)。
masked_fill_ received a mask with dtype torch.uint8, this behavior is now deprecated,please use a mask with dtype torch.bool instead.
这时,只要将mask矩阵中的torch.unit8类型变为torch.bool即可。
如:
scores.masked_fill_(mask,-1e9)
改为以下,即可:
scores.masked_fill_(mask.bool(),-1e9)
在使用PyTorch实现Transformer模型时,遇到attenmask矩阵为torch.uint8类型的问题,这在新版PyTorch中已不推荐。当使用masked_fill_函数填充序列时,会发出警告,提示应将mask类型改为torch.bool。解决方法是将mask转换为torch.bool类型,如:scores.masked_fill_(mask.bool(),-1e9)。此更改能消除警告并正确执行mask操作。
877

被折叠的 条评论
为什么被折叠?



