模型推理FPS计算

本文探讨了在模型性能比较中,除了指标提升外,模型效率和速度的重要性。通过计算推理速度(FPS)来衡量模型的运行效率,作者提供了一段代码示例,用于测量和平均推理每张图片所需的时间。该方法排除了数据加载和计算指标的耗时,重点关注模型的前向传播过程。
摘要由CSDN通过智能技术生成

文章目录

场景

很多模型的性能比较,不只是指标的提升,还需要考虑模型的效率、速度;
计算模型的推理速度FPS是一项重要的指标,记录如下:

 # the first several iterations may be very slow so skip them
    parser.add_argument(
        '--max-iter', type=int, default=2000, help='num of max iter')
    parser.add_argument(
        '--log-interval', type=int, default=50, help='interval of logging')
    num_warmup = 5
    pure_inf_time = 0
    fps = 0

    # benchmark with 2000 image and take the average
    for i, data in enumerate(data_loader):

        torch.cuda.synchronize()
        start_time = time.perf_counter()

        with torch.no_grad():
            model(return_loss=False, rescale=True, **data)

        torch.cuda.synchronize()
        elapsed = time.perf_counter() - start_time

        if i >= num_warmup:
            pure_inf_time += elapsed
            if (i + 1) % log_interval == 0:
                fps = (i + 1 - num_warmup) / pure_inf_time
                print(
                    f'Done image [{i + 1:<3}/ {max_iter}], '
                    f'fps: {fps:.1f} img / s, '
                    f'times per image: {1000 / fps:.1f} ms / img',
                    flush=True)

        if (i + 1) == max_iter:
            fps = (i + 1 - num_warmup) / pure_inf_time
            print(
                f'Overall fps: {fps:.1f} img / s, '
                f'times per image: {1000 / fps:.1f} ms / img',
                flush=True)
            break
    return fps

思路

FPS的计算,主要是对模型前向传播的耗时平均数进行计算,不包含读取数据和计算指标耗时

  1. 计算每一次、每张图进行推理是耗时
  2. 将耗时累加并除以累加次数得到平均值
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值