当前位置: 首页 > article >正文

别再手动拼接数据了!用ONNXRuntime和TensorRT实现多Batch推理的Python/C++实战对比

多Batch推理实战ONNXRuntime与TensorRT的高效对决在计算机视觉项目的实际部署中我们常常会遇到这样的场景摄像头持续采集图像或者需要同时处理来自多个传感器的数据。如果每次只处理单张图片就像用吸管喝一大桶水——理论上可行但效率低得令人抓狂。这就是多Batch推理的价值所在它能像漏斗一样一次性处理多张图片显著提升吞吐量。1. 为什么需要多Batch推理想象一下工厂的生产线。如果传送带上每次只允许放一个零件那么大部分时间机器都在等待零件就位。而多Batch就像加宽传送带让机器一次性处理多个零件最大化利用计算资源。硬件利用率对比RTX 3090显卡处理方式GPU利用率吞吐量(images/sec)延迟(ms)单张循环15%-25%1208.3Batch465%-80%4808.3Batch885%-98%9008.9从表格可以看出当Batch Size从1增加到8时吞吐量提升了7.5倍而延迟几乎不变。这就是为什么在实际工程中多Batch处理是必选项而非可选项。2. ONNXRuntime的多Batch实现解析ONNXRuntime作为跨平台推理引擎其多Batch处理API设计得非常直观。让我们看一个Python示例处理两张MNIST手写数字图片import numpy as np import onnxruntime as ort # 准备两个28x28的MNIST图像数据 img1 np.random.rand(1, 1, 28, 28).astype(np.float32) # 模拟数字2 img2 np.random.rand(1, 1, 28, 28).astype(np.float32) # 模拟数字8 # 沿batch维度拼接 batch_input np.concatenate([img1, img2], axis0) # 创建推理会话 sess ort.InferenceSession(lenet.onnx, providers[CUDAExecutionProvider]) # 获取输入输出名称 input_name sess.get_inputs()[0].name output_name sess.get_outputs()[0].name # 执行推理 outputs sess.run([output_name], {input_name: batch_input}) predicted_labels np.argmax(outputs[0], axis1) print(f预测结果: {predicted_labels}) # 输出类似 [2, 8]关键点说明np.concatenate的axis0参数指定沿batch维度拼接ONNXRuntime会自动识别输入数据的batch维度大小输出结果也会按batch维度排列在C中实现时内存管理需要更谨慎// 准备batch数据 std::vectorfloat input_tensor_values(batch_size * 1 * 28 * 28); // 填充img1数据到前28*28个位置 // 填充img2数据到后28*28个位置 // 创建Tensor Ort::Value input_tensor Ort::Value::CreateTensorfloat( memory_info, input_tensor_values.data(), input_tensor_values.size(), input_dims.data(), input_dims.size() ); // 执行推理 auto outputs session.Run( Ort::RunOptions{nullptr}, input_name, input_tensor, 1, output_name, 1 );3. TensorRT的批处理实现策略TensorRT作为NVIDIA的专属推理加速器其批处理实现更底层但也更高效。Python实现的关键步骤import tensorrt as trt import pycuda.driver as cuda # 创建引擎和执行上下文 with open(lenet.engine, rb) as f, trt.Runtime(trt.Logger(trt.Logger.WARNING)) as runtime: engine runtime.deserialize_cuda_engine(f.read()) context engine.create_execution_context() # 分配显存 h_input cuda.pagelocked_empty(trt.volume(context.get_binding_shape(0)), dtypenp.float32) d_input cuda.mem_alloc(h_input.nbytes) stream cuda.Stream() # 准备batch数据 batch_data np.concatenate([img1, img2], axis0).ravel() np.copyto(h_input, batch_data) # 异步执行推理 cuda.memcpy_htod_async(d_input, h_input, stream) context.execute_async_v2( bindings[int(d_input), int(d_output)], stream_handlestream.handle ) cuda.memcpy_dtoh_async(h_output, d_output, stream) stream.synchronize()TensorRT的C实现更显其威力// 准备batch数据 float* host_input nullptr; cudaMallocHost(host_input, batch_size * 1 * 28 * 28 * sizeof(float)); // 填充img1和img2数据 // 执行异步推理 float* device_bindings[] {device_input, device_output}; context-enqueueV2( (void**)device_bindings, stream, nullptr ); // 同步并获取结果 cudaStreamSynchronize(stream); float* output ...; // 从device_output获取结果性能对比测试数据同一RTX 3090显卡框架Batch1延迟(ms)Batch8延迟(ms)最大吞吐量ONNXRuntime(CPU)12.585.294 img/sONNXRuntime(GPU)3.210.1790 img/sTensorRT2.88.7920 img/s4. 工程实践中的陷阱与解决方案维度不匹配错误是最常见的问题之一。当你的模型期望输入是[batch, channel, height, width]而你提供了[channel, height, width, batch]时就会出现静默错误。调试技巧在调用run/enqueue前打印输入张量的shape确保与模型预期一致内存对齐问题在C中尤为棘手。例如TensorRT可能要求输入数据在显存中是64字节对齐的// 确保内存对齐的分配方式 void* aligned_malloc(size_t size, size_t alignment) { void* ptr nullptr; posix_memalign(ptr, alignment, size); return ptr; }批处理尺寸动态化是实际项目中的常见需求。TensorRT支持动态batch但需要特殊配置profile builder.create_optimization_profile() profile.set_shape( input_name, min(1, 1, 28, 28), opt(8, 1, 28, 28), max(32, 1, 28, 28) ) config.add_optimization_profile(profile)流式处理模式可以进一步提升吞吐量。我们在一个安防摄像头项目中实现了这样的流水线线程A从摄像头采集图像并预处理线程B将多个图像拼接到batch缓冲区线程C执行异步推理线程D解析并输出结果这种设计使得GPU几乎没有空闲时间将系统吞吐量提升了3倍。

相关文章:

别再手动拼接数据了!用ONNXRuntime和TensorRT实现多Batch推理的Python/C++实战对比

多Batch推理实战:ONNXRuntime与TensorRT的高效对决 在计算机视觉项目的实际部署中,我们常常会遇到这样的场景:摄像头持续采集图像,或者需要同时处理来自多个传感器的数据。如果每次只处理单张图片,就像用吸管喝一大桶…...

在数据预处理流水线中集成 Taotoken 进行文本摘要与分类

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 在数据预处理流水线中集成 Taotoken 进行文本摘要与分类 对于数据工程师和算法工程师而言,构建一个稳定、高效且成本可…...

从 API 调用到工具链:梳理 AI 介入测试流程的 5 个成熟度等级

2026年,AI正在以前所未有的速度重构软件测试行业。但“AI测试”并非一个开关——从简单调用ChatGPT生成几条用例,到构建完整的Agent自愈测试体系,中间存在一条清晰的能力进化路径。本文将这条路径梳理为5个成熟度等级,结合2026年最新工具、开源项目与行业数据,帮你准确评估…...

IS6201A多相PWM控制器:从架构解析到PCB布局的电源设计实战

1. 项目概述:为什么我们需要关注IS6201A?在电源设计领域,尤其是面对高性能计算、数据中心服务器、高端显卡以及工业自动化设备时,工程师们常常面临一个核心挑战:如何为那些“电老虎”级别的核心芯片(比如CP…...

Jable视频下载神器:3分钟掌握Chrome插件+本地下载器完美方案

Jable视频下载神器:3分钟掌握Chrome插件本地下载器完美方案 【免费下载链接】jable-download 方便下载jable的小工具 项目地址: https://gitcode.com/gh_mirrors/ja/jable-download 还在为无法保存Jable.tv上的精彩视频而烦恼吗?想要轻松将喜欢的…...

HPM6750 LVGL性能优化:片内SRAM帧缓冲实战解析

1. 项目概述:当LVGL遇上HPM6750的片内“新大陆”最近在嵌入式图形界面开发的圈子里,一个关于HPM6750的话题热度不低。起因是有开发者发现,在基于HPM6750这款高性能RISC-V MCU进行LVGL(Light and Versatile Graphics Library&#…...

NAS-FPN里的GP和Sum Cell到底怎么工作的?手把手图解MMCV源码实现

NAS-FPN中的GP与Sum Cell工作机制解析:从理论到MMCV源码实现 在目标检测领域,特征金字塔网络(FPN)已经成为处理多尺度目标的标配组件。然而传统FPN采用固定的人工设计结构,难以适应不同检测任务的需求。NAS-FPN通过神经网络结构搜索技术&…...

STM32串口调试玄学翻车?从XCOM 2.3到2.0的降级避坑实录

STM32串口调试的版本陷阱:当XCOM 2.3让你的开发板"沉默"时 调试嵌入式系统时,最令人抓狂的莫过于硬件一切正常,代码毫无问题,但串口就是拒绝工作。最近在STM32F103ZET6开发板上遇到了一个诡异现象:同一块板子…...

WinForm窗体最小化与还原(右下角)

最小化按钮private void btnMinimize_Click( object sender, EventArgs e ) {this.WindowState FormWindowState.Minimized;notifyIcon1 new NotifyIcon( );notifyIcon1.Icon this.Icon;notifyIcon1.MouseDoubleClick NotifyIcon1_MouseDoubleClick; }窗体最小化与还原触发…...

ESP32任务看门狗(TWDT)实战:从配置到调试,手把手教你防止程序‘饿死’

ESP32任务看门狗深度实战:构建高可靠多任务系统的关键技巧 在物联网设备开发中,系统稳定性往往决定着产品的成败。想象一下这样的场景:你的智能家居网关在凌晨3点突然停止响应,或者工业传感器节点在关键时刻丢失数据——这些问题的…...

从‘过拟合陷阱’到可靠评估:手把手教你用Python和Scikit-learn玩转交叉验证(含RepeatedKFold/LeaveOneOut)

从‘过拟合陷阱’到可靠评估:手把手教你用Python和Scikit-learn玩转交叉验证(含RepeatedKFold/LeaveOneOut) 当你满怀期待地将训练集上准确率高达98%的模型部署到生产环境,却发现实际预测效果惨不忍睹时,那种落差感就…...

protobufjs 编译命令选错就报错?一文搞懂 pbjs 的 -w 参数(es6 vs commonjs 实战解析)

ProtobufJS编译模块类型选型指南:ES6与CommonJS的深度对比与实战避坑 最近在Vite项目中集成Protobuf时,编译后的模块导入总是抛出The requested module does not provide an export named错误。这个问题困扰了我整整两天,最终发现根源在于pbj…...

地平线6地图有哪些 地平线6可以在手机上玩吗

很多玩家都在关注地平线6地图的细节,想知道这款即将上线的竞速大作究竟有哪些可探索的场景,而地平线6地图的丰富度也直接决定了游戏的可玩性。不少玩家习惯用手机碎片时间想体验游戏,却受设备限制无法解锁地平线6地图的全部风光,这…...

UE5实战:手把手教你用AIController和PathFollowingComponent实现NPC智能移动(含源码解析)

UE5智能寻路实战:从零构建NPC导航系统 在虚幻引擎5的游戏开发中,AI角色的自主移动能力直接影响着游戏体验的真实感。许多开发者初次接触UE5的AI系统时,往往会被NavigationSystem、AIController和PathFollowingComponent等模块的复杂关系所困扰…...

3分钟搞定OFD转PDF:免费开源工具Ofd2Pdf完整使用指南

3分钟搞定OFD转PDF:免费开源工具Ofd2Pdf完整使用指南 【免费下载链接】Ofd2Pdf Convert OFD files to PDF files. 项目地址: https://gitcode.com/gh_mirrors/ofd/Ofd2Pdf 还在为打不开OFD文件而烦恼吗?今天我要向你推荐一个完全免费、简单高效的…...

英雄联盟皮肤修改器R3nzSkin:从内存钩子到游戏逆向的完整技术指南

英雄联盟皮肤修改器R3nzSkin:从内存钩子到游戏逆向的完整技术指南 【免费下载链接】R3nzSkin Skin changer for League of Legends (LOL) 项目地址: https://gitcode.com/gh_mirrors/r3n/R3nzSkin R3nzSkin是一款专为《英雄联盟》设计的开源游戏皮肤修改器&a…...

Redis分布式锁进阶第六十一篇

一、本篇前置衔接 第九十二篇我们完成Redisson源码拆解、手写复刻、底层内核穿透,彻底明白分布式锁代码层、脚本层、线程层原理。到此为止,代码、源码、坑点、运维、监控、面试全部讲透。但很多开发最大的困惑依旧存在:不同体量公司为什么锁架…...

GPU太贵跑不起?这6个优化技巧让LLM推理成本直降

大家好,我是小悟。 一、详细描述 随着深度学习模型(尤其是大语言模型)规模不断增长,推理阶段的计算和存储开销成为实际部署中的主要瓶颈。推理优化的目标是:在尽可能保持模型精度的前提下,降低推理延迟、提…...

polars导入csv文件时指定列数据类型

polars导入csv文件时指定列数据类型schema {column1: pl.Int64,column2: pl.Float64,column3: pl.Utf8}df pl.read_csv(data.csv, schemaschema)def pddaoru_csv(filedir):order_5G[承建方,厂家,市名称,统计局区县,数据时间,小区名称,基站ID,小区ID,小区覆盖类别,频段,带宽,小…...

TVA驱动智能家居的视觉范式革命(4)

重磅预告:本专栏将独家连载系列丛书《智能体视觉技术与应用》部分精华内容,该书是世界首套系统阐述“因式智能体”视觉理论与实践的专著,特邀美国 TypeOne 公司首席科学家、斯坦福大学博士 Bohan 担任技术顾问。Bohan先生师从美国三院院士、“…...

保姆级教程:把Windows系统装进固态U盘,用云固件打造随身移动办公神器

随身Windows系统:用固态U盘打造移动办公终极解决方案 咖啡馆的午后阳光斜照在键盘上,你从包里掏出一个名片大小的设备,插入陌生电脑的USB接口。30秒后,熟悉的桌面环境、未写完的文档、收藏夹里的书签全部跃然屏上——这不是科幻场…...

暗黑3终极宏工具D3KeyHelper:5分钟配置你的自动战斗系统

暗黑3终极宏工具D3KeyHelper:5分钟配置你的自动战斗系统 【免费下载链接】D3keyHelper D3KeyHelper是一个有图形界面,可自定义配置的暗黑3鼠标宏工具。 项目地址: https://gitcode.com/gh_mirrors/d3/D3keyHelper D3KeyHelper是一款专为暗黑破坏神…...

手把手教你用UE5 C++为角色添加动态攀爬:支持移动平台与高度自适应

手把手实现UE5动态攀爬系统:移动平台与高度自适应全解析 在当代3A级动作游戏中,角色与环境的动态交互已成为沉浸感的核心要素。想象一个场景:玩家在摇晃的空中浮岛上追逐目标,需要连续攀爬移动中的平台;或是潜入敌方基…...

每天节省25分钟!淘宝淘金币全自动任务脚本终极指南

每天节省25分钟!淘宝淘金币全自动任务脚本终极指南 【免费下载链接】taojinbi 淘宝淘金币自动执行脚本,包含蚂蚁森林收取能量,芭芭农场全任务,解放你的双手 项目地址: https://gitcode.com/gh_mirrors/ta/taojinbi 你是否厌…...

法律文书分析系统接入 A-MEM 长程记忆

项目实训 | Vue3 FastAPI | NeurIPS 2025 A-MEM 复现与工程落地一、背景与动机 在法律文书智能分析系统的开发过程中,我们发现了一个核心痛点:AI助手没有"记忆"。 用户在第一轮对话里详细描述了案件事实——“我是原告张三,2024年…...

大麦网Python抢票脚本终极指南:告别手速焦虑,轻松获取心仪门票

大麦网Python抢票脚本终极指南:告别手速焦虑,轻松获取心仪门票 【免费下载链接】DamaiHelper 大麦网演唱会演出抢票脚本。 项目地址: https://gitcode.com/gh_mirrors/dama/DamaiHelper 还在为心仪演唱会门票秒光而烦恼吗?还在为黄牛高…...

UNet迁移实战:如何用Labelme标注自己的数据,并快速替换官方数据集进行训练

UNet迁移实战:从Labelme标注到自定义数据集训练全流程指南 当你在GitHub上成功运行了UNet的官方Demo后,下一步自然是想让这个强大的语义分割模型为你自己的项目服务——无论是分析医学影像中的病变区域,还是识别卫星图片中的特定地物。本文将…...

独立开发者一人全栈项目中的AI能力集成与运维简化思路

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 独立开发者一人全栈项目中的AI能力集成与运维简化思路 对于独立开发者而言,一人承担全栈项目的设计、开发和运维是常态…...

独立开发者如何利用Taotoken快速上线并迭代AI功能原型

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 独立开发者如何利用Taotoken快速上线并迭代AI功能原型 对于独立开发者或小型工作室而言,验证一个AI产品创意的关键在于…...

3步掌握HTTrack:免费网站离线下载工具终极指南

3步掌握HTTrack:免费网站离线下载工具终极指南 【免费下载链接】httrack HTTrack Website Copier, copy websites to your computer (Official repository) 项目地址: https://gitcode.com/gh_mirrors/ht/httrack 你是否经常遇到网络不稳定,却急需…...