使用OpenVINO异步推理处理图像子集

聖光之護
发布: 2025-08-03 18:24:01
原创
518人浏览过

使用openvino异步推理处理图像子集

本文介绍了如何使用OpenVINO™异步推理API处理图像子集,避免了传统视频流处理的限制。通过参考OpenVINO官方提供的图像分类异步Python示例,展示了如何将图像文件路径列表作为输入,实现高效的异步推理,从而优化图像处理服务的性能。本文将指导开发者如何利用OpenVINO的强大功能,构建更灵活、高效的图像处理应用。

在使用OpenVINO™进行推理时,异步推理API能显著提高性能,尤其是在处理大量图像数据时。 传统的同步推理需要等待一个请求完成后才能开始下一个请求,而异步推理允许并发执行多个推理请求,从而充分利用硬件资源。 本文将重点介绍如何利用OpenVINO的异步API处理图像子集,并提供一个基于图像文件路径列表的示例。

OpenVINO异步推理简介

OpenVINO的异步API通过start_async()和wait()方法实现。start_async()方法启动推理请求,而不会阻塞主线程。 wait()方法用于等待特定请求完成。 通过合理地安排start_async()和wait()的调用,可以实现推理任务的并行执行,从而提高整体吞吐量。

基于图像文件路径列表的异步推理

OpenVINO官方提供了一个图像分类异步Python示例,展示了如何使用图像文件路径列表作为输入。 该示例位于OpenVINO repository中,可以参考 Image Classification Async Python Sample 获取更多信息。

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

图酷AI
图酷AI

下载即用!可以免费使用的AI图像处理工具,致力于为用户提供最先进的AI图像处理技术,让图像编辑变得简单高效。

图酷AI 57
查看详情 图酷AI
import openvino.runtime as ov
import cv2
import numpy as np

def async_inference(model_path, image_paths):
    """
    使用OpenVINO异步API对图像列表进行推理。

    Args:
        model_path (str): 模型文件路径。
        image_paths (list): 图像文件路径列表。
    """

    # 1. 加载模型
    core = ov.Core()
    model = core.read_model(model_path)
    compiled_model = core.compile_model(model, "CPU") # 根据实际情况选择设备

    # 2. 获取输入/输出信息
    input_layer = compiled_model.input(0)
    output_layer = compiled_model.output(0)
    input_shape = input_layer.shape

    # 3. 创建推理请求
    num_requests = 2  # 可以根据实际情况调整
    infer_requests = [compiled_model.create_infer_request() for _ in range(num_requests)]

    # 4. 准备输入数据
    images = []
    for image_path in image_paths:
        image = cv2.imread(image_path)
        resized_image = cv2.resize(image, (input_shape[3], input_shape[2])) # 调整大小
        input_data = np.expand_dims(resized_image.transpose(2, 0, 1), 0) # 调整维度
        images.append(input_data)

    # 5. 异步推理
    results = []
    for i in range(len(images)):
        request_id = i % num_requests
        infer_requests[request_id].infer({input_layer: images[i]}) # 使用infer
        results.append(infer_requests[request_id].get_output_tensor(output_layer).data)

    # 等待所有请求完成
    for request in infer_requests:
        request.wait()

    return results

if __name__ == "__main__":
    model_path = "path/to/your/model.xml"  # 替换为你的模型文件路径
    image_paths = ["path/to/image1.jpg", "path/to/image2.jpg", "path/to/image3.jpg"]  # 替换为你的图像文件路径列表

    results = async_inference(model_path, image_paths)

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

代码解释:

  1. 加载模型: 使用 ov.Core() 加载 OpenVINO 模型。
  2. 获取输入/输出信息: 获取模型的输入和输出层的形状信息,以便后续处理图像数据。
  3. 创建推理请求: 创建多个推理请求(InferRequest),用于并发执行推理任务。 num_requests 变量控制并发请求的数量,可以根据硬件资源进行调整。
  4. 准备输入数据: 读取图像文件,调整大小和维度,使其符合模型的输入要求。
  5. 异步推理: 循环遍历图像列表,将图像数据分配给不同的推理请求,并使用 infer() 方法启动异步推理。
  6. 等待所有请求完成: 使用 wait() 方法等待所有推理请求完成。
  7. 获取结果: 使用 get_output_tensor()获取结果。

注意事项:

  • 模型文件路径: 确保 model_path 变量指向正确的 OpenVINO 模型文件(.xml)。
  • 图像文件路径: 确保 image_paths 列表包含有效的图像文件路径。
  • 输入形状: 确保图像的调整大小操作与模型的输入形状匹配。
  • 设备选择: 根据实际情况选择合适的推理设备,例如 "CPU"、"GPU" 等。
  • 并发请求数量: num_requests 的值需要根据硬件资源进行调整,过高的值可能导致性能下降。

总结

通过使用OpenVINO的异步推理API和图像文件路径列表作为输入,可以高效地处理图像子集。 这种方法避免了视频流处理的限制,并允许开发者构建更灵活、可扩展的图像处理应用。 通过合理地配置并发请求数量和优化数据预处理流程,可以进一步提高推理性能。 官方提供的图像分类异步Python示例是一个很好的起点,可以根据实际需求进行修改和扩展。

以上就是使用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号