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

高性能百度OCR ONNX Runtime C#实现

OCR 示例

RapidOCRSharpOnnx使用

1 导出模型为onnx格式

如何转换PP-OCR模型为onnx格式,可以参考PP-OCR官网Obtaining ONNX Models, 或者直接从RapidOCR的魔塔社区下载Model List.

2 安装RapidOCRSharpOnnx组件并加载模型

Install Nuget packages RapidOCRSharpOnnx, OnnxRuntime, OpenCvSharp4.runtime

CPU 推理

dotnet add package RapidOCRSharpOnnx dotnet add package OpenCvSharp4.runtime.win dotnet add package Microsoft.ML.OnnxRuntime
using RapidOCRSharp ocr = new RapidOCRSharp(new ExecutionProviderCPU(new OcrConfig(detectPath, recPath, LangRec.CH, OCRVersion.PPOCRV5, clsMobilePath)));

CoreML 推理

dotnet add package RapidOCRSharpOnnx dotnet add package OpenCvSharp4.runtime.osx.10.15-x64 dotnet add package Microsoft.ML.OnnxRuntime
using RapidOCRSharp ocr = new RapidOCRSharp(new ExecutionProviderCoreML(new OcrConfig(detectPath, recPath, LangRec.CH, OCRVersion.PPOCRV5, clsMobilePath)));

CUDA/TensorRT 推理

dotnet add package RapidOCRSharpOnnx dotnet add package OpenCvSharp4.runtime.win dotnet add package Microsoft.ML.OnnxRuntime.Gpu.Windows
using RapidOCRSharp ocr = new RapidOCRSharp(new ExecutionProviderCUDA(new OcrConfig(detectPath, recogPath, LangRec.CH, OCRVersion.PPOCRV5, clsPath), deviceId)); using RapidOCRSharp ocr = new RapidOCRSharp(new ExecutionProviderTensorRT(new OcrConfig(detectPath, recogPath, LangRec.CH, OCRVersion.PPOCRV5, clsPath), deviceId));

DirectML 推理

dotnet add package RapidOCRSharpOnnx dotnet add package OpenCvSharp4.runtime.win dotnet add package Microsoft.ML.OnnxRuntime.DirectML
using RapidOCRSharp ocr = new RapidOCRSharp(new ExecutionProviderDirectML(new OcrConfig(detectPath, recogPath, LangRec.EN, OCRVersion.PPOCRV5, clsPath), deviceId));

OpenVINO 推理

dotnet add package RapidOCRSharpOnnx dotnet add package OpenCvSharp4.runtime.win dotnet add package Intel.ML.OnnxRuntime.OpenVino
using RapidOCRSharp ocr = new RapidOCRSharp(new ExecutionProviderOpenVINO(new OcrConfig(detectPath, recogPath, LangRec.EN, OCRVersion.PPOCRV5, clsPath), IntelDeviceType.NPU));

基本的API使用

using RapidOCRSharp ocr = new RapidOCRSharp(new ExecutionProviderDirectML(new OcrConfig(detectPath, recogPath, LangRec.EN, OCRVersion.PPOCRV5, clsPath), _deviceId)); string savePath = $"res_{Path.GetFileName(imgPath)}"; var result = ocr.RecognizeText(imgPath, savePath); Console.WriteLine($"result: {result.ToString()}");

批量识别图片

using RapidOCRSharp ocr = new RapidOCRSharp(new ExecutionProviderDirectML(new OcrConfig(detectPath, recogPath, LangRec.CH, OCRVersion.PPOCRV5, clsPath), _deviceId)); var list = Directory.GetFiles(@"C:\code\model\OCRTestImages"); Stopwatch sw = new Stopwatch(); sw.Start(); var resPath = ocr.BatchParallelAsync(list.ToList(), saveDir, receiveAction: ReceiveResult); sw.Stop(); Console.WriteLine($"BatchAsync Time: {sw.ElapsedMilliseconds} ms"); private static void ReceiveResult(OcrBatchResult batchResult) { Console.WriteLine(batchResult.ToString()); Console.WriteLine("------------------------------------------------------------"); }

批量识别使用Foreach API

private static async Task TestBatchForeachAsync() { string detectPath = @"D:\code\RapidOCRSharpOnnx\RapidOCRSharpOnnx.TestCommon\Models\ch_PP-OCRv5_det_mobile.onnx"; string recogPath = @"D:\code\RapidOCRSharpOnnx\RapidOCRSharpOnnx.TestCommon\Models\ch_PP-OCRv5_rec_mobile.onnx"; string clsPath = @"D:\code\RapidOCRSharpOnnx\RapidOCRSharpOnnx.TestCommon\Models\ch_PP-LCNet_x0_25_textline_ori_cls_mobile.onnx"; using RapidOCRSharp ocr = new RapidOCRSharp(new ExecutionProviderDirectML(new OcrConfig(detectPath, recogPath, LangRec.CH, OCRVersion.PPOCRV5, clsPath), _deviceId)); var list = Directory.GetFiles(@"D:\code\model\OCRTestImages"); var res = ocr.BatchForeachAsync(list.ToList(), @"D:\code\model\OCRTestImagesResults"); await foreach (var item in res) { Console.WriteLine(item.TextBlocks); } }

性能测试

OCR组件库性能对比测试 CPU推理测试

OCR libraryVersionlanguageInference Engine
PaddleSharp3.0.1Paddle Inference C API .NET bindingSdcb.PaddleInference
PaddleOCR3.5.0pythonpaddlepaddle
RapidOCR3.8.1pythonopenvino
RapidOCRSharpOnnx1.0.0C#Intel.ML.OnnxRuntime.OpenVino

测试电脑

Windows 11 Pro OS Version 25H2

CPU: Intel Core Ultra 9 285k 3.7GHz

内存:DDR5 128GB speed 4400MT/s

硬盘:SSD 2TB

测试数据

图片: 60 张图片 (图片大小: 1180x92)

PP-OCR 模型: ch_PP-OCRv5_det_mobile, ch_PP-OCRv5_rec_mobile, ch_PP-LCNet_x0_25_textline_ori_cls_mobile

PaddleSharp 测试结果

CPU 推理时间 : 48.1769278s

PaddleOCR 测试结果

CPU 推理时间 : 62.6685s

RapidOCR 测试结果

CPU 推理时间 : 17.9634s

RapidOCRSharpOnnx 测试结果

CPU 推理时间 : 9.2447s

性能测试结果

OCR libraryVersionlanguageInference EngineElapsed Time
PaddleSharp3.0.1Paddle Inference C API .NET bindingSdcb.PaddleInference.runtime.win64.mkl version 3.1.0.54 CPU48.1769s
PaddleOCR3.5.0pythonpaddlepaddle version 3.2.0 CPU62.6685s
RapidOCR3.8.1pythonopenvino version 2026.1.0 21367 CPU
http://www.gsyq.cn/news/1642358.html

相关文章:

  • AgentKit 与 MCP 集成指南:打造企业级智能体应用
  • 如何快速上手CorridorKey:AI绿幕抠像的5个专业技巧与常见问题解决方案
  • 开源革命:OpenCore Legacy Patcher让老Mac重获新生的终极指南
  • 解锁2.5G网络性能:Realtek RTL8125 DKMS驱动终极指南
  • 揭秘sprocketnes架构:Rust如何实现高性能NES游戏机模拟的10个关键技术
  • Kokoro TTS自动化脚本编写:批量处理大量文件的完整方案
  • Shopware 6完整部署指南:5步搭建专业电商平台
  • Serverless Node.js Starter完全指南:快速构建现代无服务器应用
  • 如何专业配置LaTeX Workshop环境变量:5个高级技巧实战指南
  • 如何为linux_kernel_cves贡献数据:社区驱动的CVE追踪完整指南
  • Varnish Agent 2与Dashboard集成:实现实时监控的黄金组合
  • PySol FC:300+款开源纸牌游戏的终极指南,打造你的专属游戏库
  • 三步解锁国家中小学智慧教育平台电子课本PDF下载:免费开源解决方案
  • 自定义地图标记完全指南:Google Maps iOS Utils高级样式与动画技巧
  • 高精度计时系统设计与CS2200-CP应用实践
  • 如何轻松永久保存微信聊天记录:WeChatMsg终极指南
  • RTX3060本地部署DeepSeek 7B模型实战指南
  • MAA明日方舟助手:3个核心功能让你轻松实现游戏日常自动化
  • 突破性解决方案:Kronos金融市场基础模型的创新架构与生产就绪部署
  • Scan Tailor终极指南:免费开源文档扫描处理神器,让老旧文档重获新生
  • 告别手动修图:用Scan Tailor实现扫描文档的智能重生
  • OpCore-Simplify:从新手到专家,三分钟搞定黑苹果EFI配置
  • 三步构建智能代码助手:低资源消耗部署方案
  • 如何永久珍藏你的数字对话?一款让聊天记录重获新生的本地工具
  • 深度解析:如何高效实现Windows平台微信/QQ/TIM防撤回补丁的终极指南
  • BT下载终极加速指南:89个公共Tracker让你的下载速度飙升300%
  • 5个步骤让旧Mac焕然一新:OpenCore Legacy Patcher升级指南
  • Wexflow移动端应用终极指南:Android和iOS客户端的使用与开发
  • Linux社区技术实践:从ILF 2011看问题驱动的开源协作范式
  • Missionary:Clojure/Script函数式效果与流式处理系统的终极指南