opencv3/C++ 直方图反向投影实例

 更新时间:2019年12月11日 17:33:14   作者:阿卡蒂奥  
今天小编就为大家分享一篇opencv3/C++ 直方图反向投影实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

直方图反向投影:

即取直方图中的值,按直方图面积由大到小,对其对应的像素也由大到小赋予新值。即某种灰度值在图像中所占面积越大,其对应的像素的新值就越大;反之就越小。

void calcBackProject( 
const Mat* images, //源数组/图像;有相同的大小和深度(CV_8U或CV_32F)。
int nimages,//源图像的数量
const int* channels, //计算反投影的通道列表;通道数量必须与直方图维度相匹配。
InputArray hist,//输入直方图。
OutputArray backProject, //目标反向投影数组,与images[0]大小、深度相同的单通道数组。
const float** ranges,//每个维度的直方图bin边界数组。
double scale = 1, //输出反向投影的可选比例因子。
bool uniform = true //直方图是否均匀的标志。
);

示例:

获取测试图像中每个像素的hue数据 hi,j,并找到 hi,j 在hue直方图中的bin的位置

#include<opencv2/opencv.hpp>
using namespace cv;

Mat hue;
int bins = 10;
void histBackprojection(int, void*);
int main()
{
 Mat src, hsv;
 src = imread("E:/image/image/shape.jpg");
 if (src.empty())
 {
  printf("can not load image \n");
  return -1;
 }
 namedWindow("input", WINDOW_AUTOSIZE); 
 imshow("input", src);
 cvtColor(src, hsv, COLOR_BGR2HSV); 
 hue.create(hsv.size(), hsv.depth());
 int ch[] = {0, 0};
 //分离Hue通道:色相通道
 mixChannels(&hsv, 1, &hue, 1, ch, 1);
 //创建Trackbar来输入bin的数目
 createTrackbar("bins:", "input", &bins, 255, histBackprojection);
 histBackprojection(0, 0);
 waitKey(0);
 return 0;
}

void histBackprojection(int, void*)
{
 MatND hist, backproj;
 int histSize = max(bins, 2);
 float range[] = {0, 255};
 const float *ranges = {range};
 //计算直方图
 calcHist(&hue, 1, 0, Mat(), hist,1, &histSize, &ranges, true, false);
 //将直方图bin的数值归一化到0-255
 normalize(hist, hist, 0, 255, NORM_MINMAX, -1, Mat());
 //计算反向投影
 calcBackProject(&hue, 1, 0, hist, backproj, &ranges, 1, true);
 namedWindow("backprogection", WINDOW_AUTOSIZE);
 imshow("backprogection", backproj);
 //显示直方图
 int binsW = cvRound((double)500/histSize);
 Mat histImg = Mat::zeros(500, 500, CV_8UC3);
 RNG rng(123);
 for (int i = 0; i < bins; i++)
 {
  Scalar color = Scalar(rng.uniform(0,255),rng.uniform(0,255),rng.uniform(0,255));
  rectangle(histImg, Point(i*binsW, 500), Point((i+1)*binsW, 500 - cvRound(hist.at<float>(i) * 500 / 255.0)), color, -1);
 }
 namedWindow("histogram", WINDOW_AUTOSIZE);
 imshow("histogram", histImg);
}

以上这篇opencv3/C++ 直方图反向投影实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • C语言中炫酷的文件操作实例详解

    C语言中炫酷的文件操作实例详解

    内存中的数据都是暂时的,当程序结束时,它们都将丢失,为了永久性的保存大量的数据,C语言提供了对文件的操作,这篇文章主要给大家介绍了关于C语言中文件操作的相关资料,需要的朋友可以参考下
    2021-10-10
  • C++实现地铁自动售票系统程序设计

    C++实现地铁自动售票系统程序设计

    这篇文章主要为大家详细介绍了C++实现地铁自动售票系统程序设计,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • C++中的new/delete、构造/析构函数、dynamic_cast分析

    C++中的new/delete、构造/析构函数、dynamic_cast分析

    这篇文章主要介绍了C++中的new/delete、构造/析构函数、dynamic_cast分析 本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-05-05
  • C++ 两个vector对象拼接方式

    C++ 两个vector对象拼接方式

    这篇文章主要介绍了C++ 两个vector对象拼接方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • 详细理解函C语言的函数栈帧

    详细理解函C语言的函数栈帧

    这篇文章主要为大家介绍了C语言的函数栈帧,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助,希望能够给你带来帮助
    2021-11-11
  • C++实现的归并排序算法详解

    C++实现的归并排序算法详解

    这篇文章主要介绍了C++实现的归并排序算法,结合实例形式详细分析了归并排序算法的原理、实现步骤、操作技巧与使用方法,需要的朋友可以参考下
    2017-05-05
  • C语言陷阱与缺陷之数组越界访问详解

    C语言陷阱与缺陷之数组越界访问详解

    这篇文章主要为大家详细介绍了C语言的数组越界访问,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • 如何用C++实现双向循环链表

    如何用C++实现双向循环链表

    本篇文章是对用C++实现双向循环链表的方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • c语言中如何修改文件中间的几个字节

    c语言中如何修改文件中间的几个字节

    工作中碰到一个问题,如何只修改文件中间的几个字节,而其他的内容不变。这个问题看似简单,但是很多人估计都不知道怎么做。我开始seek到文件的特定的位置,然后写文件,但是使用的文件打开模式不对,文件不是被清空,就是被截断,达不到效果
    2020-10-10
  • Vs2019+Qt+Opencv环境配置心得(图文)

    Vs2019+Qt+Opencv环境配置心得(图文)

    这篇文章主要介绍了Vs2019+Qt+Opencv环境配置心得(图文),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08

最新评论