哈哈哈哈哈操欧洲电影,久草网在线,亚洲久久熟女熟妇视频,麻豆精品色,久久福利在线视频,日韩中文字幕的,淫乱毛视频一区,亚洲成人一二三,中文人妻日韩精品电影

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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

解析OpenVINO? + SSD 實(shí)時(shí)對(duì)象檢測(cè)

英特爾物聯(lián)網(wǎng) ? 來源:英特爾物聯(lián)網(wǎng) ? 作者:英特爾物聯(lián)網(wǎng) ? 2021-05-18 09:35 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

前面我們了解OpenVINO 如何部署圖像分類網(wǎng)絡(luò)ResNet,本文我們將會(huì)學(xué)習(xí)OpenVINO 中對(duì)象檢測(cè)網(wǎng)絡(luò)的部署與推理應(yīng)用。說到對(duì)象檢測(cè)網(wǎng)絡(luò),我們首先需要理解兩個(gè)概念:對(duì)象檢測(cè)與對(duì)象檢測(cè)網(wǎng)絡(luò)。

SSD對(duì)象檢測(cè)模型

對(duì)象檢測(cè)是計(jì)算機(jī)視覺核心任務(wù)之一,也是最常見與應(yīng)用最廣泛的視覺場(chǎng)景。OpenVINO 已經(jīng)提供了以下通用場(chǎng)景下的對(duì)象檢測(cè)包括人臉檢測(cè)、行人檢測(cè)、物體檢測(cè)、車輛檢測(cè)、車牌檢測(cè)等,一個(gè)圖像對(duì)象檢測(cè)顯示示意圖如下:

圖-1(來自SSD論文)

相比圖像分類,對(duì)象檢測(cè)多了每個(gè)對(duì)象位置信息,所以簡(jiǎn)單的認(rèn)為對(duì)象檢測(cè)=圖像分類+Box位置信息。第一個(gè)深度學(xué)習(xí)相關(guān)的對(duì)象檢測(cè)網(wǎng)絡(luò)正是基于這樣思想的RCNN模型,但是它的缺點(diǎn)是無法實(shí)時(shí),所以2015年底有人提出了一個(gè)實(shí)時(shí)對(duì)象檢測(cè)網(wǎng)絡(luò)Single Shot MultiBox Detector縮寫為SSD。它的模型結(jié)構(gòu)如下:

23b73396-b4ff-11eb-bf61-12bb97331649.png

圖2(來自SSD論文)

圖2中SSD對(duì)象檢測(cè)網(wǎng)絡(luò)簡(jiǎn)單說可以分為三個(gè)部分:

- 基礎(chǔ)網(wǎng)絡(luò)(backbone) 這里為VGG16

- 特征提取Neck,構(gòu)建多尺度特征

- 檢測(cè)頭 – 非最大抑制與輸出

OpenVINO 中模型庫(kù)自帶預(yù)訓(xùn)練的人臉檢測(cè)網(wǎng)絡(luò)有很多,分別針對(duì)不同的應(yīng)用場(chǎng)景與輸入分辨率。這里我們以face-detection-0202人臉檢測(cè)模型為例說明,它是一個(gè)MobileNetV2作為基礎(chǔ)網(wǎng)絡(luò)的SSD對(duì)象檢測(cè)模型,模型支持的輸入圖像大小與格式如下:

NCHW=1x3x384x384其中

N表示圖像數(shù)目,這里為1

C表示輸入圖像通道數(shù)目,這里彩色圖像為3

H表示圖像高度

W表示圖像寬度

期望的圖像通道順序:BGR

23f26fa6-b4ff-11eb-bf61-12bb97331649.png

圖-3

模型推理計(jì)算得輸出格式為:

1x1xNx7其中

N表示檢測(cè)到的對(duì)象數(shù)目

7表示[image_id, label, conf, x_min, y_min, x_max, y_max]這七個(gè)值,其中

Image_id 表示圖像編號(hào),這個(gè)輸入的是一張圖像,base為0

Label 表示標(biāo)簽,跟數(shù)據(jù)集的label_map文本文件相關(guān),根據(jù)標(biāo)簽編號(hào)可以查找標(biāo)簽文本名

Conf 表示對(duì)象的置信度,取值范圍在0~1之間,值越大表示置信程度越高

x_min, y_min, x_max, y_max 四個(gè)值對(duì)象位置信息,分別是左上角與有下角的坐標(biāo)

該模型的相關(guān)性能參數(shù)如下:

圖-4

從上面我們可以知道模型來自Pytorch訓(xùn)練生成。

OpenVINO基于SSD模型實(shí)時(shí)人臉檢測(cè)

現(xiàn)在我們已經(jīng)了解SSD模型的基本網(wǎng)絡(luò)結(jié)構(gòu),OpenVINO 自帶SSD人臉檢測(cè)模型face-detection-0202的輸入與輸出相關(guān)格式與參數(shù)細(xì)節(jié)信息,這里我們就基于該模型使用OpenVINO 中的推理引擎模型實(shí)現(xiàn)一個(gè)實(shí)時(shí)人臉檢測(cè)應(yīng)用,根據(jù)之前的內(nèi)容,我們首先需要加載模型,相關(guān)代碼如下:

// 加載檢測(cè)模型

auto network = ie.ReadNetwork(model_xml, model_bin);

其中

model_xml表示face-detection-0202模型文件

model_bin表示face-detection-0202權(quán)重文件

然后設(shè)置模型的輸入與輸出相關(guān)的格式,代碼如下:

// 請(qǐng)求網(wǎng)絡(luò)輸入與輸出信息

InferenceEngine::InputsDataMap input_info(network.getInputsInfo());

InferenceEngine::OutputsDataMap output_info(network.getOutputsInfo());

// 設(shè)置輸入格式

for (auto &item : input_info) {

auto input_data = item.second;

input_data->setPrecision(Precision::U8);

input_data->setLayout(Layout::NCHW);

}

printf("get it ");

// 設(shè)置輸出格式

for (auto &item : output_info) {

auto output_data = item.second;

output_data->setPrecision(Precision::FP32);

}

加載可執(zhí)行網(wǎng)絡(luò),創(chuàng)建推理請(qǐng)求對(duì)象實(shí)例,代碼如下:

// 創(chuàng)建可執(zhí)行網(wǎng)絡(luò)對(duì)象

auto executable_network = ie.LoadNetwork(network, "CPU");

// 請(qǐng)求推斷圖

auto infer_request = executable_network.CreateInferRequest();

設(shè)置推理輸入圖像數(shù)據(jù),轉(zhuǎn)換為NCHW格式的blob數(shù)據(jù),代碼如下:

/** Getting input blob **/

auto input = infer_request.GetBlob(input_name);

size_t num_channels = input->getTensorDesc().getDims()[1];

size_t h = input->getTensorDesc().getDims()[2];

size_t w = input->getTensorDesc().getDims()[3];

size_t image_size = h*w;

Mat blob_image;

resize(src, blob_image, Size(w, h));

// NCHW

unsigned char* data = static_cast(input->buffer());

for (size_t row = 0; row < h; row++) {

for (size_t col = 0; col < w; col++) {

for (size_t ch = 0; ch < num_channels; ch++) {

data[image_size*ch + row*w + col] = blob_image.at(row, col)[ch];

}

}

}

預(yù)測(cè)與解析輸出結(jié)果,代碼如下:

// 執(zhí)行預(yù)測(cè)

infer_request.Infer();

// 處理輸出結(jié)果

for (auto &item : output_info) {

auto output_name = item.first;

// 獲取輸出數(shù)據(jù)

auto output = infer_request.GetBlob(output_name);

const float* detection = static_cast::value_type*>(output->buffer());

const SizeVector outputDims = output->getTensorDesc().getDims();

const int maxProposalCount = outputDims[2];

const int objectSize = outputDims[3];

// 解析輸出結(jié)果

for (int curProposal = 0; curProposal < maxProposalCount; curProposal++) {

float label = detection[curProposal * objectSize + 1];

float confidence = detection[curProposal * objectSize + 2];

float xmin = detection[curProposal * objectSize + 3] * image_width;

float ymin = detection[curProposal * objectSize + 4] * image_height;

float xmax = detection[curProposal * objectSize + 5] * image_width;

float ymax = detection[curProposal * objectSize + 6] * image_height;

if (confidence > 0.5) {

printf("label id : %d ", static_cast(label));

Rect rect;

rect.x = static_cast(xmin);

rect.y = static_cast(ymin);

rect.width = static_cast(xmax - xmin);

rect.height = static_cast(ymax - ymin);

putText(src, "OpenVINO-2021R02", Point(20, 20), FONT_HERSHEY_SIMPLEX, 0.75, Scalar(0, 0, 255), 2, 8);

rectangle(src, rect, Scalar(0, 255, 255), 2, 8, 0);

}

std::cout << std::endl;

}

}

imshow("OpenVINO+SSD人臉檢測(cè)", src);

最終顯示結(jié)果如下:

圖-5

總結(jié)

本文我們完成了OpenVINO 人臉檢測(cè)模型的推理調(diào)用演示,關(guān)鍵知識(shí)點(diǎn)在于模型的輸入與輸出格式,以及推理以后的模型輸出數(shù)據(jù)的解析方式。到這里大家希望借助OpenVINO 實(shí)現(xiàn)一個(gè)視頻版本的人臉檢測(cè),沒關(guān)系,下一次我們將來完成這樣的事情……

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • SSD
    SSD
    +關(guān)注

    關(guān)注

    21

    文章

    3146

    瀏覽量

    122563
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4975

    瀏覽量

    74314
  • 人臉檢測(cè)
    +關(guān)注

    關(guān)注

    0

    文章

    88

    瀏覽量

    17312
  • 深度學(xué)習(xí)
    +關(guān)注

    關(guān)注

    73

    文章

    5603

    瀏覽量

    124590
  • resnet
    +關(guān)注

    關(guān)注

    0

    文章

    14

    瀏覽量

    3424

原文標(biāo)題:OpenVINO? + SSD 實(shí)時(shí)對(duì)象檢測(cè)

文章出處:【微信號(hào):英特爾物聯(lián)網(wǎng),微信公眾號(hào):英特爾物聯(lián)網(wǎng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    SSD固態(tài)硬盤品牌推薦:從FTL到掉電保護(hù),讀懂高可靠存儲(chǔ)的技術(shù)邏輯

    SSD固態(tài)硬盤正在逐步取代機(jī)械硬盤成為各類系統(tǒng)的核心存儲(chǔ)方案。本文從技術(shù)原理出發(fā),解析SSD如何通過FTL閃存轉(zhuǎn)換層、磨損均衡、垃圾回收等機(jī)制實(shí)現(xiàn)高性能與高可靠,并結(jié)合工業(yè)級(jí)應(yīng)用場(chǎng)景,探討高可靠
    的頭像 發(fā)表于 04-09 17:06 ?231次閱讀

    工業(yè)級(jí)SATA 2.5” ArmourDrive? PX系列SSD深度解析

    工業(yè)級(jí)SATA 2.5” ArmourDrive? PX系列SSD深度解析 在電子設(shè)備飛速發(fā)展的今天,數(shù)據(jù)存儲(chǔ)的需求日益增長(zhǎng),對(duì)存儲(chǔ)設(shè)備的性能、可靠性和安全性提出了更高的要求。Greenliant
    的頭像 發(fā)表于 03-30 14:20 ?119次閱讀

    Windows平臺(tái)EtherCAT實(shí)時(shí)控制:從抖動(dòng)抑制到虛擬化架構(gòu)解析

    Windows平臺(tái)EtherCAT實(shí)時(shí)控制:從抖動(dòng)抑制到虛擬化架構(gòu)解析
    的頭像 發(fā)表于 01-29 15:26 ?363次閱讀
    Windows平臺(tái)EtherCAT<b class='flag-5'>實(shí)時(shí)</b>控制:從抖動(dòng)抑制到虛擬化架構(gòu)<b class='flag-5'>解析</b>

    無法在NPU上推理OpenVINO?優(yōu)化的 TinyLlama 模型怎么解決?

    在 NPU 上推斷 OpenVINO?優(yōu)化的 TinyLlama 模型。 遇到的錯(cuò)誤: get_shape was called on a descriptor::Tensor with dynamic shape
    發(fā)表于 07-11 06:58

    無法將Tensorflow Lite模型轉(zhuǎn)換為OpenVINO?格式怎么處理?

    將 Tensorflow Lite 模型轉(zhuǎn)換為 OpenVINO? 格式。 遇到的錯(cuò)誤: FrontEnd API failed with OpConversionFailure:No translator found for TFLite_Detection_PostProcess node.
    發(fā)表于 06-25 08:27

    請(qǐng)問OpenVINO? 是否支持 Rust 綁定?

    無法確定OpenVINO?是否支持 Rust 綁定。
    發(fā)表于 06-25 07:45

    無法運(yùn)行Whisper Asr GenAI OpenVINO? Notebook怎么解決?

    冉小 聲說-asr-genai OpenVINO?筆記本。 遇到的錯(cuò)誤: Port for tensor name cache_position was not found.
    發(fā)表于 06-25 07:41

    請(qǐng)問如何優(yōu)化OpenVINO?工具套件中的內(nèi)存使用?

    運(yùn)行OpenVINO?推斷時(shí)找不到優(yōu)化內(nèi)存使用情況的方法。
    發(fā)表于 06-25 06:56

    請(qǐng)問Openvino是否支持 Risc-V (riscv64) 架構(gòu)?

    在spacemit k1型板(bpi-f3)上編譯OpenVINO?,但失敗。 使用 riscv64 構(gòu)建OpenVINO?并崩潰。
    發(fā)表于 06-24 07:26

    請(qǐng)問如何通過OpenVINO?加速啟用穩(wěn)定的擴(kuò)散 Web UI?

    無法運(yùn)行具有OpenVINO?加速的穩(wěn)定擴(kuò)散 Web UI。
    發(fā)表于 06-24 06:48

    使用Openvino? GenAI運(yùn)行Sdxl Turbo模型時(shí)遇到錯(cuò)誤怎么解決?

    使用 OpenVINO? GenAI 運(yùn)行 SDXL Turbo 模型。 遇到的錯(cuò)誤: RuntimeError :- Check ov_tokenizer || ov_detokenizer Neither tokenizer nor detokenizer models were provided
    發(fā)表于 06-24 06:38

    無法將Openvino? 2025.0與onnx運(yùn)行時(shí)Openvino? 執(zhí)行提供程序 1.16.2 結(jié)合使用,怎么處理?

    使用OpenVINO?與英特爾 i5-8500 CPU 和超核處理器 630 iGPU 一起部署模型。 使用了 Microsoft.ML.OnnxRuntime.OpenVino
    發(fā)表于 06-24 06:31

    為什么無法通過“pip install openvino-dev==2025.0.0”安裝 2025.0 OpenVINO??

    通過“pip install openvino-dev==2025.0.0OpenVINO? 2025.0 安裝。 收到的錯(cuò)誤: ERROR: No matching distribution found for openvino
    發(fā)表于 06-23 08:13

    明遠(yuǎn)智睿SSD2351開發(fā)板:視頻監(jiān)控領(lǐng)域的卓越之選

    和管理。 在實(shí)際應(yīng)用中,以智能安防監(jiān)控系統(tǒng)為例。SSD2351開發(fā)板可以連接多個(gè)高清攝像頭,對(duì)監(jiān)控區(qū)域進(jìn)行全方位覆蓋。開發(fā)板對(duì)攝像頭采集到的視頻數(shù)據(jù)進(jìn)行實(shí)時(shí)編碼和壓縮,通過網(wǎng)絡(luò)傳輸?shù)奖O(jiān)控中心或云端
    發(fā)表于 05-30 10:24

    OpenVINO C#如何運(yùn)行YOLO11實(shí)例分割模型

    代碼是我在OpenVINO-CSharp-API作者開源的YOLOv8對(duì)象檢測(cè)的代碼基礎(chǔ)上修改而成。
    的頭像 發(fā)表于 04-29 09:30 ?2194次閱讀
    <b class='flag-5'>OpenVINO</b> C#如何運(yùn)行YOLO11實(shí)例分割模型
    青州市| 德州市| 巨野县| 磴口县| 和田县| 邵东县| 曲周县| 郸城县| 滦南县| 西华县| 华池县| 巢湖市| 勐海县| 罗源县| 大竹县| 沧州市| 浮梁县| 万州区| 玛曲县| 宁波市| 梅州市| 聂荣县| 宝坻区| 泰和县| 灵山县| 房产| 衡南县| 蓝田县| 葫芦岛市| 宜都市| 资源县| 马尔康县| 彰化市| 辽阳市| 闸北区| 大余县| 芦溪县| 万安县| 涡阳县| 集安市| 克山县|