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

 更新时间:2020年4月25日 17:24  点击:2443

直方图反向投影:

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

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++ 直方图反向投影实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持猪先飞。

[!--infotagslink--]

相关文章

  • opencv3/C++轮廓的提取与筛选方式

    今天小编就为大家分享一篇opencv3/C++轮廓的提取与筛选方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-25
  • opencv3/C++ 直方图反向投影实例

    今天小编就为大家分享一篇opencv3/C++ 直方图反向投影实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-25
  • opencv3/C++实现光流点追踪

    今天小编就为大家分享一篇opencv3/C++实现光流点追踪,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-25
  • R语言-绘制双坐标图直方图与折线的结合方式

    这篇文章主要介绍了R语言-绘制双坐标图直方图与折线的结合方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-05-06
  • R语言作图之直方图histogram绘制过程详解

    这篇文章主要介绍了R语言作图之直方图histogram详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-05-06
  • opencv3/C++ HOG特征提取方式

    今天小编就为大家分享一篇opencv3/C++ HOG特征提取方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-25
  • opencv3/C++基于颜色的目标跟踪方式

    今天小编就为大家分享一篇opencv3/C++基于颜色的目标跟踪方式,具有很好的参考价值,希望对的有所帮助。一起跟随小编过来看看吧...2020-04-25
  • opencv3/C++ FLANN特征匹配方式

    今天小编就为大家分享一篇opencv3/C++ FLANN特征匹配方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-25
  • R语言histogram(直方图)的具体使用

    这篇文章主要介绍了R语言histogram(直方图)的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-05-06
  • python 对一幅灰度图像进行直方图均衡化

    这篇文章主要介绍了python 如何对一幅灰度图像进行直方图均衡化,帮助大家更好的利用python处理图像,感兴趣的朋友可以了解下...2020-10-27
  • opencv3/C++实现霍夫圆/直线检测

    今天小编就为大家分享一篇opencv3/C++实现霍夫圆/直线检测,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-25
  • opencv3/C++ PHash算法图像检索详解

    今天小编就为大家分享一篇opencv3/C++ PHash算法图像检索详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-25
  • opencv3/C++ 将图片转换为视频的实例

    今天小编就为大家分享一篇opencv3/C++ 将图片转换为视频的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-25
  • python使用numpy实现直方图反向投影示例

    今天小编就为大家分享一篇python使用numpy实现直方图反向投影示例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-27
  • opencv3/C++绘制几何图形实例

    今天小编就为大家分享一篇opencv3/C++绘制几何图形实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-25
  • opencv3/C++图像边缘提取方式

    今天小编就为大家分享一篇opencv3/C++图像边缘提取方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-25
  • VS2015+Qt5+OpenCV3开发环境配置

    这篇文章主要为大家详细介绍了VS2015+Qt5+OpenCV3开发环境配置,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-22
  • Opencv实现二维直方图的计算及绘制

    这篇博客将介绍如何使用Opencv进行二维直方图的计算及绘制,维直方图可以让我们对不同的像素密度有更好的了解,感兴趣的可以了解一下...2021-07-19
  • opencv3/C++关于移动对象的轮廓的跟踪详解

    今天小编就为大家分享一篇opencv3/C++关于移动对象的轮廓的跟踪详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-25
  • R语言绘制频率直方图的案例

    这篇文章主要介绍了R语言绘制频率直方图的案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-05-06