女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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

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

3天內不再提示

基于RK3576開發板的OCR文字識別算法

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

1. OCR文字識別簡介

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

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

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

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

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

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

2. 快速上手

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

2.1 開源碼工程下載

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

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 開發環境搭建

通過adb shell進入板卡開發環境,如下圖所示。

wKgZO2gcCpWADCYhAAC554P6NFE403.png

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

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

2.3 例程編譯

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

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

2.4 模型部署

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

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

wKgZPGgcCpaAHpB4AAA07vf6mR4257.png

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

wKgZO2gcCpaAfjwbAABfvAeEDoQ199.png

2.5 例程運行及效果

進入開發板Release目錄,執行下方命令,運行示例程序:

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
庫鏈接參數 -locr

3.2 OCR檢測初始化函數

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

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

具體介紹如下所示。

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

3.3 OCR檢測運行函數

設置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);

具體介紹如下所示。

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

3.4 OCR檢測釋放函數

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

int ocr_det_release(rknn_app_context_t* app_ctx);

具體介紹如下所示。

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

3.5 OCR識別初始化函數

OCR識別初始化函數原型如下所示。

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

具體介紹如下所示。

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

3.6 OCR識別運行函數

OCR識別運行函數原型如下所示。

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

具體介紹如下所示。

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

3.7 OCR識別釋放函數

OCR識別釋放函數原型如下所示。

int ocr_rec_release(rknn_app_context_t* app_ctx);

具體介紹如下所示。

函數名:ocr_rec_release
頭文件 ocr.h
輸入參數 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;
	}
	/* 參數初始化 */
	const char *img_path = argv[1];
	Mat input_image, rgb_img;
	input_image = imread(img_path);
	if (input_image.empty()) {
		cout 

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

    關注

    3

    文章

    131

    瀏覽量

    17110
  • 文字識別
    +關注

    關注

    0

    文章

    18

    瀏覽量

    8773
  • OCR
    OCR
    +關注

    關注

    0

    文章

    157

    瀏覽量

    16704
  • rk3576
    +關注

    關注

    1

    文章

    145

    瀏覽量

    554
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    基于RK3576開發板的WDT看門狗使用說明

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

    基于RK3576開發板的PCIE固態硬盤使用說明

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

    基于RK3576開發板的TF卡槽使用說明

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

    基于RK3576開發板的PWN使用說明

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

    基于RK3576開發板的RTC使用說明

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

    基于RK3576開發板的人臉識別算法

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

    新品體驗 | RK3576開發板

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

    米爾RK3576開發板特惠活動!

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

    敬請期待 | 迅為RK3576開發板即將發布

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

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

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

    迅為RK3576開發板Android?多屏顯示

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

    基于RK3576開發板的MIPI-DSI使用

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

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

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

    基于RK3576開發板的HDMI-OUT使用說明

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

    基于RK3576開發板的人員檢測算法

    展示了RK3576開發板的人員檢測算法例程及API說明
    的頭像 發表于 05-07 17:33 ?205次閱讀
    基于<b class='flag-5'>RK3576</b><b class='flag-5'>開發板</b>的人員檢測<b class='flag-5'>算法</b>