OpenCV4.0入门(20)图像直方图反向投影

知识点:

图像直方图反向投影:

图像直方图反向投影是通过构建指定模板图像的二维直方图空间与目标的二维直方图空间,进行直方图数据归一化之后, 进行比率操作,对所有得到非零数值,生成查找表对原图像进行像素映射之后,再进行图像模糊输出的结果。

直方图反向投影流程:

- 计算直方图

- 计算比率R

- LUT查找表

- 卷积模糊

- 归一化输出

相关API:

void calcBackProject( const Mat* images, int nimages,
                      const int* channels, InputArray hist,
                      OutputArray backProject, const float** ranges,
                      double scale = 1, bool uniform = true );

- images:目标图像数组;

- nimages:目标图像的个数;

- channels:需要进行统计的通道数组,第一个数组通道从0到image[0].channels()-1,第二个数组从image[0].channels()到images[0].channels()+images[1].channels()-1,以后的数组以此类推;

- hist:模板图像;

- backProject:目标图像反向投影后的输出图像;

- ranges:每一个特征维度中bin的取值范围;

- scale:是否需要对图像进行放缩,默认1.0即可;

- uniform:直方图是否均匀的标识符,默认为true。

注意:

事实上,在OpenCV中,为了加快速度,进行直方图的反向投影并不会进行计算比率R的这一步操作,在得到模板图形的直方图数据,且进行归一化操作之后,OpenCV直接进行模板图像和目标图像的LUT查找表映射,最终得到反射投影后的结果。

上文所说的直方图反射投影的流程,具体实现代码可以参考贾志刚老师的CV4J开源代码,纯Java语言的轻量级图像处理库。

 

代码演示:

#ifndef DAY20
#define DAY20

#include <opencv2/opencv.hpp>
#include <iostream>

using namespace std;
using namespace cv;

void backProjection_demo(Mat &image, Mat &model);

void day20() {

	Mat src = imread("G:/opencvTest/target.png");
	Mat model = imread("G:/opencvTest/sample.png");
	if (src.empty() || model.empty()) {
		printf("could not load image...\n");
		return;
	}
	imshow("target", src);
	imshow("model", model);

	backProjection_demo(src, model);

	waitKey();
}

void backProjection_demo(Mat &image, Mat &model) {
	// 转化为HSV色彩空间
	Mat model_hsv, image_hsv;
	cvtColor(model, model_hsv, COLOR_BGR2HSV);
	cvtColor(image, image_hsv, COLOR_BGR2HSV);

	// 定义直方图参数与属性
	int h_bins = 32; int s_bins = 32;
	int histSize[] = { h_bins, s_bins };
	// h通道取值范围0到180,s通道取值范围0到256
	float h_ranges[] = { 0, 180 };
	float s_ranges[] = { 0, 256 };
	const float* ranges[] = { h_ranges, s_ranges };
	int channels[] = { 0, 1 };

	// 计算model的直方图
	Mat roiHist;
	calcHist(&model_hsv, 1, channels, Mat(), roiHist, 2, histSize, ranges);

	// 直方图归一化
	normalize(roiHist, roiHist, 0, 255, NORM_MINMAX, -1, Mat());

	// 直方图二维化显示
	Mat roiHist_Show;
	roiHist.convertTo(roiHist_Show, CV_8UC3);
	resize(roiHist_Show, roiHist_Show, Size(400, 400));
	imshow("roiHist_Show_400x400", roiHist_Show);

	// 将image和model进行反向投影,得到反向投影后的结果backproj
	MatND backproj;
	calcBackProject(&image_hsv, 1, channels, roiHist, backproj, ranges, 1.0);

	// 显示backproj
	imshow("BackProj", backproj);
}

#endif // !DAY20

 

结果展示:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Apple_Coco

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值