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++模板 index_sequence使用示例详解

    C++模板 index_sequence使用示例详解

    这篇文章主要为大家介绍了C++模板 index_sequence使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • 基于C语言的库封装发布技术详解

    基于C语言的库封装发布技术详解

    在编程的过程中,使用已经封装好的库函数是十分方便的,也是十分高效的,这篇文章主要给大家介绍了关于C语言库的封装和使用的相关资料,需要的朋友可以参考下
    2021-08-08
  • Qt实现编写SMTP客户端的示例详解

    Qt实现编写SMTP客户端的示例详解

    这篇文章主要介绍了如何通过Qt实现编写SMTP客户端,可以实现通过SMTP发送电子邮件(有文本,html,附件,内联文件等的MIME)。并支持SSL和SMTP身份验证,感兴趣的可以学习一下
    2022-11-11
  • 老生常谈C语言中指针的使用

    老生常谈C语言中指针的使用

    这篇文章主要为大家详细介绍了C语言中指针的使用,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • c++中queue用法超详细讲解(入门必看!)

    c++中queue用法超详细讲解(入门必看!)

    queue是一种容器转换器模板,调用#include< queue>即可使用队列类,下面这篇文章主要给大家介绍了关于c++中queue用法超详细讲解的相关资料,需要的朋友可以参考下
    2022-10-10
  • C++使用MySQL-Connector/C++连接MySQL出现LNK2019错误的解决方法

    C++使用MySQL-Connector/C++连接MySQL出现LNK2019错误的解决方法

    这篇文章主要介绍了C++使用MySQL-Connector/C++连接MySQL出现LNK2019错误的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-03-03
  • C++变量,常量,数组和字符串详解

    C++变量,常量,数组和字符串详解

    这篇文章主要介绍了C++变量,常量,数组和字符串,是C++入门学习中的基础知识,需要的朋友可以参考下,希望能够给你带来帮助
    2021-10-10
  • 基于C语言实现的迷宫算法示例

    基于C语言实现的迷宫算法示例

    这篇文章主要介绍了基于C语言实现的迷宫算法,结合具体实例形式分析了C语言解决迷宫问题算法的实现技巧与相关注意事项,需要的朋友可以参考下
    2017-09-09
  • 利用C++模拟实现STL容器:list

    利用C++模拟实现STL容器:list

    列表是一种顺序容器,它允许在序列中的任何位置执行常量时间插入和删除操作,并允许在两个方向上进行迭代。本文将利用C++模拟实现list,希望对大家有所帮助
    2022-12-12
  • C++生成格式化的标准字符串实例代码

    C++生成格式化的标准字符串实例代码

    这篇文章主要给大家介绍了关于C++生成格式化的标准字符串的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用C++具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09

最新评论