torch 多进程卡死

torch训练卡死,后来发现是

DataLoader卡死,原因是enumerate参数不对,

dataloader = DataLoader(COCODataset(config["train_path"],
                                                 (config["img_w"], config["img_h"]),
                                                 is_training=True, data_size=100000),
batch_size=config["batch_size"], shuffle=True,drop_las
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论
torch多进程推理服务可以通过使用`torch.multiprocessing`模块来实现。该模块提供了一种简便的方式来创建和控制多个并行的进程。 首先,我们需要定义一个函数,该函数将在每个进程中运行。这个函数负责实例化模型和加载权重,然后对输入数据进行推理。推理结果可以通过共享内存或其他方式进行收集和返回。 接下来,我们可以使用`torch.multiprocessing.Process`类来创建进程对象。我们可以为每个进程指定要执行的函数以及传递给该函数的参数。然后,我们可以调用进程对象的`start`方法来启动进程。 为了实现多进程之间的通信,我们可以使用`torch.multiprocessing.Queue`类来创建队列对象。队列可以用于在进程之间传递数据和结果。一个进程可以将数据放入队列,而另一个进程可以从队列中获取数据。这种方式可以方便地实现并行推理任务的输入输出。 最后,我们需要使用`torch.multiprocessing.Queue`类实现进程间的同步。我们可以使用`put`方法将数据放入队列,并使用`get`方法从队列中获取,从而确保进程在执行推理之前具有所需的输入数据。 总的来说,使用`torch.multiprocessing`模块可以实现多进程的推理服务。通过定义一个函数来处理推理任务,并使用`Process`类创建多个进程来并行执行任务。使用队列实现进程间的通信和同步,可以方便地传递输入数据和获取输出结果。这样可以提高推理服务的效率和性能。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

AI算法网奇

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

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

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

打赏作者

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

抵扣说明:

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

余额充值