您好,登錄后才能下訂單哦!
這篇文章主要講解了“C++怎么實現(xiàn)基于OpenCV的DNN網(wǎng)絡”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“C++怎么實現(xiàn)基于OpenCV的DNN網(wǎng)絡”吧!
OpenCV從3.3版本就開始引入DNN模塊,現(xiàn)在已經(jīng)是4.5版本了,DNN模塊的支持度也更好了。目前OpenCV已經(jīng)支持ONNX格式的模型加載和推理,后端的推理引擎也有了多種選擇。
而Pytorch作為目前易用性相對最好的深度學習訓練框架,使用非常廣泛。Pytorch的pth格式模型沒法直接用OpenCV加載,但可以轉換成ONNX格式使用。
首先在Ubuntu下編譯OpenCV,默認配置選項已經(jīng)可以支持加載ONNX模型進行推理,不需要contrib
庫支持或其他的特殊配置。
我在編譯過程中,按照習慣僅指定了CMAKE_INSTALL_PREFIX
參數(shù),用來指定編譯后的安裝路徑,方便后期管理,不干擾系統(tǒng)目錄。
Pytorch已經(jīng)原生支持導出ONNX模型,具體可以參見官方教程和文檔。
一個最簡化的導出Demo如下,核心的只有torch.onnx.export
一個函數(shù)。
import torch import torchvision model = torchvision.models.mobilenet_v2(pretrained=True) x = torch.rand(1, 3, 224, 224) save_path = "./model_file/mobilenetv2.onnx" torch.onnx.export(model, x, save_path, input_names=["input"], output_names=["output"], opset_version=11)
利用OpenCV的DNN模塊進行網(wǎng)絡推理,可以參考官方教程,以及源碼包中的samples/dnn/classification.cpp
。
這邊以我之前做的一個目標修正的小網(wǎng)絡為例,演示一個簡化的Demo。
模型借鑒MobilenetV2
中的InvertedResidual
模塊,搭建特征提取部分,輸入64*64的圖像,最后通過pooling
層和fc
層,輸出一個10維的向量。
輸出向量的含義分別為:
0:目標Confidence,是否包含目標;
1-5:目標Class,分類得分;
6-9:2D-BBox,按xywh方式表述。
一個簡化的推理Demo如下所示。
#include <iostream> #include <opencv2/opencv.hpp> using namespace cv; int main(int argc, char** argv) { // load model String model = "../model_file/mobilenet.onnx"; dnn::Net net = dnn::readNetFromONNX(model); // load image data float scale = 0.0078125; Scalar mean = Scalar(128.0, 128.0, 128.0); Mat frame = imread("../images/car.png"); Mat blob; dnn::blobFromImage(frame, blob, scale, Size(64, 64), mean, false, false); // inference and time double t = getTickCount(); net.setInput(blob); Mat output = net.forward(); t = (getTickCount() - t) / getTickFrequency(); std::cout << "Output shape: " << output.size() << ", Time-cost: " << t << std::endl; // visualize visualize_result(frame, output); return 0; }
其中結果可視化的代碼不再贅述,主要是把回歸出的2DBBox畫出來。
結果輸出如下:
Output shape: [10 x 1], Time-cost: 0.0013024
輸出結果維度符合預期,運行時間也與python調用onnxruntime
的運行耗時差不多。
結果可視化如下,可以正確地對車輛目標的位置進行修正。
感謝各位的閱讀,以上就是“C++怎么實現(xiàn)基于OpenCV的DNN網(wǎng)絡”的內容了,經(jīng)過本文的學習后,相信大家對C++怎么實現(xiàn)基于OpenCV的DNN網(wǎng)絡這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。