model在CPU上能正常运行在GPU上却卡住

1、torch.sigmoid
2、lstm的hidden_size先改成很小的,后来又增上去;
3、最最根本的原因是:cpu和cuda之间的数据传输太多,导致很慢很慢!!!

true=label.cuda()
pred=torch.sigmoid(pred).cuda()
loss = criterion(pred.float(), true.float())

改成

true = label
pred = torch.sigmoid(pred).cpu()
loss = criterion(pred.float(), true.float())

即转移到cpu上来计算loss后,速度变快。

我这个程序很奇怪,一模一样的数据和代码,几天前跑得很正常,啥都没改,莫名其妙就跑不动了,经过调试发现总是卡住算loss的这一句话,而显卡与前几天唯一的不同是前几天是空的而现在有别人在跑代码,所以可能是显卡内存不够我的程序跑了;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值