如何解决使用 ONNX 模型推理时遇到的 "RuntimeError: Input must be a list of dictionaries or a single numpy array" 错误?

如何解决使用 onnx 模型推理时遇到的

如何调用 torch.onnx.export 导出的模型?

torch.onnx.export 会创建一个 onnx 模型,该模型可以在其他框架或设备上进行推理。

解决 runtimeerror:输入必须是字典列表或单个 numpy 数组

当你使用导出的 onnx 模型进行推理时,遇到了以下错误:

runtimeerror: input must be a list of dictionaries or a single numpy array for input 'x'.

这是因为 pytorch 模型的输入是张量,而 onnx 模型的输入是数组。要解决此错误,请将输入张量转换为 numpy 数组。

修改后的示例代码:

import onnxruntime
import numpy
import torch

# 创建 ONNX 模型
model = SumModule()
torch.onnx.export(model, (torch.ones(2, 2),), "onnx.pb", input_names=["x"], output_names=["sum"])

# 加载 ONNX 模型
ort_session = onnxruntime.InferenceSession("onnx.pb")

# 为模型创建输入,将其转换为 numpy 数组
input_data = numpy.ones((2, 2), dtype=numpy.float32)

# 运行模型
output_data = ort_session.run(None, {"x": input_data})

# 输出预测结果
print(output_data)

注意:input_data 类型的修改是关键。通过将输入张量转换为 numpy 数组,消除了 pytorch 和 onnx 之间的类型不匹配问题,使推理能够成功进行。

以上就是如何解决使用 ONNX 模型推理时遇到的 "RuntimeError: Input must be a list of dictionaries or a single numpy array" 错误?的详细内容,更多请关注硕下网其它相关文章!