pytorch multiprocessing跳出进程之后无法获得梯度

经过一段如下的多进程计算之后
for ith in range(nth):
th[ith] = Process( target=self.ComptTInteriorthread0, args=(geom,cfg,netith,min(netith+net,nnode),iz,solution,solz))

for ith in range(nth):
  th[ith].start()
for ith in range(nth):
  th[ith].join()  

在每个进程内可以计算solution的导数,但是退出进程之后导数信息就不存在了,要如何让导数信息在跳出进程之后还能计算呢。

Traceback (most recent call last):
File “”, line 1, in
File “c:\Users\sphin\AppData\Local\Programs\Python\Python39\lib\site-packages\torch_tensor.py”, line 487, in backward
torch.autograd.backward(
File “c:\Users\sphin\AppData\Local\Programs\Python\Python39\lib\site-packages\torch\autograd_init_.py”, line 200, in backward
Variable._execution_engine.run_backward( # Calls into the C++ engine to run the backward pass
RuntimeError: element 0 of tensors does not require grad and does not have a grad_fn

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值