吴忠躺衫网络科技有限公司

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

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

3天內不再提示

基于OpenVINO?工具包部署飛槳PP-Human的全流程

SDNLAB ? 來源:楊雪鋒 ? 2023-02-23 18:03 ? 次閱讀

本文將詳細介紹基于OpenVINO工具包,在C#語言下,部署飛槳PP-Human的全流程,幫助開發者快速掌握并部署產業級AI人體分析解決方案。

飛槳實時行人分析工具PP-Human

PP-Human是飛槳目標檢測套件PaddleDetection中開源的實時行人分析工具,提供了五大異常行為識別和四大產業級功能:人體屬性分析、人流計數、跨鏡ReID,如下圖所示:

68a96c2a-a2e3-11ed-bfe3-dac502259ad0.png

圖 1-1PP-Human v2全功能全景圖

PP-Human技術架構

PP-Human支持單張圖片、圖片文件夾單鏡頭視頻和多鏡頭視頻輸入,經目標檢測以及特征關聯,實現屬性識別、關鍵點檢測、軌跡/流量計數以及行為識別等功能,如下圖所示。本文將以行人摔倒識別為例,基于OpenVINO進行多種模型聯合部署。

68bdfe42-a2e3-11ed-bfe3-dac502259ad0.png ?

圖 1-2PP-Human技術架構

構建C#開發環境

為了防止復現代碼出現問題,列出以下代碼開發環境,可以根據自己需求設置,注意OpenVINO一定是2022版本,其他依賴項可以根據自己的設置修改。

操作系統:Windows 11

OpenVINO:2022.3

OpenCV:4.5.5

Visual Studio:2022 Community

C#框架:.NET 6.0

OpenCvSharp:OpenCvSharp4

C#中調用OpenVINO實現

構建OpenVINO動態鏈接庫

由于OpenVINO只有C++Python接口,無法直接在C#中使用OpenVINO部署模型,為了實現在C#中使用,通過動態鏈接庫的方式實現。

在C#中引入動態鏈接庫文件

在C#中需要使用[DllImport()]方法引入動態鏈接庫文件,其完整的使用方式如以下代碼所示:

[DllImport(openvino_dll_path, CharSet=CharSet.Unicode, CallingConvention=CallingConvention.Cdecl)]

publicexternstaticIntPtrset_input_image_sharp(IntPtrinference_engine, stringinput_node_name, refulonginput_size);

針對[DllImport()]括號中的內容:

openvino_dll_path為dll文件路徑

CharSet = CharSet.Unicode代表支持中文編碼格式字符串

CallingConvention = CallingConvention.Cdecl指示入口點的調用約定為調用方清理堆棧

在聲明動態鏈接庫后,就可以引入動態鏈接庫中的方法,由于我們在C++環境下生成的動態鏈接庫,為了讓編譯器識別,需要方法名、變量類型一一對應,才可以引入成功:

6916e8c2-a2e3-11ed-bfe3-dac502259ad0.png

表 1C++與C#方法對應關系

基于以上方法,我們將動態鏈接庫中的所有方法引入到C#中。

C#構建Core類

上一步我們引入了封裝的OpenVINO動態鏈接庫,為了更方便的使用,將其封裝到Core類中。

在不同方法之間,主要通過推理核心結構體指針在各個方法之間傳遞,在C#是沒有指針這個說法的,不過可以通過IntPtr結構體來接收這個指針,為了防止該指針被篡改,將其封裝在類中作為私有成員使用。

根據模型推理的步驟,構建模型推理類:

(1)構造函數

publicCore(stringmodel_file, stringdevice_name){

// 初始化推理核心

ptr = NativeMethods.core_init(model_file, device_name);

}

在該方法中,主要是調用推理核心初始化方法,初始化推理核心,讀取本地模型,將模型加載到設備、創建推理請求等模型推理步驟。

(2)設置模型輸入形狀

// @brief 設置推理模型的輸入節點的大小

// @param input_node_name 輸入節點名

// @param input_size 輸入形狀大小數組

publicvoidset_input_sharp(stringinput_node_name, ulong[] input_size) {

// 獲取輸入數組長度

intlength = input_size.Length;

if(length == 4) {

// 長度為4,判斷為設置圖片輸入的輸入參數,調用設置圖片形狀方法

ptr = NativeMethods.set_input_image_sharp(ptr, input_node_name, refinput_size[0]);

}

elseif(length == 2) {

// 長度為2,判斷為設置普通數據輸入的輸入參數,調用設置普通數據形狀方法

ptr = NativeMethods.set_input_data_sharp(ptr, input_node_name, refinput_size[0]);

}

else{

// 為防止輸入發生異常,直接返回

return;

}

}

OpenVINO 2022.3支持模型動態輸入,讀入模型可以不固定輸入大小,在使用時固定模型的輸入大小,并且可以隨時修改輸入形狀。當前設置情況下,至此設置二維、以及四維的輸入形狀,在當前模型中足夠使用。

(3)加載推理數據

// @brief 加載推理數據

// @param input_node_name 輸入節點名

// @param input_data 輸入數據數組

publicvoidload_input_data(stringinput_node_name, float[] input_data) {

ptr = NativeMethods.load_input_data(ptr, input_node_name, refinput_data[0]);

}

// @brief 加載圖片推理數據

// @param input_node_name 輸入節點名

// @param image_data 圖片矩陣

// @param image_size 圖片矩陣長度

publicvoidload_input_data(stringinput_node_name, byte[] image_data, ulongimage_size, inttype) {

ptr = NativeMethods.load_image_input_data(ptr, input_node_name, refimage_data[0], image_size, type);

}

加載推理數據主要包含圖片數據和普通的矩陣數據,其中對于圖片的預處理,也已經在C++中進行封裝,保證了圖片數據在傳輸中的穩定性。

(4)模型推理

// @brief 模型推理

publicvoidinfer() {

ptr = NativeMethods.core_infer(ptr);

}

(5)讀取推理結果數據

// @brief 讀取推理結果數據

// @param output_node_name 輸出節點名

// @param data_size 輸出數據長度

// @return 推理結果數組

publicT[] read_infer_result(stringoutput_node_name, intdata_size) {

// 獲取設定類型

stringt = typeof(T).ToString();

// 新建返回值數組

T[] result = newT[data_size];

if(t == "System.Int32") { // 讀取數據類型為整形數據

int[] inference_result = newint[data_size];

NativeMethods.read_infer_result_I32(ptr, output_node_name, data_size, refinference_result[0]);

result = (T[])Convert.ChangeType(inference_result, typeof(T[]));

returnresult;

}

else{ // 讀取數據類型為浮點型數據

float[] inference_result = newfloat[data_size];

NativeMethods.read_infer_result_F32(ptr, output_node_name, data_size, refinference_result[0]);

result = (T[])Convert.ChangeType(inference_result, typeof(T[]));

returnresult;

}

}

在讀取模型推理結果時,支持讀取整形數據和浮點型數據,且需要知曉模型輸出數據的大小,這就要求我們對自己所使用的模型有很好的把握。

(6)清除地址

// @brief 刪除創建的地址

publicvoiddelet() {

NativeMethods.core_delet(ptr);

}

此處的清除地址需要調用fengzhuangd額地址刪除方法實現,不可以直接刪除C#中創建的IntPtr,這樣會導致內存泄漏,影響程序性能。

通過上面的封裝,比可以在C#平臺下,調用Core類,間接調用OpenVINO工具包署自己的模型了。





審核編輯:劉清

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

    關注

    180

    文章

    7614

    瀏覽量

    137727
  • OpenCV
    +關注

    關注

    31

    文章

    635

    瀏覽量

    41559
  • python
    +關注

    關注

    56

    文章

    4807

    瀏覽量

    85040

原文標題:基于C# 和OpenVINO部署飛槳PP-Human

文章出處:【微信號:SDNLAB,微信公眾號:SDNLAB】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    基于C#和OpenVINO?在英特爾獨立顯卡上部署PP-TinyPose模型

    OpenVINO,將 PP-TinyPose 模型部署在英特爾獨立顯卡上。 1.1 PP-TinyPose 模型簡介 PP-TinyP
    的頭像 發表于 11-18 18:27 ?2606次閱讀

    介紹英特爾?分布式OpenVINO?工具包

    介紹英特爾?分布式OpenVINO?工具包可快速部署模擬人類視覺的應用程序和解決方案。 該工具包基于卷積神經網絡(CNN),可擴展英特爾?硬件的計算機視覺(CV)工作負載,從而最大限度
    發表于 07-26 06:45

    怎么安裝適用于Linux *的OpenVINO?工具包的英特爾?發布版?

    怎么安裝適用于Linux *的OpenVINO?工具包的英特爾?發布版?
    發表于 09-23 08:33

    利用OpenVINO工具包檢測汽車品牌

    地檢測品牌、車標和形狀。 OpenVINO TM的Intel&Distribution工具包是一個全面的工具包,用于快速開發模擬人類視覺的應用程序和解決方案。該工具包以細胞神經
    發表于 08-04 07:36

    如何在OpenVINO工具包中使用帶推理引擎的blob?

    無法確定如何在OpenVINO?工具包中使用帶推理引擎的 blob。
    發表于 08-15 07:17

    如何在OpenVINO trade工具包中推斷兩個圖像?

    無法在OpenVINO?工具包中對兩個輸入圖像運行推理。
    發表于 08-15 08:24

    關于英特爾推出OpenVINO?工具包對物聯網的變革和影響分析

    新的OpenVINO工具包結合了各種先進硅片,可提供一個完整的高性能解決方案,用于邊緣到云端的深度學習和視頻分析。通過各種常見軟件框架,如TensorFlow*、MXNet*、Caffe*等,英特爾的視覺產品助力開發者更容易地部署
    的頭像 發表于 09-05 14:09 ?1843次閱讀

    產業級預訓練模型的實時行人分析工具PP-Human

    今天給大家介紹的,就是這樣一套不僅擁有上述能力,還直接提供目標檢測、屬性分析、關鍵點檢測、行為識別、ReID等產業級預訓練模型的實時行人分析工具PP-Human,方便開發者靈活取用及更改!
    的頭像 發表于 04-20 10:16 ?2045次閱讀

    基于OpenVINO? 的版 PGNet 實現案例

    OpenVINO 工具套件2022.1版于2022年3月22日正式發布,根據官宣OpenVINO 迎來迄今為止最重大更新,2022.1新特性搶先看!,OpenVINO 2022.1將是
    發表于 08-04 16:25 ?877次閱讀

    基于NVIDIAGPU定制優化的NGC容器

    基于 NVIDIA GPU 定制優化的 NGC 容器,包含了最新的 NVIDIA 工具包和優化后的版本,致力于為開發者提供最佳的開發
    的頭像 發表于 08-25 10:49 ?920次閱讀

    行人分析工具PP-Human重磅升級!

    PP-Human經由真實業務場景數據深度打磨優化,擁有適應不同光線、復雜背景下的人體屬性特征分析、異常行為識別、出入口人流計數與軌跡繪制、跨鏡跟蹤四大核心功能。
    的頭像 發表于 10-19 15:19 ?1980次閱讀

    PaddleDetection 發新,歡迎在 NVIDIA NGC 容器中體驗最新特性!

    PaddleDetection 發版 v2.5,又帶著新功能和大家見面了。 本次更新,為大家帶來 PP-YOLOE+、PP-Human v2、PP-Vehicle、PicoDet-NPU 等技術
    的頭像 發表于 11-10 11:00 ?948次閱讀

    使用 OpenVINO? 工具包進行停車場監控

    使用 OpenVINO? 工具包進行停車場監控
    的頭像 發表于 01-03 09:45 ?768次閱讀
    使用 <b class='flag-5'>OpenVINO</b>? <b class='flag-5'>工具包</b>進行停車場監控

    使用 OpenVINO? 工具包監控機器操作員

    使用 OpenVINO? 工具包監控機器操作員
    的頭像 發表于 01-03 09:45 ?792次閱讀
    使用 <b class='flag-5'>OpenVINO</b>? <b class='flag-5'>工具包</b>監控機器操作員

    行人摔倒檢測-在英特爾開發套件上基于OpenVINO? C# API部署PP-Human

    OpenVINO 2023.1 于 2023 年 9 月 18 日發布,該工具包帶來了挖掘生成人工智能全部潛力的新功能。生成人工智能的覆蓋范圍得到了擴展,通過 PyTorch* 等框架增強了體驗,您可以在其中自動導入和轉換模型。
    的頭像 發表于 10-13 16:28 ?818次閱讀
    行人摔倒檢測-在英特爾開發套件上基于<b class='flag-5'>OpenVINO</b>? C# API<b class='flag-5'>部署</b><b class='flag-5'>PP-Human</b>
    威尼斯人娱乐备用6222| 卡迪拉娱乐城开户| 百家乐官网在线投注顺势法| 百家乐棋牌交友| 百乐坊娱乐城官网| 太阳城百家乐优惠| 关于阳宅风水24山知识| 澳门百家乐有没有假| 凱旋门百家乐的玩法技巧和规则 | 澳门百家乐官网鸿福厅| 哪里有百家乐代理| 皇冠百家乐官网客户端皇冠| 百家乐玩法介| 百家乐游戏网址| 百家乐官网书| 仪征市| 大发888娱乐场漏洞| 揭西县| 百家乐巴厘岛平台| 百家乐官网赌场老千| 362百家乐官网的玩法技巧和规则 大集汇百家乐官网的玩法技巧和规则 | 百家乐庄闲局部失衡| 海阳市| 公海百家乐的玩法技巧和规则| 百家乐官网北京| 北京太阳城二手房| 百家乐里和的作用| 三公百家乐官网玩法| 灵川县| 赌博百家乐经验网| 在线百家乐官网博彩网| 威尼斯人娱乐场钓鱼网站| 百家乐赌的技巧| 百家乐官网网络赌博网址| 大发888老虎机官方| 百家乐娱乐网会员注册| 线上百家乐官网技巧| 德州扑克 下载| 百家乐三国| 澳门百家乐官网娱乐场开户注册 | 百家乐视频打麻将|