OpenCV DNN单张与多张图像的推断

本文介绍如何使用OpenCV的DNN模块进行单张和多张图像的推断,详细解析了blobFromImage与blobFromImages函数,并提供了C++和Python的代码示例,展示了如何加载预训练模型并执行图像分类。

转载请注明作者和出处: http://blog.youkuaiyun.com/john_bh/

1. blobFromImage与blobFromImages

OpenCV DNN中支持单张图像推断,同时还支持分批次方式的图像推断,对应的两个相关API分别为blobFromImage与blobFromImages,它们的返回对象都是一个四维的Mat对象-按照顺序分别为NCHW 其组织方式详解如下:

  • N表示多张图像 ;
  • C表示接受输入图像的通道数目 ;
  • H表示接受输入图像的高度 ;
  • W表示接受输入图像的宽度。
Mat cv::dnn::blobFromImage(
	InputArray 	image,
	double 	scalefactor = 1.0,
	const Size & 	size = Size(),
	const Scalar & 	mean = Scalar(),
	bool 	swapRB = false,
	bool 	crop = false,
	int 	ddepth = CV_32F
)

Mat cv::dnn::blobFromImages(
	InputArrayOfArrays 	images,
	double 	scalefactor = 1.0,
	Size 	size = Size(),
	const Scalar & 	mean = Scalar(),
	bool 	swapRB = false,
	bool 	crop = false,
	int 	ddepth = CV_32F 
)

参数解释:

  • Images:表示多张图像,image表示单张图像 ;
  • Scalefactor:表示放缩 ;
  • Size:表示图像大小 ;
  • Mean:表示均值;
  • swapRB:是否交换通道 ;
  • crop:是否剪切 ;
  • ddepth: 输出的类型,默认是浮点数格式。

2. 代码实现

2.1 C++

#include <opencv2/opencv.hpp>
#include <opencv2/dnn.hpp>
#include <iostream>
#include <fstream>
/******************************************************
*
********************************************************/
using namespace cv;
using namespace cv::dnn;
using namespace std;


String bin_model = "D:/projects/opencv_tutorial/data/models/googlenet/bvlc_googlenet.caffemodel";
String protxt = "D:/projects/opencv_tutorial/data/models/googlenet/bvlc_googlenet.prototxt";
String labels_txt_file = "D:/vcworkspaces/classification_classes_ILSVRC2012.txt";
vector<String> readClassNames()
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值