全球最实用的IT互联网信息网站!

AI人工智能P2P分享&下载搜索网页发布信息网站地图

当前位置:诺佳网 > 电子/半导体 > 模拟技术 >

简单探讨一下直方图及其反向投影的应用

时间:2023-01-18 10:35

人气:

作者:admin

标签: 探讨  直方图  一下    简单 

导读:在计算机视觉中,直方图的有着很广泛的的应用,通常用来统计图像中的某些特征,比如边缘特征、色彩特征、梯度特征等等。...

前言

计算机视觉中,直方图的有着很广泛的的应用,通常用来统计图像中的某些特征,比如边缘特征、色彩特征、梯度特征等等。

直方图通过一种统计的方法,来表征图形的特征。这篇文章简单来探讨一下直方图以及它的一个应用--反向投影。

直方图

直返图的计算其实很简单,和我们数学中的直方图差不多,就是统计某一特征,在这里我们用统计灰度值举例子。

首先来看一段画直方图的代码:

#include 
#include 


using namespace cv;
using namespace std;


int main(int argc, char **argv)
{
    Mat img = imread("football2.png");
    cout << "img size " << img.size() << endl;
    cvtColor(img, img, COLOR_BGR2GRAY);
    imshow("img", img);


    Rect rect(330, 270, 160, 160); //lofated of football
    Mat img_obj = img(rect);
    imshow("img_obj", img_obj);


    int bin = 4;
    int channels = 0;
    int size = 256 / bin;
    float hranges[] = {0, 256};
    const float *ranges[] = {hranges};
    const float *ranges_back = {hranges};


    // 计算直方图
    MatND hist;
    calcHist(&img_obj, 1, &channels, Mat(), hist, 1, &size, ranges);


    double minValue = 0;
    double maxValue = 0;
    minMaxLoc(hist, &minValue, &maxValue, 0, 0);
    cout << "maxValue: " << maxValue << endl;


    Mat img_hist(maxValue, size, CV_8UC3, Scalar(0, 0, 0));
    for (int i = 0; i < size; i++)
    {
        float bin_value = hist.at<float>(i);
        rectangle(img_hist,Point(i, maxValue), Point(i+1, maxValue-bin_value), Scalar(0, 255, 0));
    }
    imshow("img_hist", img_hist);


    ......
    waitKey(0);
    return 0;
}

直方图有个一概念,就是bin,其实是组距的意思,代码中是4,就是按照[0, 4)、[4, 8)、[8, 12)......[251,255)为x轴来做统计的。

整个代码其实简单,OpenCV画直方图的函数是calcHist,我们要了解函数的用法以及每个参数的意思,在这了不在赘述。另外,它的原理其实不难,如果想自己实现一下,应该也是比较简单的。

反向投影

在这篇博客https://blog.csdn.net/zhangjunp3/article/details/79862424是这样说的

反向投影其实是直方图运算的逆过程。直方图运算是统计每个灰度值对应的像素个数,而反向投影则是将像素个数回送到该像素个数对应灰度区间的像素位置。

反向投影是直方图运算的逆过程,这个是最最要的内容,上面讲的已经差不多了,下面我们自己来实现一下反向投影。

接着上面直方图的代码继续:

......
  //将直方图归一化为[0, 255]区间,方面下面可视化
    normalize(hist, hist, 0, 255, NORM_MINMAX, -1, Mat());


    Mat img_back_proj = img.clone();
    for (int i = 0; i < img_back_proj.rows; i++)
    {
        uchar *p = img_back_proj.ptr

代码的核心就是这句话:p[j] = hist.at(p[j] / bin);

将p[j]位置的像素值带到直放图的x轴,得到该像素值在直方图中的个数,用统计的个数取代原先的像素值。

代码的运行结果如下:

2.jpg

可以看出来,在这个例子中足球的匹配效果还是很好的,

在这个例子中,我们用的是灰度值做的直方图,另外的一些特征,比如颜色,边缘都是可以用来做统计的。

审核编辑:刘清

温馨提示:以上内容整理于网络,仅供参考,如果对您有帮助,留下您的阅读感言吧!
相关阅读
本类排行
相关标签
本类推荐

CPU | 内存 | 硬盘 | 显卡 | 显示器 | 主板 | 电源 | 键鼠 | 网站地图

Copyright © 2025-2035 诺佳网 版权所有 备案号:赣ICP备2025066733号
本站资料均来源互联网收集整理,作品版权归作者所有,如果侵犯了您的版权,请跟我们联系。

关注微信