引言
在工业视觉领域 OpenCV 使用较为广泛,其 DNN 模块支持深度学习模型的推理,如果在项目中使用了 OpenCV,那么很容易添加深度学习支持。
模型获取
OpenCV 不适合用于搭建模型,通常使用其他框架训练模型。ONNX 作为通用的模型描述格式被众多框架支持,这里推荐使用 ONNX 作为模型保存格式。以 PyTorch 为例,保存 ONNX 格式方法如下:
x = torch.randn(1, 3, 640, 640)
torch.onnx.export(network, x, "model.onnx")
加载并推理模型
Python代码如下:
# opencv 推理
net = cv2.dnn.readNetFromONNX("model.onnx") # 加载训练好的识别模型
image = cv2.imread("numbers/1.bmp") # 读取图片
blob = cv2.dnn.blobFromImage(image) # 由图片加载数据 这里还可以进行缩放、归一化等预处理
net.setInput(blob) # 设置模型输入
out = net.forward() # 推理出结果
C++代码如下:
// opencv 推理
cv::dnn::Net net = cv::dnn::readNetFromONNX("save.onnx"); // 加载训练好的识别模型
cv::Mat image = cv::imread("numbers/1.bmp"); // 读取图片
cv::Mat blob = cv::dnn::blobFromImage(image); // 由图片加载数据 这里还可以进行缩放、归一化等预处理
net.setInput(blob); // 设置模型输入
cv::Mat predict = net.forward(); // 推理出结果