在 Python 和 C++ 环境下安装和使用 ONNX Runtime
创始人
2024-11-11 19:38:59
0

GPU 依赖项

对于 GPU 版本的 ONNX Runtime,需要安装 CUDA 和 cuDNN。请检查 CUDA 执行提供程序的要求以获取兼容版本的 CUDA 和 cuDNN。安装时请注意:

  • cuDNN 需要 ZLib,安装方法请参照 cuDNN 安装指南。
  • CUDA 和 cuDNN 的 bin 目录路径需要添加到环境变量 PATH 中。

《这部分可以去B站有很多教学视频讲的更详细》

Python 环境安装

安装 ONNX Runtime CPU 版本

要在 Python 环境中安装 ONNX Runtime 的 CPU 版本,可以使用以下命令:

pip install onnxruntime 

安装 ONNX Runtime GPU 版本 (CUDA )

pip install onnxruntime-gpu 

验证Python 示例

以下是一个简单的 Python 示例,用于加载和运行 ONNX 模型:

import onnxruntime as ort  # 加载 ONNX 模型 session = ort.InferenceSession("model.onnx")  # 准备输入数据 input_name = session.get_inputs()[0].name input_data = ...  # 根据模型要求准备输入数据  # 运行推理 result = session.run(None, {input_name: input_data})  # 输出结果 print(result) 

C++ 环境安装

安装 ONNX Runtime CPU 版本

在 C++ 环境中安装 ONNX Runtime 的 CPU 版本,可以使用以下命令:

# 克隆 ONNX Runtime 仓库 git clone --recursive https://github.com/microsoft/onnxruntime cd onnxruntime  # 构建并安装 ./build.sh --config Release --build_shared_lib 

安装 ONNX Runtime GPU 版本 (CUDA 11.x)

要安装支持 CUDA 11.x 的 GPU 版本,可以使用以下步骤:

  1. 设置环境变量

export PATH=/usr/local/cuda-11.8/bin:$PATH export LD_LIBRARY_PATH=/usr/local/cuda-11.8/lib64:$LD_LIBRARY_PATH 

      2. 构建 ONNX Runtime

./build.sh --config Release --use_cuda 

《windows端可以用 vs编辑器配置相应的头文件、库文件》 

C++ 验证示例

以下是一个简单的 C++ 示例,用于加载和运行 ONNX 模型:

#include  #include  #include   int main() {   // 初始化 ONNX Runtime   Ort::Env env(ORT_LOGGING_LEVEL_WARNING, "example");    // 创建 SessionOptions   Ort::SessionOptions session_options;   session_options.SetIntraOpNumThreads(1);   session_options.SetGraphOptimizationLevel(GraphOptimizationLevel::ORT_ENABLE_BASIC);    // 加载模型   Ort::Session session(env, "model.onnx", session_options);    // 获取模型输入信息   Ort::AllocatorWithDefaultOptions allocator;   const char* input_name = session.GetInputName(0, allocator);   std::cout << "Input Name: " << input_name << std::endl;    // 准备输入数据   std::vector input_data = ...;  // 根据模型要求准备输入数据   std::vector input_shape = {1, 3, 224, 224};  // 示例输入形状    // 创建输入 tensor   Ort::Value input_tensor = Ort::Value::CreateTensor(allocator, input_data.data(), input_data.size(), input_shape.data(), input_shape.size());    // 运行推理   auto output_tensors = session.Run(Ort::RunOptions{nullptr}, &input_name, &input_tensor, 1, session.GetOutputNames(allocator), 1);    // 输出结果   float* output_data = output_tensors[0].GetTensorMutableData();   std::cout << "Output: " << output_data[0] << std::endl;    return 0; } 

 通过上述步骤和示例代码,您可以在 Python 和 C++ 环境下安装并使用 ONNX Runtime 进行模型推理。

相关内容

热门资讯

玩家必备教程"wep... 玩家必备教程"wepoke软件机器人"详细外挂透明挂辅助工具-素来是真的有挂(哔哩哔哩);1、完成w...
第2分钟了解(WPK外挂)外挂... 第2分钟了解(WPK外挂)外挂透明挂辅助安装(透视)扑克教程(2020已更新)(哔哩哔哩);WPK外...
第9分钟了解!山西扣点辅助(辅... 第9分钟了解!山西扣点辅助(辅助挂)详细透视开挂辅助扑克教程(总是是真的挂)-哔哩哔哩;相信小伙伴都...
透视计算!wepoker有用(... 透视计算!wepoker有用(透视)底牌透视挂辅助挂(可靠开挂辅助爆料教程)-哔哩哔哩;详细wepo...
大家学习交流"wpk... 您好:wpk微扑克有辅助这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的...
7分钟了解(Wepoke识别)... 您好,Wepoke识别这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在...
第7分钟了解!邳州友友辅助软件... 您好,邳州友友辅助软件这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在...
一分钟揭秘!"wpk... 一分钟揭秘!"wpk后台管理系统"详细外挂透明挂辅助下载-先前真的有挂(哔哩哔哩);1、不需要AI权...
透视挂!hhpoker德州透视... 透视挂!hhpoker德州透视挂(透视)底牌透视挂辅助程序(可靠开挂辅助揭秘教程)-哔哩哔哩;透视挂...
八分钟了解(aapoker能玩... 您好:aapoker能玩这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的...