直方图概述

简单来说,直方图就是对数据进行统计的一种方法,这些数据可以是梯度、方向、色彩或任何其他特征。它的表现形式是一种二维统计表,横纵坐标分别是统计样本和该样本对应的某个属性的度量。

计算直方图:calcHist 函数

calcHist 函数用于计算一个或多个阵列的直方图。

void calcHist(const Mat* images, int nimages, const int* channels, InputArray mask, OutputArray hist, int dims, const int* histSize, const float** ranges, bool uniform = true, bool accumul = false);

  • images,输入的数组(图像)或数组集(图像集),他们需为相同深度(CV_8U 或 CV_32F)和相同尺寸。
  • nimages,第一个参数中存放了多少张图象。
  • channels,图像索引,会按照索引顺序依次计算图像直方图(注意,第一张图片索引为 0,以此类推)。
  • mask,可选的掩膜操作,非零掩码元素用于标记待统计元素,需要与输入图像集有相同尺寸。
  • hist,输出的目标直方图,一个二维数组。
  • dims,输出目标直方图的维度。一般设为 1(线)。
  • histSize,x 轴将被分成 histSize 份。
  • ranges,x 的取值范围。
  • uniform,直方图是否归一化的标识符,默认为 true。
  • accumulate,在计算直方图时是否清空传入的 hist。true 表示不清空,false 表示清空。默认为 false。只有在想要统计多个图像序列中的累加直方图时才会设置为 true。

代码示例:

  1. #include<opencv.hpp>
  2. #include<iostream>
  3. using namespace std;
  4. using namespace cv;
  5. int main() {
  6. Mat src = imread("C:/Users/齐明洋/Desktop/证件照/6.jpg");
  7. imshow("src", src);
  8.  
  9. //计算 BGR 三通道各自直方图
  10. vector<Mat>bgr();
  11. int channels[] = { ,, };
  12. int histsize[] = { ,, };
  13. float r[] = { , };
  14. const float* ranges[] = { r,r,r };
  15. calcHist(&src, , &channels[], Mat(), bgr[], , &histsize[], &ranges[], true);
  16. calcHist(&src, , &channels[], Mat(), bgr[], , &histsize[], &ranges[], true);
  17. calcHist(&src, , &channels[], Mat(), bgr[], , &histsize[], &ranges[], true);
  18.  
  19. //直方图归一化
    //https://www.cnblogs.com/bjxqmy/p/12292421.html
  20. int w = , h = ;
  21. normalize(bgr[], bgr[], h, , NORM_L1);
  22. normalize(bgr[], bgr[], h, , NORM_L1);
  23. normalize(bgr[], bgr[], h, , NORM_L1);
  24.  
  25. //绘制直方图
  26. string names[] = { "b_img","g_img","r_img" };
  27. Mat dst[];//绘在三张背景上
  28. dst[] = Mat(h, w, src.type(), Scalar(, , ));
  29. dst[] = dst[].clone();
  30. dst[] = dst[].clone();
  31. double width[] = { w / histsize[],w / histsize[],w / histsize[] };
  32. Scalar colors[] = { Scalar(,,),Scalar(,,) ,Scalar(,,) };
  33. for (int i = ; i < ; i++) {
  34. for (int j = ; j < histsize[i]; j++) {
  35. Point pre = Point(j*width[i], h);
  36. Point next = Point(j*width[i], h - bgr[i].at<float>(j));
  37. line(dst[i], pre, next, colors[i], );
  38. }
  39. imshow(names[i], dst[i]);
  40. }
  41. waitKey();
  42. }

效果演示:

借鉴博客:https://blog.csdn.net/zhu_hongji/article/details/81663161

opencv —— calcHist、minMaxLoc 计算并绘制图像直方图、寻找图像全局最大最小值的更多相关文章

  1. OpenCV 学习(计算图像的直方图)

    OpenCV 计算图像的直方图 计算图像的直方图是图像处理领域一个非经常见的基本操作. OpenCV 中提供了 calcHist 函数来计算图像直方图.只是这个函数说实话挺难用的,研究了好久才掌握了些 ...

  2. C++ 彩色图像(RGB)三通道直方图计算和绘制,图像逆时针旋转90° 实现代码

    #include "iostream" #include "opencv2/opencv.hpp" #include "vector" us ...

  3. OpenCV计算机视觉学习(9)——图像直方图 & 直方图均衡化

    如果需要处理的原图及代码,请移步小编的GitHub地址 传送门:请点击我 如果点击有误:https://github.com/LeBron-Jian/ComputerVisionPractice 1, ...

  4. OpenCV成长之路(4):图像直方图

    一.图像直方图的概念 图像直方图是反映一个图像像素分布的统计表,其实横坐标代表了图像像素的种类,可以是灰度的,也可以是彩色的.纵坐标代表了每一种颜色值在图像中的像素总数或者占所有像素个数的百分比. 图 ...

  5. OpenCV成长之路:图像直方图

    http://ronny.blog.51cto.com/8801997/1394115 2014-04-11 13:47:27 标签:opencv 直方图 统计表 原创作品,允许转载,转载时请务必以超 ...

  6. Python 图像处理 OpenCV (16):图像直方图

    前文传送门: 「Python 图像处理 OpenCV (1):入门」 「Python 图像处理 OpenCV (2):像素处理与 Numpy 操作以及 Matplotlib 显示图像」 「Python ...

  7. opencv——图像直方图与反向投影

    引言 在图像处理中,对于直方图这个概念,肯定不会陌生.但是其原理真的可以信手拈来吗? 本文篇幅有点长,在此列个目录,大家可以跳着看: 分析图像直方图的概念,以及opencv函数calcHist()对于 ...

  8. 【图像处理】基于OpenCV实现图像直方图的原理

    背景 图像的直方图是衡量图像像素分布的一种方式,可以通过分析像素分布,使用直方图均衡化对图像进行优化,让图像变的清晰. opencv官方对图像直方图的定义如下: 直方图是图像中像素强度分布的图形表达方 ...

  9. OpenCV成长之路(5):图像直方图的应用

    正如第4篇文章所说的图像直方图在特征提取方面有着很重要的作用,本文将举两个实际工程中非常实用的例子来说明图像直方图的应用. 一.直方图的反向映射. 我们以人脸检测举例,在人脸检测中,我们第一步往往需要 ...

随机推荐

  1. python 面向对象-初识

    一.分类 1.面向过程 2.面向函数 3.面向对象 二.类和对象 1.宏关 类是抽象的,对象是具体的 2.实例化 类->对象 3.类的作用 1)实例化成对象 实例化的过程,创建self对象,调用 ...

  2. Java入门 - 语言基础 - 22.异常处理

    原文地址:http://www.work100.net/training/java-exception.html 更多教程:光束云 - 免费课程 异常处理 序号 文内章节 视频 1 概述 2 Exce ...

  3. Scala 学习(4)之「类——基本概念2」

    目录 内部类 extends override和super override field isInstanceOf和asInstanceOf getClass和classOf 内部类 import s ...

  4. 【java面试】Web篇

    1.AJAX创建步骤 step1. 创建XMLHttpRequest对象,也就是创建一个异步调用对象:  step2. 创建一个新的HTTP请求,并指定改HTTP请求的方法.URL以及验证信息:  s ...

  5. Python-logging模块简单使用

    logging模块只要用于日志的打印.模块的源码在:Lib/logging/__init__.py 其中,logging.basicConfig(**kwargs)方法用于进行基本的属性配置,它的参数 ...

  6. python实例:自动爬取豆瓣读书短评,分析短评内容

    思路: 1.打开书本“更多”短评,复制链接 2.脚本分析链接,通过获取短评数,计算出页码数 3.通过页码数,循环爬取当页短评 4.短评写入到txt文本 5.读取txt文本,处理文本,输出出现频率最高的 ...

  7. CSS-18-媒体查询

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  8. ios--->使用@synchronized和dispatch_once实现单例

    使用dispatch_once实现单例 单例实现的两种模式 @implementation XXClass //@synchronized来实现 + (id)sharedInstance { stat ...

  9. windows系统中如何找到某程序运行的本地文件

    主要通过window自带的服务功能来查询: 比如:

  10. java操作数组转list集合删除元素报错ConcurrentModificationException

    public static void main(String[] args) { ArrayList<String> list = new ArrayList<String>( ...