首页
/ ONNX Runtime中OpenVINO与DirectML执行提供器的兼容性问题解析

ONNX Runtime中OpenVINO与DirectML执行提供器的兼容性问题解析

2025-05-13 02:07:02作者:宣利权Counsellor

问题背景

在ONNX Runtime深度学习推理框架中,执行提供器(Execution Provider, EP)是支持不同硬件加速后端的关键组件。近期有开发者在Windows平台上构建了集成OpenVINO和DirectML(DML)两种执行提供器的ONNX Runtime 1.19.0版本,虽然构建过程顺利完成,但在实际使用中遇到了一个特殊的技术问题。

现象描述

开发者成功构建了包含OpenVINO 2024.3和DirectML的ONNX Runtime版本,并通过Python wheel包进行安装。系统能够正确识别并注册这两个执行提供器,但在尝试同时使用它们时出现了"Execution type OpenVINOExecutionProvider doesn't support memcpy"的错误。

具体表现为:

  1. 单独使用DirectML执行提供器时工作正常
  2. OpenVINO执行提供器也能被正确识别
  3. 但当尝试在同一个推理会话(InferenceSession)中同时指定这两个提供器时,系统抛出内存拷贝(memcpy)不支持的异常

技术分析

经过深入排查,发现问题源于ONNX Runtime执行提供器的协同工作机制。虽然ONNX Runtime文档中说明可以通过优先级列表指定多个执行提供器,让系统自动选择最合适的提供器执行每个节点,但这种机制在OpenVINO和DirectML这两个特定提供器之间存在兼容性问题。

根本原因可能涉及以下几个方面:

  1. 内存管理差异:OpenVINO和DirectML可能采用了不同的内存分配和管理策略,导致在尝试在两者之间传输数据时出现不兼容
  2. 执行上下文隔离:这两个提供器可能要求完全独立的执行上下文,不能很好地共享内存资源
  3. 架构限制:早期版本中可能存在过于严格的检查机制,限制了跨提供器的内存操作

解决方案

开发者最终找到了有效的解决方法:

  1. 单独使用执行提供器:为OpenVINO和DirectML分别创建独立的推理会话
# OpenVINO专用会话
openvino_options = [{'device_type': 'GPU', 'cache_dir': 'cachedir'}]
openvino_session = onnxruntime.InferenceSession(
    "model.onnx", 
    providers=['OpenVINOExecutionProvider'],
    provider_options=openvino_options
)

# DirectML专用会话
dml_session = onnxruntime.InferenceSession(
    "model.onnx",
    providers=['DmlExecutionProvider']
)
  1. 避免混合使用:不要在同一个会话中同时指定这两个提供器

最佳实践建议

  1. 版本选择:考虑使用更新的ONNX Runtime版本,因为后续版本可能已经修复了这个问题
  2. 性能考量:如果需要切换不同硬件后端,建议预先创建多个会话实例,而不是依赖执行提供器的自动切换
  3. 错误处理:在代码中添加适当的异常处理,当首选提供器不可用时优雅地回退到备用方案
  4. 资源管理:注意不同提供器可能对GPU资源有不同的占用方式,避免资源冲突

总结

这个案例展示了深度学习框架中多后端支持可能遇到的底层兼容性问题。虽然ONNX Runtime设计上支持多执行提供器的协同工作,但在实际实现中,特定硬件后端的组合可能需要特殊处理。理解这些底层机制有助于开发者更好地利用框架的强大功能,同时避免潜在的陷阱。

对于需要同时支持多种硬件加速方案的应用程序,建议采用明确的、分离的后端选择策略,而不是依赖框架的自动选择机制,这样可以获得更可靠和可预测的行为。

登录后查看全文
热门项目推荐
相关项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
27
11
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
466
3.47 K
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
10
1
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
65
19
flutter_flutterflutter_flutter
暂无简介
Dart
715
172
giteagitea
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
23
0
kernelkernel
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
203
82
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.27 K
695
rainbondrainbond
无需学习 Kubernetes 的容器平台,在 Kubernetes 上构建、部署、组装和管理应用,无需 K8s 专业知识,全流程图形化管理
Go
15
1
apintoapinto
基于golang开发的网关。具有各种插件,可以自行扩展,即插即用。此外,它可以快速帮助企业管理API服务,提高API服务的稳定性和安全性。
Go
22
1