-
一份来自python cnocr的cpp实现,官方文档->CnOcr文档
-
onnxruntime 自 https://github.com/microsoft/onnxruntime/releases 下载后 放入此文件夹或自行更改CMakeListsCMAK
-
onnxruntime版本为1.19
-
另 需求 vcpkg (opencv) 包
-
如只需截图识别工具请见 ScreenCutOcrCn
修改 以支持生成DLL
更新支持为 1.19 版本。
修改以支持新版onnxruntime
支持繁体中文识别
opencv Mat 替换为Umat,性能得到了一点点提升 onnxruntime 可以调用CUDA进行模型计算
英 文 识 别 可 用,~~但 是 有 [空格] 很 多,~~并英文识别准确率不准。en_dict词典首行和末行加了空格。
添加模型切换框架 修复黑底白字对调错误
添加准确率
移除numcpp包的需求转为opencv 也就是说 完全不需要numcpp包了
#include "cnocr.h"
#include <boost/timer/timer.hpp>
#include <thread>
void run_cnocr();
int main(){
boost::timer::auto_cpu_timer time1;
run_cnocr();
}
void run_cnocr(){
int i=0;
cnocr ocr(cnocr::USE_MODLE::cnocr136fc,cnocrmodle::USE_DEVICE::CUDA);//使用中文模型,和GPU
for (auto line:ocr.ocr("D:/Dev/CPP/CnocrCpp/cnocr.png")){
std::wcout<<i++<<":"<<line.first<<","<<line.second<<std::endl;
}
cnocr enocr(cnocr::USE_MODLE::en_number);//使用英文识别模型
for (auto line:enocr.ocr("D:/Dev/CPP/CnocrCpp/enocr.png")){
std::wcout<<i++<<":"<<line.first<<","<<line.second<<std::endl;
}
cnocr ctocr(cnocr::USE_MODLE::chinese_cht);//使用繁体识别
for (auto line:ctocr.ocr("D:/Dev/CPP/CnocrCpp/ctocr.png")){
std::wcout<<i++<<":"<<line.first<<","<<line.second<<std::endl;
}
}
0:cnocr自V2.1.2之后,可直接使用的模型包含两类:1)cnocr自己训练的模型,通常会包含PyTorch和,0.511289
1:ONNX版本;2)从其他ocr引擎搬运过来的训练好的外部模型,ONNX化后用于 cnocr中。,0.721081
2:The Rust Standard Library is the foundation of portable Rust software, a set of minimal and battle-tested shared abstractions for the,0.535793
3:broader Rust ecosystem. It offers core types, like Vec<T> and Option<T>, library-defined operations on language primitives,,0.51892
4:standard macros, I/O and multithreading, among many other things.,0.579248
5:如能粗略定位問題所牽涉的代碼巖請到相應的此代碼庫提交吋,0.0598933
6:若有解決方案峇歡迎發起l下eue吋,0.122603
1.125892s wall, 4.375000s user + 0.046875s system = 4.421875s CPU (392.7%)