在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

基于RK3576開發(fā)板的OCR文字識別算法

ljx2016 ? 來源:ljx2016 ? 作者:ljx2016 ? 2025-05-08 09:30 ? 次閱讀

1. OCR文字識別簡介

文字識別也是圖像領域一個常見問題。然而,對于自然場景圖像,首先要定位圖像中的文字位置,然后才能進行文字的識別。所以一般包含兩個步驟:

文字檢測:解決的問題是哪里有文字,文字的范圍有多少。

文字識別:對定位好的文字區(qū)域進行識別,主要解決的問題是每個文字是什么,將圖像中的文字區(qū)域進轉化為字符信息。

我們的OCR算法是基于CTPN+CRNN設計的。CTPN是一種文字檢測算法,能有效的檢測出復雜場景的橫向分布的文字,是目前比較好的文字檢測算法。CRNN算法主要用于端到端地對不定長的文本序列進行識別,不用先對單個文字進行切割,而是將文本識別轉化為時序依賴的序列學習問題,就是基于圖像的序列識別。

基于EASY-EAI-Orin-nano硬件主板的運行效率:

算法種類 模型大小 運行效率
文字檢測算法 3.31MB 37ms
文字識別算法 6.19MB 3ms

2. 快速上手

如果您初次閱讀此文檔,請閱讀:《入門指南/源碼管理及編程介紹/源碼工程管理》,按需管理自己工程源碼(注:此文檔必看,并建議采用【遠程掛載管理】方式,否則有代碼丟失風險!!!)。

2.1 開源碼工程下載

先在PC虛擬機定位到nfs服務目錄,再在目錄中創(chuàng)建存放源碼倉庫的管理目錄:

cd ~/nfsroot
mkdir GitHub
cd GitHub

再通過git工具,在管理目錄內克隆遠程倉庫(需要設備能對外網進行訪問)

git clone https://github.com/EASY-EAI/EASY-EAI-Toolkit-3576.git
wKgZPGgcCpWAPmWOAAFJlZ-Xh3k614.png

注:

* 此處可能會因網絡原因造成卡頓,請耐心等待。

* 如果實在要在gitHub網頁上下載,也要把整個倉庫下載下來,不能單獨下載本實例對應的目錄。

2.2 開發(fā)環(huán)境搭建

通過adb shell進入板卡開發(fā)環(huán)境,如下圖所示。

wKgZO2gcCpWADCYhAAC554P6NFE403.png

通過以下命令,把nfs目錄掛載上nfs服務器。

mount -t nfs -o nolock : /home/orin-nano/Desktop/nfs/
wKgZPGgcCpaAeWuoAAD8wWi-yWg276.png

2.3 例程編譯

然后定位到板卡的nfs的掛載目錄(按照實際掛載目錄),進入到對應的例程目錄執(zhí)行編譯操作,具體命令如下所示:

cd EASY-EAI-Toolkit-3576/Demos/algorithm-ocr/
./build.sh
wKgZO2gcCpaARon-AAFi6Caoj7A860.png

2.4 模型部署

要完成算法Demo的執(zhí)行,需要先下載法模型。

百度網盤鏈接為:https://pan.baidu.com/s/1g4kpLTgMnYm1xop9LFeMIw?pwd=1234 (提取碼:1234 )。

wKgZPGgcCpaAHpB4AAA07vf6mR4257.png

同時需要把下載的檢測模型和識別模型復制粘貼到Release/目錄:

wKgZO2gcCpaAfjwbAABfvAeEDoQ199.png

2.5 例程運行及效果

進入開發(fā)板Release目錄,執(zhí)行下方命令,運行示例程序:

cd Release/
./test-ocr test.jpg

運行例程命令如下所示:

wKgZPGgcCpaAPIlEAAMgujgnozY569.png

結果圖片如下所示:

wKgZO2gcCpeAGQClAAEkuy9pDjk591.jpg

API的詳細說明,以及API的調用(本例程源碼),詳細信息見下方說明。

3. OCR文字識別API說明

3.1 引用方式

為方便客戶在本地工程中直接調用我們的EASY EAI api庫,此處列出工程中需要鏈接的庫以及頭文件等,方便用戶直接添加。

選項 描述
頭文件目錄 easyeai-api/algorithm/ocr
庫文件目錄 easyeai-api/algorithm/ocr
庫鏈接參數(shù) -locr

3.2 OCR檢測初始化函數(shù)

設置OCR檢測初始化函數(shù)原型如下所示。

int ocr_det_init(const char* model_path, rknn_app_context_t* app_ctx);

具體介紹如下所示。

函數(shù)名: ocr_det_init
頭文件 ocr.h
輸入參數(shù) model_path:算法模型名字/路徑
輸入參數(shù) app_ctx:算法模型句柄
返回值 成功返回:0
失敗返回:-1
注意事項

3.3 OCR檢測運行函數(shù)

設置OCR檢測運行原型如下所示。

int ocr_det_run(rknn_app_context_t* app_ctx, cv::Mat input_image, ocr_det_postprocess_params* params, ocr_det_result* out_result);

具體介紹如下所示。

函數(shù)名:ocr_det_run
頭文件 ocr.h
輸入參數(shù) app_ctx:算法模型句柄
輸入參數(shù) input_image:Cv::Mat輸入圖像
輸入參數(shù) params:ocr檢測算法參數(shù)
輸出參數(shù) out_result:返回結果
返回值 成功返回:0
失敗返回:-1
注意事項

3.4 OCR檢測釋放函數(shù)

設置OCR檢測釋放原型如下所示。

int ocr_det_release(rknn_app_context_t* app_ctx);

具體介紹如下所示。

函數(shù)名:ocr_det_release
頭文件 ocr.h
輸入參數(shù) app_ctx:算法模型句柄
返回值 成功返回:0
失敗返回:-1
注意事項

3.5 OCR識別初始化函數(shù)

OCR識別初始化函數(shù)原型如下所示。

int ocr_rec_init(const char* model_path, rknn_app_context_t* app_ctx);

具體介紹如下所示。

函數(shù)名:ocr_rec_init
頭文件 ocr.h
輸入參數(shù) model_path:算法模型名字/路徑
輸入參數(shù) app_ctx:算法模型句柄
返回值 成功返回:0
失敗返回:-1
注意事項

3.6 OCR識別運行函數(shù)

OCR識別運行函數(shù)原型如下所示。

int ocr_rec_run(rknn_app_context_t* app_ctx, cv::Mat input_image, ocr_rec_result* out_result);

具體介紹如下所示。

函數(shù)名:ocr_rec_run
頭文件 ocr.h
輸入參數(shù) app_ctx:算法模型句柄
輸入參數(shù) input_image:輸入圖像
輸出參數(shù) out_result:返回結果
返回值 成功返回:0
失敗返回:-1
注意事項

3.7 OCR識別釋放函數(shù)

OCR識別釋放函數(shù)原型如下所示。

int ocr_rec_release(rknn_app_context_t* app_ctx);

具體介紹如下所示。

函數(shù)名:ocr_rec_release
頭文件 ocr.h
輸入參數(shù) app_ctx:算法模型句柄
返回值 成功返回:0
失敗返回:-1
注意事項

4. OCR檢測算法例程

例程目錄為Demos/algorithm-ocr/test-ocr.cpp,操作流程如下。

wKgZPGgcCpeAakeIAABD0JksQWc004.png

#include 
#include 
#include 
#include"ocr.h"

using namespace cv;
using namespace std;

#define INDENT "    "
#define THRESHOLD 0.3 // pixel score threshold
#define BOX_THRESHOLD 0.9 // box score threshold
#define USE_DILATION false // whether to do dilation, true or false
#define DB_UNCLIP_RATIO 1.5 // unclip ratio for poly type

int main(int argc, char **argv)
{
	if (argc != 2) {
		printf("%s n", argv[0]);
		return -1;
	}
	/* 參數(shù)初始化 */
	const char *img_path = argv[1];
	Mat input_image, rgb_img;
	input_image = imread(img_path);
	if (input_image.empty()) {
		cout 

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 板卡
    +關注

    關注

    3

    文章

    132

    瀏覽量

    17121
  • 文字識別
    +關注

    關注

    0

    文章

    18

    瀏覽量

    8785
  • OCR
    OCR
    +關注

    關注

    0

    文章

    160

    瀏覽量

    16722
  • rk3576
    +關注

    關注

    1

    文章

    153

    瀏覽量

    590
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    基于RK3576開發(fā)板的WDT看門狗使用說明

    RK3576開發(fā)板的WDT使用說明
    的頭像 發(fā)表于 05-06 17:15 ?517次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發(fā)板</b>的WDT看門狗使用說明

    基于RK3576開發(fā)板的PCIE固態(tài)硬盤使用說明

    RK3576開發(fā)板的PICE固態(tài)硬盤使用方法
    的頭像 發(fā)表于 05-06 17:33 ?1240次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發(fā)板</b>的PCIE固態(tài)硬盤使用說明

    基于RK3576開發(fā)板的TF卡槽使用說明

    RK3576開發(fā)板使用TF卡槽
    的頭像 發(fā)表于 05-07 09:24 ?614次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發(fā)板</b>的TF卡槽使用說明

    基于RK3576開發(fā)板的PWN使用說明

    RK3576開發(fā)板使用PWN教程及Demo
    的頭像 發(fā)表于 05-07 14:07 ?1190次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發(fā)板</b>的PWN使用說明

    基于RK3576開發(fā)板的RTC使用說明

    文章主要展示RK3576開發(fā)板的RTC信息和快速上手例程
    的頭像 發(fā)表于 05-07 15:04 ?680次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發(fā)板</b>的RTC使用說明

    基于RK3576開發(fā)板的人臉識別算法

    RK3576開發(fā)板展示人臉識別算法例程和API說明
    的頭像 發(fā)表于 05-07 16:48 ?1843次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發(fā)板</b>的人臉<b class='flag-5'>識別</b><b class='flag-5'>算法</b>

    新品體驗 | RK3576開發(fā)板

    RK3399、RK3566、RK3568、RK3588、RK3576等型號的核心與評估
    的頭像 發(fā)表于 11-01 08:08 ?1785次閱讀
    新品體驗 | <b class='flag-5'>RK3576</b><b class='flag-5'>開發(fā)板</b>

    米爾RK3576開發(fā)板特惠活動!

    近日,米爾電子發(fā)布基于瑞芯微RK3576核心開發(fā)板RK3576作為國產熱門處理器,其高性能數(shù)據處理能力、領先的AI智能分析、強大的擴展性與兼容性受到廣大
    的頭像 發(fā)表于 11-12 01:00 ?752次閱讀
    米爾<b class='flag-5'>RK3576</b><b class='flag-5'>開發(fā)板</b>特惠活動!

    敬請期待 | 迅為RK3576開發(fā)板即將發(fā)布

    敬請期待 | 迅為RK3576開發(fā)板即將發(fā)布
    的頭像 發(fā)表于 11-22 15:13 ?558次閱讀
    敬請期待 | 迅為<b class='flag-5'>RK3576</b><b class='flag-5'>開發(fā)板</b>即將發(fā)布

    迅為RK3576開發(fā)板核心與底板接口硬件介紹

    迅為RK3576開發(fā)板核心與底板接口硬件介紹
    的頭像 發(fā)表于 01-14 15:15 ?1324次閱讀
    迅為<b class='flag-5'>RK3576</b><b class='flag-5'>開發(fā)板</b>核心<b class='flag-5'>板</b>與底板接口硬件介紹

    迅為RK3576開發(fā)板Android?多屏顯示

    迅為RK3576開發(fā)板Android?多屏顯示
    的頭像 發(fā)表于 01-16 16:58 ?875次閱讀
    迅為<b class='flag-5'>RK3576</b><b class='flag-5'>開發(fā)板</b>Android?多屏顯示

    基于RK3576開發(fā)板的MIPI-DSI使用

    MIPI DSI接口是由MIPI聯(lián)盟下的Display工作組指定的DSI(Display Serial Interface)的接口標準。rk3576開發(fā)板使用mipi-dsi教程
    的頭像 發(fā)表于 05-06 16:11 ?269次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發(fā)板</b>的MIPI-DSI使用

    基于RK3576開發(fā)板的揚聲器和耳機使用說明

    RK3576開發(fā)板的揚聲器和耳機使用說明
    的頭像 發(fā)表于 05-06 16:36 ?258次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發(fā)板</b>的揚聲器和耳機使用說明

    基于RK3576開發(fā)板的HDMI-OUT使用說明

    RK3576開發(fā)板的HDMI-OUT使用說明
    的頭像 發(fā)表于 05-06 16:48 ?223次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發(fā)板</b>的HDMI-OUT使用說明

    基于RK3576開發(fā)板的人員檢測算法

    展示了RK3576開發(fā)板的人員檢測算法例程及API說明
    的頭像 發(fā)表于 05-07 17:33 ?228次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發(fā)板</b>的人員檢測<b class='flag-5'>算法</b>
    主站蜘蛛池模板: 深夜大尺度视频在线观看 | 男人都懂得网址 | 台湾av| 免费的毛片网站 | 亚洲卡1卡2卡新区网站 | 黄色一级片播放 | 色狠狠色综合吹潮 | 国模大尺度人体一区 | 99精品热女视频专线 | 国产美女亚洲精品久久久久久 | nxgx欧美| 色秀网站 | 青草99| 欧美一级在线全免费 | 女人张开腿让男人桶视频免费大全 | 一级片aaaaaa| 国产美女一区二区三区 | 国产欧美一区二区日本加勒比 | 91av视频在线| 中文天堂在线视频 | 8844aa在线毛片 | 久久综合香蕉久久久久久久 | 国产男女怕怕怕免费视频 | 久久精品国产免费看久久精品 | 在线种子搜索 | 午夜视频在线免费 | 四虎影院大全 | 热99re久久精品2久久久 | 国产精品黄页网站在线播放免费 | 欧美黄又粗暴一进一出抽搐 | 成人丁香| 四虎影视免费 | 公妇乱淫日本免费观看 | 精品欧美 | 四虎影院美女 | 欧美成人一区二区三区在线视频 | 直接黄91麻豆网站 | 一级特黄aaa大片在线观看视频 | 天天舔天天射 | 成人亚洲精品 | 欧美一级艳片视频免费观看 |