我的编程空间,编程开发者的网络收藏夹
学习永远不晚

基于OpenCV如何生成图像直方图

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

基于OpenCV如何生成图像直方图

这篇文章将为大家详细讲解有关基于OpenCV如何生成图像直方图,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

01. 什么是图像直方图?

在开始定义直方图之前,为简单起见我们先使用灰度图像,稍后再解释彩色图像的处理过程。

图像直方图表示图像的像素分布情况。换言之,图像直方图显示具有特定像素值的图像点数量。例如,假设正常图像的像素强度在0到255之间变化。为了生成其直方图,我们只需要计算像素值为0的像素数量,然后计算1并继续到255即可。在图1中,我们有一个5 * 5的样本图像,我们通过计算每个像素强度的数量来创建直方图表。

基于OpenCV如何生成图像直方图

图1:生成图像直方图的过程

02. 如何生成图像直方图?

在python中,我们可以使用以下两个函数来创建然后显示图像的直方图。

import matplotlib.pyplot as pltimport numpy as np  def generate_histogram(img, do_print):  """  @params: img: can be a grayscale or color image. We calculate the Normalized histogram of this image.  @params: do_print: if or not print the result histogram  @return: will return both histogram and the grayscale image   """  if len(img.shape) == 3: # img is colorful, so we convert it to grayscale    gr_img = np.mean(img, axis=-1)  else:    gr_img = img  '''now we calc grayscale histogram'''  gr_hist = np.zeros([256])    for x_pixel in range(gr_img.shape[0]):    for y_pixel in range(gr_img.shape[1]):      pixel_value = int(gr_img[x_pixel, y_pixel])      gr_hist[pixel_value] += 1    '''normalizing the Histogram'''  gr_hist /= (gr_img.shape[0] * gr_img.shape[1])  if do_print:    print_histogram(gr_hist, name="n_h_img", title="Normalized Histogram")  return gr_hist, gr_img   def print_histogram(_histrogram, name, title):  plt.figure()  plt.title(title)  plt.plot(_histrogram, color='#ef476f')  plt.bar(np.arange(len(_histrogram)), _histrogram, color='#b7b7a4')  plt.ylabel('Number of Pixels')  plt.xlabel('Pixel Value')  plt.savefig("hist_" + name)

在大多数情况下,当我们创建直方图时,我们通过将每个强度值的像素数除以归一化因子(即图像宽度和图像高度的乘积)来对直方图进行归一化。为了便于使用,如果generate_histogram函数的输入图像是彩色图像,我们首先将其转换为灰度图像(请参见第6行)。

03. 如何均衡图像直方图?

直方图均衡化通常用于增强图像的对比度。因此,该技术不能保证始终提高图像质量。计算CDF(累积分布函数)是均衡图像直方图的常用方法。在图2中,我们计算了在图1中创建的样本图像的CDF。此外,在图3中,我们显示了先前样本的均衡直方图。

基于OpenCV如何生成图像直方图

图2:计算CDF。

基于OpenCV如何生成图像直方图

图3:均方图。

为了计算python中的均衡直方图,我们创建了以下代码:

def equalize_histogram(img, histo, L):  eq_histo = np.zeros_like(histo)  en_img = np.zeros_like(img)  for i in range(len(histo)):    eq_histo[i] = int((L - 1) * np.sum(histo[0:i]))  print_histogram(eq_histo, name="eq_"+str(index), title="Equalized Histogram")  '''enhance image as well:'''  for x_pixel in range(img.shape[0]):    for y_pixel in range(img.shape[1]):      pixel_val = int(img[x_pixel, y_pixel])      en_img[x_pixel, y_pixel] = eq_histo[pixel_val]  '''creating new histogram'''  hist_img, _ = generate_histogram(en_img, print=False, index=index)  print_img(img=en_img, histo_new=hist_img, histo_old=histo, index=str(index), L=L)  return eq_histo

这是我们拍摄的3张不同图片,并用作示例。如图4所示,对于第一个图像,直方图显示低强度像素的数量多于明亮像素。对于第二张图像,情况完全相反,其中较亮像素的密度远大于较暗像素的密度。第三张图片似乎具有半正态直方图。

基于OpenCV如何生成图像直方图

基于OpenCV如何生成图像直方图

基于OpenCV如何生成图像直方图

图4:三种不同类型的图像及其直方图和均等的直方图。

使用均衡直方图增强图像

如前所述,我们可以使用图像的均衡直方图修改图像的对比度。如代码2第12行所示,对于输入图像中的每个像素,我们可以使用其均等值。结果可能比原始图像更好,但不能保证。在图5中,我们描述了3张图像的修改版本。如图所示,使用其均等的直方图修改图像会产生对比度更高的图像。此功能在许多计算机视觉任务中很有用。

基于OpenCV如何生成图像直方图

基于OpenCV如何生成图像直方图

基于OpenCV如何生成图像直方图

图5:使用均衡直方图的对比度修改。最左列是原始图像。中间一栏是对比度修改的结果。

最右边的列是修改后的图像的直方图。

04. 什么是直方图匹配?

假设我们有两个图像,每个图像都有其特定的直方图。因此,我们想在进一步解决此问题之前,是否可以根据另一幅图像的对比度来修改一幅图像?答案是肯定的。实际上,这就是直方图匹配的定义。换句话说,给定图像A和B,可以根据B修改A的对比度。

当我们要统一一组图像的对比度时,直方图匹配非常有用。实际上,直方图均衡也可以视为直方图匹配,因为我们将输入图像的直方图修改为与正态分布相似。

为了匹配图像A和B的直方图,我们需要首先均衡两个图像的直方图。然后,我们需要使用均衡后的直方图将A的每个像素映射到B。然后,我们基于B修改A的每个像素。

让我们使用图6中的以下示例来阐明以上段落。

基于OpenCV如何生成图像直方图

图6:直方图匹配

在图6中,我们将图像A作为输入图像,将图像B作为目标图像。我们要基于B的分布来修改A的直方图。第一步,我们计算A和B的直方图和均等直方图。然后,我们需要根据该值映射A的每个像素它的均衡直方图求B的值。因此,例如,对于A中强度级别为0的像素,A均衡直方图的对应值为4。现在,我们看一下B均衡直方图并找到强度值对应于4,即0。因此我们将0强度从A映射到0 从B开始。对于A的所有强度值,我们继续进行。如果从A到B的均衡直方图中没有映射,我们只需要选择最接近的值即可。

def find_value_target(val, target_arr):  key = np.where(target_arr == val)[0]    if len(key) == 0:    key = find_value_target(val+1, target_arr)    if len(key) == 0:      key = find_value_target(val-1, target_arr)  vvv = key[0]  return vvv    def match_histogram(inp_img, hist_input, e_hist_input, e_hist_target, _print=True):  '''map from e_inp_hist to 'target_hist '''  en_img = np.zeros_like(inp_img)  tran_hist = np.zeros_like(e_hist_input)  for i in range(len(e_hist_input)):    tran_hist[i] = find_value_target(val=e_hist_input[i], target_arr=e_hist_target)  print_histogram(tran_hist, name="trans_hist_", title="Transferred Histogram")  '''enhance image as well:'''  for x_pixel in range(inp_img.shape[0]):    for y_pixel in range(inp_img.shape[1]):      pixel_val = int(inp_img[x_pixel, y_pixel])      en_img[x_pixel, y_pixel] = tran_hist[pixel_val]  '''creating new histogram'''  hist_img, _ = generate_histogram(en_img, print=False, index=3)  print_img(img=en_img, histo_new=hist_img, histo_old=hist_input, index=str(3), L=L)

基于OpenCV如何生成图像直方图

图7:直方图匹配示例。我们修改了左图像的直方图以匹配中心图像的直方图。

图7示出了直方图匹配的示例。如大家所见,尽管最左边的图像是明亮的图像,但就对比度级别而言,可以将中心图像视为更好的图像。因此,我们决定使用中心图像的收缩来修改最左边的图像。结果,即最右边的图像已得到改善。

关于“基于OpenCV如何生成图像直方图”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

基于OpenCV如何生成图像直方图

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

基于OpenCV如何生成图像直方图

这篇文章将为大家详细讲解有关基于OpenCV如何生成图像直方图,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。01. 什么是图像直方图?在开始定义直方图之前,为简单起见我们先使用灰度图像,稍后再解释彩色图像
2023-06-14

python OpenCV图像直方图如何处理

这篇“python OpenCV图像直方图如何处理”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“python OpenCV图
2023-07-02

C++ OpenCV如何生成蒙太奇图像

这篇文章主要介绍“C++ OpenCV如何生成蒙太奇图像”,在日常操作中,相信很多人在C++ OpenCV如何生成蒙太奇图像问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++ OpenCV如何生成蒙太奇图像
2023-06-26

OpenCV-Python直方图均衡化如何实现图像去雾

小编给大家分享一下OpenCV-Python直方图均衡化如何实现图像去雾,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!直方图均衡化直方图均衡化的目的是将原始图像的灰度级均匀地映射到整个灰度级范围内,得到一个灰度级分布均衡的
2023-06-15

matlab如何生成图像

这篇文章主要介绍“matlab如何生成图像”,在日常操作中,相信很多人在matlab如何生成图像问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”matlab如何生成图像”的疑惑有所帮助!接下来,请跟着小编一起来
2023-07-04

基于OpenCv与JVM如何实现加载保存图像功能

今天给大家介绍一下基于OpenCv与JVM如何实现加载保存图像功能。,文章的内容小编觉得不错,现在给大家分享一下,觉得有需要的朋友可以了解一下,希望对大家有所帮助,下面跟着小编的思路一起来阅读吧。加载图片openCv有一个名imread的简
2023-06-26

matlab生成的图像如何调出来

在MATLAB中生成的图像可以通过多种方式调出来:在MATLAB命令窗口中使用figure命令可以将当前图像显示出来。在MATLAB中使用imshow函数可以显示灰度图像或彩色图像。使用imtool函数可以在一个交互式的工具中显示图像,并且
matlab生成的图像如何调出来
2024-03-15

如何基于Python深度图生成3D点云详解

通常使用TOF等3d摄像头采集的格式一般只是深度图,下面这篇文章主要给大家介绍了关于如何基于Python深度图生成3D点云的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
2022-12-20

java 使用ImageIO.write如何生成jpeg图像

本篇文章给大家分享的是有关java 使用ImageIO.write如何生成jpeg图像,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。java 使用ImageIO.writer从
2023-05-31

基于Java生成图片验证码的方法解析

这篇文章主要来为大家详细介绍一下基于Java生成图片验证码的具体方法,文中的示例代码讲解详细,具有一定的借鉴价值,需要的可以参考一下
2023-02-06

Python OpenCV基于霍夫圈变换算法如何检测图像中的圆形

小编给大家分享一下Python OpenCV基于霍夫圈变换算法如何检测图像中的圆形,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!第一章:霍夫变换检测圆① 实例演示
2023-06-22

如何基于Python实现将列表数据生成折线图

这篇文章主要为大家展示了“如何基于Python实现将列表数据生成折线图”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何基于Python实现将列表数据生成折线图”这篇文章吧。代码下面直接发一下样
2023-06-29

基于PyQt5如何制作一个gif动态图片生成器

这篇文章的内容主要围绕基于PyQt5如何制作一个gif动态图片生成器进行讲述,文章内容清晰易懂,条理清晰,非常适合新手学习,值得大家去阅读。感兴趣的朋友可以跟随小编一起阅读吧。希望大家通过这篇文章有所收获!这个小工具制作的目的是为了将多张图
2023-06-28

C#合并BitMap图像如何生成超大bitmap

这篇文章主要介绍C#合并BitMap图像如何生成超大bitmap,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!当只需要两个图像合并的时候,可以简单的使用gdi+,把两个图像画到一个画布上面实现合并bitmap.当需要
2023-06-25

Python如何获取图片像素BGR值并生成纯色图

这篇“Python如何获取图片像素BGR值并生成纯色图”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python如何获取图片
2023-06-26

如何在pyqt5中展示pyecharts生成的图像

这期内容当中小编将会给大家带来有关如何在pyqt5中展示pyecharts生成的图像,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。下面通过一个实际的散点图案例,展示了如何使用pyqt5嵌套一个pyecha
2023-06-26

如何基于Python实现图像的傅里叶变换

这篇文章主要介绍了如何基于Python实现图像的傅里叶变换,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。前言首先是本文总体代码,改一下图像的读取路径就可以运行了,但我还是建议
2023-06-22

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录