OpenVINO 异步推理:图像列表输入解决方案

花韻仙語
发布: 2025-08-03 18:02:15
原创
606人浏览过

openvino 异步推理:图像列表输入解决方案

本文将深入探讨如何利用 OpenVINO™ 异步推理 API 处理图像列表输入,并提供相应的解决方案。正如文章摘要所述,我们将借鉴官方提供的图像分类异步推理 Python 示例,介绍如何将图像文件路径列表作为输入,从而避免使用视频流输入方式。这将帮助开发者更灵活地应用于实际场景,例如从消息队列(如 RabbitMQ)接收图像数据的情况。

异步推理可以显著提高推理效率,尤其是在处理大量数据时。通过将推理任务分解为多个异步请求,可以充分利用 CPU 和 GPU 资源,减少等待时间,从而提升整体吞吐量。

使用图像分类异步推理 Python 示例

OpenVINO™ 官方提供了一个图像分类异步推理 Python 示例,该示例展示了如何使用异步推理 API 处理图像输入。该示例的代码可以在 OpenVINO 仓库中找到:Image Classification Async Python SampleOpenVINO repository.

这个示例的关键在于它支持通过图像文件路径列表作为输入。这意味着您可以将从队列或其他来源获取的图像文件路径添加到列表中,然后将该列表传递给推理引擎。

代码示例(改编自官方示例)

以下是一个改编自官方示例的简化代码片段,展示了如何使用图像文件路径列表进行异步推理:

爱图表
爱图表

AI驱动的智能化图表创作平台

爱图表 99
查看详情 爱图表
import openvino.runtime as ov
import cv2
import numpy as np
import os

def async_inference_image_list(image_paths, model_path, device="CPU"):
    """
    使用 OpenVINO 异步推理 API 处理图像列表。

    Args:
        image_paths: 图像文件路径列表。
        model_path: OpenVINO 模型文件路径 (.xml)。
        device: 推理设备 (例如 "CPU", "GPU")。
    """

    # 1. 加载 OpenVINO 模型
    core = ov.Core()
    model = core.read_model(model_path)
    compiled_model = core.compile_model(model=model, device_name=device)

    # 2. 获取输入和输出层
    input_layer = compiled_model.input(0)
    output_layer = compiled_model.output(0)

    # 3. 获取输入尺寸
    input_shape = input_layer.shape
    _, _, h, w = input_shape

    # 4. 创建异步推理请求
    infer_requests = [compiled_model.create_infer_request() for _ in range(2)]  # 使用两个请求实现流水线

    # 5. 预处理图像并提交推理请求
    results = []
    for i, image_path in enumerate(image_paths):
        # 读取图像
        image = cv2.imread(image_path)
        if image is None:
            print(f"Error: Could not read image at {image_path}")
            continue

        # 调整图像尺寸并进行预处理
        resized_image = cv2.resize(image, (w, h))
        input_data = np.expand_dims(resized_image.transpose(2, 0, 1), 0)

        # 获取当前和下一个推理请求
        current_request_id = i % 2
        next_request_id = (i + 1) % 2

        # 设置输入张量并启动异步推理
        infer_requests[current_request_id].set_tensor(input_layer, ov.Tensor(input_data))
        infer_requests[current_request_id].start_async()

        # 如果不是第一张图像,则等待上一个推理请求完成
        if i > 0:
            infer_requests[next_request_id].wait()
            output = infer_requests[next_request_id].get_tensor(output_layer).data
            results.append(output)

    # 6. 等待最后一个推理请求完成
    infer_requests[(len(image_paths) - 1) % 2].wait()
    output = infer_requests[(len(image_paths) - 1) % 2].get_tensor(output_layer).data
    results.append(output)

    return results


# 示例用法
if __name__ == "__main__":
    # 创建一些示例图像文件(或者使用你自己的图像文件路径)
    image_paths = ["image1.jpg", "image2.jpg", "image3.jpg"]  # 替换为实际图像路径
    for path in image_paths:
        if not os.path.exists(path):
            # 创建一个假的图像文件
            blank_image = np.zeros((100, 100, 3), dtype=np.uint8)
            cv2.imwrite(path, blank_image)

    model_path = "your_model.xml"  # 替换为你的 OpenVINO 模型路径

    # 执行异步推理
    results = async_inference_image_list(image_paths, model_path)

    # 打印结果
    for i, result in enumerate(results):
        print(f"Image {i+1} result: {result}")
登录后复制

代码解释:

  1. 加载模型: 使用 ov.Core() 加载 OpenVINO 模型。
  2. 获取输入/输出层: 获取模型的输入和输出层,以便设置输入数据和获取推理结果。
  3. 创建推理请求: 创建多个异步推理请求,这里使用了两个请求来实现简单的流水线。
  4. 图像预处理: 读取图像,调整尺寸到模型所需的输入尺寸,并进行必要的预处理(例如,归一化)。
  5. 提交异步请求: 使用 infer_request.set_tensor() 设置输入张量,然后使用 infer_request.start_async() 启动异步推理。
  6. 等待结果: 使用 infer_request.wait() 等待推理完成,然后使用 infer_request.get_tensor() 获取推理结果。

注意事项:

  • 确保已安装 OpenVINO™ 运行时环境,并且模型文件路径正确。
  • 根据实际情况调整图像预处理步骤,例如归一化、缩放等。
  • 根据硬件资源和模型复杂度,调整异步推理请求的数量,以达到最佳性能。
  • 上述代码只是一个简化示例,实际应用中可能需要添加错误处理、性能监控等功能。
  • 需要替换 your_model.xml 为实际的 OpenVINO 模型路径。
  • 如果图像文件不存在,示例代码会创建假的图像文件,方便测试。

总结

通过使用 OpenVINO™ 提供的图像分类异步推理 Python 示例,我们可以轻松地实现图像列表的异步推理。这种方法避免了使用视频流输入,更加灵活,适用于各种需要处理图像数据的场景。通过调整代码中的参数和预处理步骤,您可以将其应用于不同的模型和任务,从而充分利用 OpenVINO™ 的强大功能。记住,异步推理的关键在于合理地管理推理请求,充分利用硬件资源,从而提高整体推理效率。

以上就是OpenVINO 异步推理:图像列表输入解决方案的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号