RuntimeError: Expected object of device type cuda but got device type cpu for argument #1 ‘self‘ in

RuntimeError: Expected object of device type cuda but got device type cpu for argument #1 'self' in call to _thnn_conv2d_forward  怎么解决呢?

Traceback (most recent call last):
  File "train_heart.py", line 101, in <module>
    train()
  File "train_heart.py", line 99, in train
    trainer.train()
  File "/home/dluser/code/CL-Cardiac-segmentation-master/base/base_trainer.py", line 117, in train
    self._train_epoch(epoch)
  File "/home/dluser/code/CL-Cardiac-segmentation-master/trainer_heart.py", line 105, in _train_epoch
    curr_iter=batch_idx, target_ul=target_ul, epoch=epoch - 1, **kargs)
  File "/home/dluser/anaconda3/envs/lib/python3.7/site-packages/torch/nn/modules/module.py", line 889, in _call_impl
    result = self.forward(*input, **kwargs)
  File "/home/dluser/anaconda3/envs/lib/python3.7/site-packages/torch/nn/parallel/distributed.py", line 705, in forward
    output = self.module(*inputs[0], **kwargs[0])
  File "/home/dluser/anaconda3/envs/lib/python3.7/site-packages/torch/nn/modules/module.py", line 889, in _call_impl
    result = self.forward(*input, **kwargs)
  File "/home/dluser/code/CL-Cardiac-segmentation-master/models/model.py", line 122, in forward
    enc = self.encoder(x_l)
  File "/home/dluser/anaconda3/envs/lib/python3.7/site-packages/torch/nn/modules/module.py", line 889, in _call_impl
    result = self.forward(*input, **kwargs)
  File "/home/dluser/code/CL-Cardiac-segmentation-master/models/modeling/unet_model.py", line 34, in forward
    x1 = self.inc(x)
  File "/home/dluser/anaconda3/envs/lib/python3.7/site-packages/torch/nn/modules/module.py", line 889, in _call_impl
    result = self.forward(*input, **kwargs)
  File "/home/dluser/code/CL-Cardiac-segmentation-master/models/modeling/unet_parts.py", line 39, in forward
    x= self.double_conv(x)
  File "/home/dluser/anaconda3/envs/lib/python3.7/site-packages/torch/nn/modules/module.py", line 889, in _call_impl
    result = self.forward(*input, **kwargs)
  File "/home/dluser/anaconda3/envs/lib/python3.7/site-packages/torch/nn/modules/container.py", line 119, in forward
    input = module(input)
  File "/home/dluser/anaconda3/envs/lib/python3.7/site-packages/torchstat/model_hook.py", line 50, in wrap_call
    output = self._origin_call[module.__class__](module, *input, **kwargs)
  File "/home/dluser/anaconda3/envs/lib/python3.7/site-packages/torch/nn/modules/module.py", line 889, in _call_impl
    result = self.forward(*input, **kwargs)
  File "/home/dluser/anaconda3/envs/lib/python3.7/site-packages/torch/nn/modules/conv.py", line 399, in forward
    return self._conv_forward(input, self.weight, self.bias)
  File "/home/dluser/anaconda3/envs/lib/python3.7/site-packages/torch/nn/modules/conv.py", line 396, in _conv_forward
    self.padding, self.dilation, self.groups)
RuntimeError: Expected object of device type cuda but got device type cpu for argument #1 'self' in call to _thnn_conv2d_forward

  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据你提供的引用信息,你在运行PyTorch代码时遇到了一个报错:RuntimeError: Expected a &#39;cuda&#39; device type for generator but found &#39;cpu&#39;。这个错误是因为你在代码中使用了一个生成器(generator),但是你期望它在GPU上运行,而实际上它在CPU上运行。 根据引用\[1\],你可以通过修改代码中的生成器参数来解决这个问题。根据引用\[2\],你可以在生成器参数中添加一个`device=&#39;cuda&#39;`的参数,将生成器指定为在GPU上运行。这样,生成器就会在GPU上运行,而不是在CPU上。 另外,根据引用\[3\],你还可以尝试使用`torch.set_default_tensor_type(&#39;torch.cuda.FloatTensor&#39;)`将默认的张量类型设置为在GPU上的浮点型。这样,数据加载到GPU上时就不需要再进行`data.cuda()`操作了。 综上所述,你可以尝试在生成器参数中添加`device=&#39;cuda&#39;`,或者使用`torch.set_default_tensor_type(&#39;torch.cuda.FloatTensor&#39;)`来解决这个问题。 #### 引用[.reference_title] - *1* [RuntimeError: Expected a ‘cpudevice type for generator but found cuda](https://blog.csdn.net/qq_41813454/article/details/129812083)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [RuntimeError: Expected a ‘cudadevice type for generator but found ‘cpu](https://blog.csdn.net/hhhhhhhhhhwwwwwwwwww/article/details/124649651)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [RuntimeError:Expected a ‘cudadevice type for generator but found ‘cpu](https://blog.csdn.net/u013114420/article/details/121018262)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值