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

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

    文章

    7617

    瀏覽量

    138156
  • OpenCV
    +關注

    關注

    31

    文章

    635

    瀏覽量

    41664
  • python
    +關注

    關注

    56

    文章

    4812

    瀏覽量

    85147

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

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

收藏 人收藏

    評論

    相關推薦

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

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

    使用OpenVINO C# API輕松部署PP-OCRv4模型

    ? 作者:算力魔方創始人/英特爾創新大使劉力 《超4萬6千星的開源OCR黑馬登場,PaddleOCR憑什么脫穎而出?》 收到了讀者熱烈反響,很多讀者提出:如何在C#中部署PP-OC
    的頭像 發表于 02-12 10:42 ?771次閱讀
    使用<b class='flag-5'>OpenVINO</b> C# API輕松<b class='flag-5'>部署</b><b class='flag-5'>飛</b><b class='flag-5'>槳</b><b class='flag-5'>PP</b>-OCRv4模型

    介紹英特爾?分布式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

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

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

    基于OpenVINO? 的版 PGNet 實現案例

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

    基于NVIDIAGPU定制優化的NGC容器

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

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

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

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

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

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

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

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

    使用 OpenVINO? 工具包監控機器操作員
    的頭像 發表于 01-03 09:45 ?805次閱讀
    使用 <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 ?841次閱讀
    行人摔倒檢測-在英特爾開發套件上基于<b class='flag-5'>OpenVINO</b>? C# API<b class='flag-5'>部署</b><b class='flag-5'>PP-Human</b>
    主站蜘蛛池模板: 婷婷四房综合激情五月性色 | 欧美成人h精品网站 | 日本69式xxx视频 | 久久夜色精品国产噜噜 | 六月婷婷导航福利在线 | 在线亚洲日产一区二区 | 九色愉拍自拍 | 欧美人与zoxxxx | 成人午夜啪啪免费网站 | 免费一级大毛片a一观看不卡 | 26uuu影院亚洲欧美综合 | 免费一级特黄视频 | 国产三级播放 | 国产免费福利网站 | 关晓彤被调教出奶水的视频 | 68日本xxxxxxx18| 免费高清特级毛片 | 天天看天天碰 | 免费啪视频在线观看 | 丁香网五月 | 国产精品久久久久久久久 | 黄色一级片在线观看 | 午夜视频免费观看黄 | 色丁香在线观看 | 天天看片中文字幕 | 久久久久久全国免费观看 | 国产三片理论电影在线 | 免费观看交性大片 | 国产无套视频在线观看香蕉 | 午夜大片免费完整在线看 | 一区二区三区中文国产亚洲 | 黄色二级视频 | 国产一级片免费看 | 夜夜春宵翁熄性放纵古代 | 欧美一区二区三区免费高 | 久操操操 | 99色视频在线 | 免费看成年视频网页 | 91久久青草精品38国产 | 欧美另类激情 | 野外啪啪抽搐一进一出 |